Special thanks to Apache Kafka from which most of this documented process was blatantly copied.
Apache Knox follows the Commit-Then-Review policy as defined in: http://www.apache.org/foundation/glossary.html
Commit-Then-Review
(Often abbreviated 'CTR' or 'C-T-R'.) A policy governing code changes which permits developers to make changes at will, with the possibility of being retroactively vetoed. C-T-R is an application of decision making through lazy consensus. The C-T-R model is useful in rapid-prototyping environments, but because of the lack of mandatory review it may permit more bugs through in daily practice than the R-T-C alternative. Compare R-T-C , and see the description of the voting process.
Acknowledging the potential negative aspects of not mandating a review for every commit, we have a short set of guidelines and a notification mechanism for ensuring the rapid development that CTR affords the community while providing communication and attention to review comments which are all important to the Knox community.
The following guidelines are prescribed for committers on the Apache Knox project and should be considered for each change commit:
Guidelines
Notification
In order to draw attention to review topics the use of the [REVIEW] tag in an email subject will be used for:
https://gitbox.apache.org/repos/asf?p=knox.git |
This is the simple workflow and will work well for small features development for people who don't have direct access to check in to the Apache repository. Let's assume you are working on a feature or bug called, KNOX-nnn:
1. Checkout a new repository:
git clone https://gitbox.apache.org/repos/asf/knox.git |
2. Create and checkout a branch to work in:
git checkout -b KNOX-nnn remote/origin/master |
3. Do some work on this branch and periodically checkin locally:
git commit -a |
4. When done (or periodically) rebase your branch to take any changes from trunk:
git pull --rebase origin master |
5. Make a patch containing your work and upload it to JIRA:
git format-patch master --stdout > KNOX-nnn.patch |
6. You may need to iterate/rebase your patch a few times as people comment on the code until a commit checks it in to the main repository.
You will also want to ensure you have your username and email setup correctly so that we correctly record the source of the contribution:
git config --global user.name "Joe Coder" git config --global user.email "jcoder@fake.org" |
This assumes you already have a copy of the repository (https://git-wip-us.apache.org/repos/asf/knox.git).
1. Make sure your code is up-to-date:
git fetch |
2. Checkout the destination branch:
git checkout master |
3. See what the patch will do:
git apply --stat KNOX-nnn.patch |
4. See that the patch will apply cleanly (otherwise prod the contributor to rebase):
git apply --check KNOX-nnn.patch |
6. Apply the patch to trunk
git am --signoff < KNOX-nnn.patch |
If you get an error that says "Patch does not have a valid e-mail address." then the patch might have been created by doing git diff in which case you can apply the patch using.
patch -p1 < KNOX-nnn.patch |
If the am operation failed you will also need to remove the .git/rebase-apply/ that gets created
7. If things go wrong (tests fail, you find some problem, etc), you can back out:
git reset --hard HEAD git clean -f |
8. If after review and running the test you want to push the change into the Apache repo:
git push origin master |
If you have commit access on the Apache repository (https://git-wip-us.apache.org/repos/asf/knox.git) then you will not be applying patches in the manner described in the reviewer workflow.
Instead, once your patch is ready, you will check it in yourself as follows:
1. Create a branch to work on:
git fetch git checkout -b KNOX-nnn remotes/origin/master |
2. Implement the feature. Commit as desired to phase the work.
commit -am "<short message about progress.>" |
3. Rebase as required to track the master branch.
git stash git rebase remotes/origin/master git stash pop |
4. Run the tests. Should always rebase before testing prior to submitting a patch.
ant verify |
5. Create a patch, if desired. Note that commit messages should include the issue identifier and the issue title (e.g., KNOX-{NNNN} - {JIRA TITLE}).
git reset --soft origin/master git commit -am "KNOX-nnn: <short, meaningful message>" git format-patch origin/master --stdout > KNOX-nnn.patch |
6. Post the change patch file to JIRA and optionally get it reviewed.
7. Push the change back to Apache. Pick one of the following:
git push |
If you are working on a sizable set of code, for instance, implementing a significant feature, then it is recommended to use a Git remote branch. This will not only help backup your code but also ensure the master branch is never in an unstable state. Also, using a branch will make for easy code reviews and collaboration.
The workflow for creating a remote branch and using it is the following (presuming that you have done a git clone and are in the master branch) :
git checkout -b KNOX-nnn |
2. Push the local branch remote and setup remote tracking
git push -u origin KNOX-nnn |
3. Implement the feature and commit and push as desired. Note that commit messages should include the issue identifier and the issue title (e.g., KNOX-{NNNN} - {JIRA TITLE}).
git commit -am "<short message about commit>" git push |
4. To update the branch from master at any time
git pull --rebase origin master |
5. To merge the branch back into master, first switch to the master branch and then merge.
git checkout master git merge KNOX-nnn git push |
6. After all code has been merged and the branch is no longer needed, it can be deleted remotely with:
git push origin :KNOX-nnn |
To delete the branch locally
git branch -d KNOX-nnn |
Recently the Knox project converted our repository to Gitbox. This allows us to merge pull requests directly using the Github interface. In this chapter you can read about the recommended Github workflow on how to use this approach as a Knox contributor/committer instead of the old style JIRA patches.
Clone this fork:
# Replace [forked-repository-url] with your git clone url. This sets up the remote alias "origin" automatically which refers back to your forked repo. $ git clone [forked-repository-url] knox |
Set upstream remote:
$ cd knox $ git remote add upstream https://github.com/apache/knox.git |
Make sure that your master branches remote to the newly created upstream. Therefore your local master
branch will be tracking upstream/master
so when you do a git pull
by default it will look at upstream
:
$ git checkout master $ git branch --set-upstream-to upstream/master |
If you are already a Knox contributor and you followed the old contribution flow using JIRA patches you are very likely to have https://github.com/apache/knox checked out locally as follows:
$ cd [your knox project path] $ git checkout master $ git status On branch master Your branch is up to date with 'origin/master'. nothing to commit, working tree clean $ git remote -v origin https://github.com/apache/knox.git (fetch) origin https://github.com/apache/knox.git (push) |
To support consistency with the approach we described above the following changes are recommended in your local repository:
# renaming the existing origin to upstream $ git remote rename origin upstream # adding your forked repository as a new remote with name origin $ git remote add origin [forked-repository-url] $ git remote -v origin [forked-repository-url] (fetch) origin [forked-repository-url] (push) upstream https://github.com/apache/knox.git (fetch) upstream https://github.com/apache/knox.git (push) $ git checkout master $ git branch --set-upstream-to upstream/master |
# Checkout the branch that needs to sync (i.e. master) git checkout master # Pulling latest changes from upstream remote (assuming your branch does not have any local changes so that remote updates can be fast-forwarded) git pull # Optionally, push missing changes to your forked repo git push origin master |
Create a branch named KNOX-#### in your local repository and check it out
# make sure to track local master branch git checkout master # creating and checking out the new branch locally git checkout -b KNOX-#### |
Mark the status of the related JIRA as "In Progress" to let others know that you have started working on the JIRA.
Make changes to the code and commit them to the newly created branch.
git add [your-changes] git commit -m "KNOX-#### - Your meaningful commit message" |
Push your changes. Provide your Github user id and personal access token when asked for user name and password
git push origin KNOX-#### |
A Travis CI job is configured to be triggered every time
The job is configured to perform the following tasks:
It is the responsibility of the contributor of the pull request to make sure that the build passes. Pull requests should not be merged if the TravisCI job fails to validate the merge.
GitHub Actions is also enabled for the project. It is used as an alternative to Travis CI and might become the main CI in the future.
Pros: It is a bit faster than Travis CI
Cons: it doesn't have non-x86_64 nodes for testing on alternative CPU architectures
All committers who are invited for review are required to follow the instructions in this page and link their Github accounts with Gitbox to gain Merge access to apache/knox
in Github.
To try out the changes locally, you can checkout the pull request locally by following the instructions in this guide.
Rules:
git fetch upstream
followed by git rebase upstream/[KNOX-####]
and resolving the conflicts by hand, then pushing the result to your branch.All of the documentation is maintained in a separate SVN repository to facilitate independent updates.
1. Checkout the SVN repository.
svn checkout https://svn.apache.org/repos/asf/knox knox-site cd knox-site |
2. Edit site or documentation files. Note that there are no version branches in the SVN repo. Each version of the guides are maintained in separate directories identified by {version} in the example command blow. In addition, most of the guides are in Markdown format and are broken into multiple sections as indicated by {section}.md in the command below. These fils can be edited with the tool of your choice vi is only used as an example.
vi trunk/books/{version}/{section}.md |
3. Generate the new site and review. The command below should be run from the root of the product. The 'review' target causes the local site to be launched in a browser so that you can review the generation result.
ant generate review |
4. If you're only creating a patch, then remove any changes to the generated site. Those changes will be regenerated by the committer as part of committing the patch. If you don't do this it makes it patch review process very difficult. We recommend naming the patch using the JIRA ID. Upload the patch to the JIRA and request review from a committer.
svn revert --recursive site svn diff > KNOX-nnn.patch |
5. If you're committing changes, then DO NOT revert the generated site content. Commit all the changes.
svn ci <modified_files> -m "Change comment" |