Working with pull requests - deegree/deegree3 GitHub Wiki

Use of pull requests within the deegree project

To make best use of GitHub's fork and pull development model, we use the following procedure:

  • No major changes are pushed into the main repositories of the deegree group directly
  • Everybody is invited to fork the deegree repositories on GitHub
  • If you want a code enhancement to be included, please prepare a pull request
  • deegree's technical management committee (TMC) will review pending pull requests and merge the ones that are ready to go into the main repository. This is part of the biweekly TMC meetings.
  • Everybody is invited to join the TMC meetings to talk about the pull requests, especially the actual implementers!

Creating your own pull request

In order to create a pull request for a new feature or a bugfix it is advisable to follow these steps:

  • Create your own fork on GitHub

  • Add the original deegree repository as remote to your local clone, eg. git remote add deegree git://github.com/deegree/deegree3.git for the deegree3 repository

  • create a feature branch based on the current deegree master:

    • git checkout deegree/master
    • git checkout -b <my-new-branch-name>
  • Implement what you want to implement within your new branch

  • Create a pull request from that branch to the deegree master

If the deegree master is changed during your implementation phase, it might be a good idea to merge these changes into your branch from time to time using git merge deegree/master. Make sure you've previously fetched the remote changes using git fetch --all.

Checklist for pull requests

Any pull request must meet the following base requirements, before it is considered for inclusion:

  • Confirm you have read the contribution guidelines.
  • There is an issue describing the bug/enhancement/feature.
  • The description of the PR contains a link to the related issue and a short explanation what changes are included.
  • It must be possible to merge the pull request automatically. You can check this yourself by opening the PR in GitHub.
  • It must compile without errors and must not break any existing unit or integration tests. Here's a description for checking this yourself. Check the CI Jobs running on our Jenkins CI for errors.
  • New features that add configuration files or options need to include corresponding documentation updates for the handbook.
  • A pull request for the current version branch (current stable version) must come with a corresponding pull for main branch (current unstable version), or otherwise guarantee that the bugfix/improvement is not lost in the next version.
  • The pull request contains changes related to a single objective. If multiple concerns cannot be avoided, each one is in its own commit and has a separate issue describing it.
  • New unit tests have been added covering the changes you made.

Pull requests marked for deletion

On the rare occasion the TMC decides on not merging a PR into the deegree code base a pull request may be closed without being merged. The TMC tries to support every committer to pass the checklist as described above. In case the PR remains open for approx. 12 months and no substantial improvement has taken place to overcome the requested approvements the TMC will mark a pull request with the label "marked for deletion". After an additional time frame of approx. 1 month the TMC will close the PR.

Please keep in mind: No work will get lost. The code changes are still available and a closed pull request can be reopened.

Lifecycle of a Pull request

  • Open: Waiting for approval by the TMC
  • "Stuck": TMC has asked for improvements but got no feedback from the developer.
  • "Marked for Deletion": The PR was "Stuck" for approx. 12 months without any activity
  • Closed: After label "marked for deletion" was set and an additional month of inactivity the PR will be closed without being merged.