The Apache Brooklyn Git repositories are hosted in the ASF infrastructure and mirrored to Github. This is the current repository layout:
For everything except the most trivial changes, the submitter must have a CLA on file. Check the list of Apache committers, and non-commiters with ICLAs on record and prompt the contributor to file an appropriate CLA if required.
For all significant changes, there must be a Jira issue. If a Jira issue is not referenced in the PR and/or commit messages, prompt the contributor to open a Jira issue.
Follow these instructions to configure your local repositories. Make sure the canonical ASF repo is enabled as that is where you'll need to push to merge changes, and that you are able to fetch pull-requests.
Once that is done, run git fetch --all
to update from all remote repositories - you will see all the pull requests appear:
* [new ref] refs/pull/98/head -> upstream/pr/1234 * [new ref] refs/pull/99/head -> upstream/pr/1235
Fetch the latest remote branches, which will cause a remote branch for the PR to become available to you.
git fetch --all
If you want to inspect a particular PR and/or run tests, check out the branch:
git checkout upstream/pr/1234
To perform the merge, first update your master branch to the latest:
git checkout master git pull --rebase
Then merge and push:
git merge --no-ff -m 'This closes #1234' upstream/pr/1234 git push apache-git master
Note that this commit message is important, as this is what will trigger the pull request to be automatically closed, and the --no-ff
means that a merge commit will always be created.
Fetch the branch of the user you want to merge from (replacing -PROJECT
as appropriate):
git fetch https://github.com/user-to-merge-from/brooklyn-PROJECT.git branch-to-merge-from
If you commonly merge from a particular user, you'll want to add their repo as a remote to make fetching branches easier:
git remote add user-to-merge-from https://github.com/user-to-merge-from/brooklyn-PROJECT.git git fetch user-to-merge-from
Save the patch from the Github patch link (just append ‘.patch’ to the pull request link to get it). This patch will keep the authorship of the commit, so we should use it instead of the diff.
Apply the patch preserving the original author:
git am pull-request-9876.patch
Particularly for new committers, you may find the following ASF information useful: