michaelsembwever commented on code in PR #307: URL: https://github.com/apache/cassandra-website/pull/307#discussion_r2630223342
########## site-content/source/modules/ROOT/pages/development/how_to_commit.adoc: ########## @@ -2,147 +2,161 @@ = How-to Commit -If you are a committer, feel free to pick any process that works for you -- so long as you are planning to commit the work yourself. +Commits applicable to multiple versions are atomically pushed forward merges. -== Patch based Contribution +The fix lands on the oldest release branch and is then forward-merges it into each newer branch using an ours merge to record branch lineage and amends that merge commit to include the branch-appropriate patch. -Here is how committing and merging will usually look for merging and -pushing for tickets that follow the convention (if patch-based): - -Hypothetical CASSANDRA-12345 ticket is a cassandra-4.0 based bug fix -that requires different code for cassandra-4.0, cassandra-4.1, and -trunk. Contributor Jackie supplied a patch for the root branch -(12345-4.0.patch), and patches for the remaining branches -(12345-4.1.patch, 12345-5.0.patch, 12345-trunk.patch). - -On cassandra-4.0::: - . `+git am -3 12345-4.0.patch+` (any problem b/c of CHANGES.txt not - merging anymore, fix it in place) - . `+ant realclean && ant jar+` (rebuild to make sure code - compiles) - . `+git commit --amend+` (Notice this will squash the 4.0 applied - patch into the forward merge commit) -On cassandra-4.1::: - . `+git merge cassandra-4.0 -s ours --log+` - . `+git apply -3 12345-4.1.patch+` (any issue with CHANGES.txt : fix - and [.title-ref]#git add CHANGES.txt#) - . `+ant realclean && ant jar+` (rebuild to make sure code - compiles) - . `+git commit --amend+` (Notice this will squash the 4.1 applied - patch into the forward merge commit) -On cassandra-5.0::: -. `+git merge cassandra-4.1 -s ours --log+` -. `+git apply -3 12345-5.0.patch+` (any issue with CHANGES.txt : fix -and [.title-ref]#git add CHANGES.txt#) -. `+ant realclean && ant jar check+` (rebuild to make sure code -compiles) -. `+git commit --amend+` (Notice this will squash the 4.1 applied -patch into the forward merge commit) -On trunk::: - . `+git merge cassandra-5.0 -s ours --log+` - . `+git apply -3 12345-trunk.patch+` (any issue with CHANGES.txt : fix - and [.title-ref]#git add CHANGES.txt#) - . `+ant realclean && ant jar check+` (rebuild to make sure code - compiles) - . `+git commit --amend+` (Notice this will squash the trunk applied - patch into the forward merge commit) -On any branch::: - . `+git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic -n+` - (dryrun check) - . `+git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic+` +This keeps a clean, traceable history and a single logical unit of work per ticket per branch, while preventing unintended diffs from being pulled forward automatically. == Git branch based Contribution -Same scenario, but a branch-based contribution: - -On cassandra-4.0::: - . `+git cherry-pick <sha-of-4.0-commit>+` (any problem b/c of - CHANGES.txt not merging anymore, fix it in place) - . `+ant realclean && ant jar+` (rebuild to make sure code - compiles) -On cassandra-4.1::: - . `+git merge cassandra-4.0 -s ours --log+` - . `+git format-patch -1 <sha-of-4.1-commit>+` (alternative to - format-patch and apply is [.title-ref]#cherry-pick -n#) - . `+git apply -3 <sha-of-4.1-commit>.patch+` (any issue with - CHANGES.txt : fix and [.title-ref]#git add CHANGES.txt#) - . `+ant realclean && ant jar+` (rebuild to make sure code - compiles) - . `+git commit --amend+` (Notice this will squash the 4.1 applied - patch into the forward merge commit) -On cassandra-5.0::: -. `+git merge cassandra-4.1 -s ours --log+` -. `+git format-patch -1 <sha-of-5.0-commit>+` (alternative to -format-patch and apply is [.title-ref]#cherry-pick -n#) -. `+git apply -3 <sha-of-5.0-commit>.patch+` (any issue with -CHANGES.txt : fix and [.title-ref]#git add CHANGES.txt#) -. `+ant realclean && ant jar check+` (rebuild to make sure code -compiles) -. `+git commit --amend+` (Notice this will squash the 5.0 applied -patch into the forward merge commit) -On trunk::: - . `+git merge cassandra-5.0 -s ours --log+` - . `+git format-patch -1 <sha-of-trunk-commit>+` (alternative to - format-patch and apply is [.title-ref]#cherry-pick -n#) - . `+git apply -3 <sha-of-trunk-commit>.patch+` (any issue with - CHANGES.txt : fix and [.title-ref]#git add CHANGES.txt#) - . `+ant realclean && ant jar check+` (rebuild to make sure code - compiles) - . `+git commit --amend+` (Notice this will squash the trunk applied - patch into the forward merge commit) -On any branch::: - . `+git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic -n+` - (dryrun check) - . `+git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic+` +How to commit and merging git-based contributions. + +For example, a hypothetical `+CASSANDRA-12345+` ticket is a bug fix that requires different code for cassandra-4.0, cassandra-4.1, cassandra-5.0 and trunk. The contributor supplied git fork+branches `+12345/4.0+`, `+12345/4.1+`, `+12345/5.0+` and `+12345/trunk+`. + + +*On cassandra-4.0*::: +[source,shell] +---- +git cherry-pick <sha-of-4.0-commit> +ant realclean && ant jar # rebuild to make sure code compiles +---- +*On cassandra-4.1*::: +[source,shell] +---- +git merge cassandra-4.0 -s ours --log +git cherry-pick -n <sha-of-4.1-commit> +ant realclean && ant jar # rebuild to make sure code compiles +git commit --amend # this will squash the 4.1 applied patch into the forward merge commit +---- +*On cassandra-5.0*::: +[source,shell] +---- +git merge cassandra-4.1 -s ours --log +git cherry-pick -n <sha-of-5.0-commit> +ant realclean && ant jar check # rebuild to make sure code compiles +git commit --amend # this will squash the 5.0 applied patch into the forward merge commit +---- +*On trunk*::: +[source,shell] +---- +git merge cassandra-5.0 -s ours --log +git cherry-pick -n <sha-of-trunk-commit> +ant realclean && ant jar check # rebuild to make sure code compiles +git commit --amend # this will squash the trunk applied patch into the forward merge commit +---- +*To Push*::: +[source,shell] +---- +git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic -n # dryrun check +git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic +---- == Contributions only for release branches If the patch is for an older branch, and doesn't impact later branches -(such as trunk), we still need to merge up. - -On cassandra-4.0::: - . `+git cherry-pick <sha-of-4.0-commit>+` (any problem b/c of - CHANGES.txt not merging anymore, fix it in place) - . `+ant realclean && ant jar+` (rebuild to make sure code - compiles) -On cassandra-4.1::: - . `+git merge cassandra-4.0 -s ours --log+` - . `+ant realclean && ant jar+` (rebuild to make sure code - compiles) -On cassandra-5.0::: -. `+git merge cassandra-4.1 -s ours --log+` -. `+ant realclean && ant jar check+` (rebuild to make sure code -compiles) -On trunk::: - . `+git merge cassandra-4.1 -s ours --log+` - . `+ant realclean && ant jar check+` (rebuild to make sure code - compiles) -On any branch::: - . `+git push origin cassandra-4.0 cassandra-4.1 trunk --atomic -n+` - (dryrun check) - . `+git push origin cassandra-4.0 cassandra-4.1 trunk --atomic+` +(such as trunk), we still need to merge up and atomic push. -== Tips +*On cassandra-4.0*::: +[source,shell] +---- +git cherry-pick <sha-of-4.0-commit> +ant realclean && ant jar # rebuild to make sure code compiles +---- +*On cassandra-4.1*::: +[source,shell] +---- +git merge cassandra-4.0 -s ours --log +ant realclean && ant jar # rebuild to make sure code compiles +---- +*On cassandra-5.0*::: +[source,shell] +---- +git merge cassandra-4.1 -s ours --log +ant realclean && ant jar check # rebuild to make sure code compiles +---- +*On trunk*::: +[source,shell] +---- +git merge cassandra-4.1 -s ours --log +ant realclean && ant jar check # rebuild to make sure code compiles +---- +*To Push*::: +[source,shell] +---- +git push origin cassandra-4.0 cassandra-4.1 trunk --atomic -n # dryrun check +git push origin cassandra-4.0 cassandra-4.1 trunk --atomic +---- + +== Patch based Contribution + +How to commit and merging patch-based contributions. + +For example, a hypothetical `+CASSANDRA-12345+` ticket is a bug fix that requires different code for cassandra-4.0, cassandra-4.1, cassandra-5.0 and trunk. The contributor supplied provided the patch for the root branch `+12345-4.0.patch+`, and patches for the remaining branches `+12345-4.1.patch+`, `+12345-5.0.patch+` and `+12345-trunk.patch+`. + +*On cassandra-4.0*::: +[source,shell] +---- +git am -3 12345-4.0.patch +ant realclean && ant jar # rebuild to make sure code compiles +git commit --amend # Notice this will squash the 4.0 applied patch into the forward merge commit +---- +*On cassandra-4.1*::: +[source,shell] +---- +git merge cassandra-4.0 -s ours --log +git apply -3 12345-4.1.patch +ant realclean && ant jar # rebuild to make sure code compiles +git commit --amend # this will squash the 4.1 applied patch into the forward merge commit +---- +*On cassandra-5.0*::: +[source,shell] +---- +git merge cassandra-4.1 -s ours --log +git apply -3 12345-5.0.patch +ant realclean && ant jar check # rebuild to make sure code compiles +git commit --amend # this will squash the 4.1 applied patch into the forward merge commit +---- +*On trunk*::: +[source,shell] +---- +git merge cassandra-5.0 -s ours --log +git apply -3 12345-trunk.patch +ant realclean && ant jar check # rebuild to make sure code compiles +git commit --amend # this will squash the trunk applied patch into the forward merge commit +---- +*To Push*::: +[source,shell] +---- +git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic -n # dryrun check +git push origin cassandra-4.0 cassandra-4.1 cassandra-5.0 trunk --atomic +---- + +== Commit Message [TIP] .Tip ==== -A template for commit messages: +The commit message is to be in the format: [source,none] ---- <One sentence description, usually Jira title or CHANGES.txt summary> + <Optional lengthier description> -patch by <Authors>; reviewed by <Reviewers> for CASSANDRA-##### + patch by <Authors>; reviewed by <Reviewers> for CASSANDRA-##### Review Comment: yes -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: [email protected] For queries about this service, please contact Infrastructure at: [email protected] --------------------------------------------------------------------- To unsubscribe, e-mail: [email protected] For additional commands, e-mail: [email protected]

