summaryrefslogtreecommitdiffstats
path: root/SubmittingPatches-backports.rst
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2024-11-09 17:08:52 +0100
committerDaniel Baumann <daniel@debian.org>2024-11-09 17:08:52 +0100
commit7ae5754b6d5f4f5ce4c4894a9d0f7247731e4d29 (patch)
tree4d551ffc1d3e175c528c69f06e22a9ac2ac41854 /SubmittingPatches-backports.rst
parentInitial commit. (diff)
downloadceph-19-7ae5754b6d5f4f5ce4c4894a9d0f7247731e4d29.tar.xz
ceph-19-7ae5754b6d5f4f5ce4c4894a9d0f7247731e4d29.zip
Adding upstream version 19.2.0.upstream/19.2.0upstream
Signed-off-by: Daniel Baumann <daniel@debian.org>
Diffstat (limited to 'SubmittingPatches-backports.rst')
-rw-r--r--SubmittingPatches-backports.rst415
1 files changed, 415 insertions, 0 deletions
diff --git a/SubmittingPatches-backports.rst b/SubmittingPatches-backports.rst
new file mode 100644
index 000000000..0f96aec65
--- /dev/null
+++ b/SubmittingPatches-backports.rst
@@ -0,0 +1,415 @@
+Submitting Patches to Ceph - Backports
+======================================
+
+Most likely you're reading this because you intend to submit a GitHub pull
+request ("PR") targeting one of the stable branches ("nautilus", etc.) at
+https://github.com/ceph/ceph.
+
+Before you open that PR, please read this entire document or, at the very least,
+the following two sections: `General principles`_ and `Cherry-picking rules`_.
+
+
+.. contents::
+ :depth: 3
+
+
+General principles
+------------------
+
+To help the people who will review your backport, please state either in the
+backport PR, or in the backport tracker issue, or in the ``main`` branch tracker issue:
+
+1. what bug is fixed
+2. why this fix is the minimal way to do it
+3. why does this need to be fixed in <release>
+
+The above should be followed especially in cases when the backport could be seen
+as introducing, into a stable branch, code that is not related to a particular
+bug or issue.
+
+Rationale: every modification of a stable branch carries a certain risk of
+introducing a regression. To minimize this risk, backports should be as
+straightforward and narrowly-targeted as possible. As a stable release series
+ages, the importance of following these general principles rises.
+
+
+Cherry-picking rules
+--------------------
+
+The following rules, which have been codified from "best practices" developed
+over years of backporting, apply to the actual backport implementation:
+
+* all fixes should land in ``main`` first
+* commits to stable branches should be cherry-picked from ``main``
+* before starting to cherry-pick a set of commits from ``main``, grep the ``main`` git history for the SHA1 of each ``main`` commit (using ``git log --grep``) to check for follow-up fixes. Include any follow-up fixes found in the set of commits to be cherry-picked.
+* when backporting a ``main`` PR to a stable branch, double-check that the backport PR contains cherry-picks of all of the ``main`` PR's commits. If any commit needs to be omitted, declare and explain this in the PR.
+* cherry-picks must be done using ``git cherry-pick -x``
+* if a cherry-pick from ``main`` is not feasible and a direct fix is being undertaken, this must be explained
+* the commit message generated by ``git cherry-pick -x`` must not be modified, except to add a "Conflicts" section below the "cherry picked from commit ..." line added by git
+* the "Conflicts" section must mention all files where changes had to be made manually (not just conflicts flagged by git)
+* the "Conflicts" section should also describe the manual changes that were made
+* if a change is to be backported to multiple stable branches, a tracker issue is needed, so the backports can be tracked (if a change is only to be backported to the most recent stable branch, a tracker issue is not strictly required)
+
+For more information on tracker issues, see `Tracker workflow`_.
+
+For more information on conflict resolution and writing the "Conflicts" section,
+see `Conflict resolution`_.
+
+Adhering to these rules will make your backport easier for reviewers to
+understand. Not adhering to these rules creates additional work for reviewers
+and may cause your backport PR to be rejected.
+
+Notes on the cherry-picking rules
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+What does "all fixes should land in ``main`` first" mean? What if I just need to
+fix the issue in <release>?
+
+As the person fixing the issue, you are required to first check whether the
+issue exists in ``main``. If it does, then the proper course of action is to
+create a ``main`` branch tracker (see `Tracker workflow`_) and fix the issue in ``main``,
+first, and only then cherry-pick the fix to the stable branches that have the
+issue.
+
+If the issue exists in the stable branch, but not in ``main``, there are several
+possibilities:
+
+1. it's a regression introduced into the stable branch by a bad backport
+2. the issue was fixed in ``main`` by some massive refactoring that cannot be backported
+3. the issue was already fixed in ``main`` by a cherry-pickable commit
+
+In cases 1 and 2, it's permissible to fix the issue directly in the most recent
+stable branch, subject to the rule "if a commit could not be cherry-picked from
+``main``, the commit message must explain why that was not possible". Once the
+fix has landed in the most recent stable branch, it can be cherry-picked to
+older stable branches from there.
+
+In case 3, the issue should be handled like any other backport - read on.
+
+
+Tracker workflow
+----------------
+
+Any change that is to be backported to multiple stable branches should have
+an associated tracker issue at https://tracker.ceph.com.
+
+For fixes already merged to ``main``, this may have already been done - see the
+``Fixes:`` line in the ``main`` PR. If the ``main`` PR has already been merged and
+there is no associated ``main`` branch tracker issue, you can create a ``main`` branch tracker
+issue and fill in the fields as described below.
+
+This ``main`` branch tracker issue should be in the "Bug" or "Feature"
+trackers of the relevant subproject under the "Ceph" parent project (or
+in the "Ceph" project itself if none of the subprojects are a good fit).
+The stable branches to which the ``main`` changes are to be cherry-picked should
+be listed in the "Backport" field. For example::
+
+ Backport: mimic, nautilus
+
+Once the PR targeting ``main`` is open, add the PR number assigned by GitHub to
+the tracker issue. For example, if the PR number is 99999::
+
+ Pull request ID: 99999
+
+Once the ``main`` PR has been merged, after checking that the change really needs
+to be backported and the Backport field has been populated, change the ``main``
+branch tracker issue's ``Status`` field to "Pending Backport".
+
+ Status: Pending Backport
+
+If you do not have sufficient permissions to modify any field of the tracker
+issue, just add a comment describing what changes you would like to make.
+Someone with permissions will make the necessary modifications on your behalf.
+
+For straightforward backports, that's all that you (as the developer of the fix)
+need to do. Volunteers from the `Stable Releases and Backports team`_ will
+proceed to create Backport issues to track the necessary backports and stage the
+backports by opening GitHub PRs with the cherry-picks. If you don't want to
+wait, and provided you have sufficient permissions at https://tracker.ceph.com,
+you can `create Backport tracker issues` and `stage backports`_ yourself. In
+that case, read on.
+
+
+.. _`create backport tracker issues`:
+.. _`backport tracker issue`:
+
+Creating Backport tracker issues
+--------------------------------
+
+To track backporting efforts, "backport tracker issues" can be created from
+a parent "``main`` branch tracker issue". The ``main`` branch tracker issue is described in the
+previous section, `Tracker workflow`_. This section focuses the backport tracker
+issue.
+
+Once the entire `Tracker workflow`_ has been completed for the ``main`` branch tracker issue,
+issues can be created in the backport tracker issue for tracking the backporting work.
+
+Under ordinary circumstances, the developer who merges the ``main`` PR will flag
+the ``main`` branch tracker issue for backport by changing the Status to "Pending
+Backport", and volunteers from the `Stable Releases and Backports team`_
+periodically create backport tracker issues by running the
+``backport-create-issue`` script. They also do the actual backporting. But that
+does take time and you may not want to wait.
+
+You might be tempted to forge ahead and create the backport issues yourself.
+Please don't do that - it is difficult (bordering on impossible) to get all the
+fields correct when creating backport issues manually, and why even try when
+there is a script that gets it right every time? Setting up the script requires
+a small up-front time investment. Once that is done, creating backport issues
+becomes trivial.
+
+The backport-create-issue script
+^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+The script used to create backport issues is located at
+``src/script/backport-create-issue`` in the ``main`` branch. Though there might be
+an older version of this script in a stable branch, do not use it. Only use the
+most recent version from ``main``.
+
+Once you have the script somewhere in your PATH, you can proceed to install the
+dependencies.
+
+The dependencies are:
+
+* python3
+* python-redmine
+
+Python 3 should already be present on any recent Linux installation. The second
+dependency, `python-redmine`_, can be obtained from PyPi::
+
+ pip3 install --user python-redmine
+
+
+.. _`python-redmine`: https://pypi.org/project/python-redmine/
+
+Then, try to run the script::
+
+ backport-create-issue --help
+
+This should produce a usage message.
+
+Finally, run the script to actually create the Backport issues.
+For example, if the tracker issue number is 55555::
+
+ backport-create-issue --user <tracker_username> --password <tracker_password> 55555
+
+The script needs to know your https://tracker.ceph.com credentials in order to
+authenticate to Redmine. In lieu of providing your literal username and password
+on the command line, you could also obtain a REST API key ("My account" -> "API
+access key"), put it in ``~/.redmine_key`` and run the script like so::
+
+ backport-create-issue 55555
+
+
+.. _`stage backports`:
+.. _`stage the backport`:
+.. _`staging a backport`:
+
+Opening a backport PR
+---------------------
+
+Once the `Tracker workflow`_ is completed and the `backport tracker issue`_ has
+been created, it's time to open a backport PR. One possibility is to do this
+manually, while taking care to follow the `cherry-picking rules`_. However, this
+can result in a backport that is not properly staged. For example, the PR
+description might not contain a link to the `backport tracker issue`_ (a common
+oversight). You might even forget to update the `backport tracker issue`_.
+
+In the past, much time was lost, and much frustration caused, by the necessity
+of staging backports manually. Now, fortunately, there is a script available
+which automates the process and takes away most of the guesswork.
+
+The ceph-backport.sh script
+^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+Similar to the case of `creating backport tracker issues`_, staging the actual
+backport PR and updating the Backport tracker issue is difficult - if not
+impossible - to get right if you're doing it manually, and quickly becomes
+tedious if you do it more than once in a long while.
+
+The ``ceph-backport.sh`` script automates the entire process of cherry-picking
+the commits from the ``main`` PR, opening the GitHub backport PR, and
+cross-linking the GitHub backport PR with the correct Backport tracker issue.
+The script can also be used to good effect if you have already manually prepared
+the backport branch with the cherry-picks in it.
+
+The script is located at ``src/script/ceph-backport.sh`` in the ``main``
+branch. Though there might be an older version of this script in a stable
+branch, do not use it. Only use the most recent version from the ``main`` branch.
+To do this from anywhere and from any branch use the following
+alias that will use the most recent script in ``upstream/main`` of your
+local ceph clone on every call::
+
+ alias ceph-backport.sh="bash <(git --git-dir=$pathToCephClone/.git --no-pager show upstream/main:src/script/ceph-backport.sh)"
+
+``ceph-backport.sh`` is just a bash script, so the only dependency is ``bash``
+itself, but it does need to be run in the top level of a local clone of
+``ceph/ceph.git``. A small up-front time investment is required to get the
+script working in your environment. This is because the script needs to
+authenticate itself (i.e., as you) in order to use the GitHub and Redmine REST
+API services.
+
+The script is self-documenting. Just run the script and proceed from there.
+
+Once the script has been set up properly, you can validate the setup like so::
+
+ ceph-backport.sh --setup
+
+Once you have this saying "Overall setup is OK", you have two options for
+staging the backport: either leave everything to the script, or prepare the
+backport branch yourself and use the script only for creating the PR and
+updating the Backport tracker issue.
+
+If you prefer to leave everything to the script, just provide the Backport
+tracker issue number to the script::
+
+ ceph-backport.sh 55555
+
+The script will start by creating the backport branch in your local git clone.
+The script always uses the following format for naming the branch::
+
+ wip-<backport_issue_number>-<name_of_stable_branch>
+
+For example, if the Backport tracker issue number is 55555 and it's targeting
+the stable branch "nautilus", the backport branch would be named::
+
+ wip-55555-nautilus
+
+If you prefer to create the backport branch yourself, just do that. Be sure to
+name the backport branch as described above. (It's a good idea to use this
+branch naming convention for all your backporting work.) Then, run the script::
+
+ ceph-backport.sh 55555
+
+The script will see that the backport branch already exists, and use it.
+
+Once the script hits the first cherry-pick conflict, it will no longer provide
+any cherry-picking assistance, so in that case it's up to you to resolve the conflict(s)
+(as described in `Conflict resolution`_) and finish cherry-picking
+all of the remaining commits. Once you are satisfied that the backport is complete in
+your local branch, `ceph-backport.sh` can finish the job of creating the pull request
+and updating the backport tracker issue. To make that happen, just re-run the script
+exactly as you did before::
+
+ ceph-backport.sh $BACKPORT_TRACKER_ID
+
+The script will detect that it is running from a branch with the same name as the one it
+would normally create on the first run and continues after the cherry-picking phase.
+
+For a quick reference on CLI, that contains above information, you can run::
+
+ ceph-backport.sh --usage
+
+Conflict resolution
+^^^^^^^^^^^^^^^^^^^
+
+If git reports conflicts, the script will abort to allow you to resolve the
+conflicts manually.
+
+Once the conflicts are resolved, complete the cherry-pick ::
+
+ git cherry-pick --continue
+
+Git will present a draft commit message with a "Conflicts" section.
+
+Unfortunately, in recent versions of git, the Conflicts section is commented
+out. Since the Conflicts section is mandatory for Ceph backports that do not
+apply cleanly, you will need to uncomment the entire "Conflicts" section
+of the commit message before committing the cherry-pick. You can also
+include commentary on what the conflicts were and how you resolved
+them. For example::
+
+ Conflicts:
+ src/foo/bar.cc
+ - mimic does not have blatz; use batlo instead
+
+When editing the cherry-pick commit message, leave everything before the
+"cherry picked from" line unchanged. Any edits you make should be in the part
+following that line. Here is an example::
+
+ osd: check batlo before setting blatz
+
+ Setting blatz requires special precautions. Check batlo first.
+
+ Fixes: https://tracker.ceph.com/issues/99999
+ Signed-off-by: Random J Developer <random@developer.example.com>
+ (cherry picked from commit 01d73020da12f40ccd95ea1e49cfcf663f1a3a75)
+
+ Conflicts:
+ src/osd/batlo.cc
+ - add_batlo_check has an extra arg in newer code
+
+Naturally, the ``Fixes`` line points to the ``main`` issue. You might be tempted
+to modify it so it points to the backport issue, but - please - don't do that.
+First, the ``main`` issue points to all the backport issues, and second, *any*
+editing of the original commit message calls the entire backport into doubt,
+simply because there is no good reason for such editing.
+
+The part below the ``(cherry picked from commit ...)`` line is fair game for
+editing. If you need to add additional information to the cherry-pick commit
+message, append that information below this line. Once again: do not modify the
+original commit message.
+
+If you use `ceph-backport.sh` for your backport creation (which is recommended),
+read up at the end of `The ceph-backport.sh script`_ on how to continue from here.
+
+Labelling of backport PRs
+-------------------------
+
+Once the backport PR is open, the first order of business is to set the
+Milestone tag to the stable release the backport PR is targeting. For example,
+if the PR is targeting "nautilus", set the Milestone tag to "nautilus".
+
+If you don't have sufficient GitHub permissions to set the Milestone, don't
+worry. Members of the `Stable Releases and Backports team`_ periodically run
+a script (``ceph-backport.sh --milestones``) which scans all PRs targetting stable
+branches and automatically adds the correct Milestone tag if it is missing.
+
+Next, check which component label was applied to the ``main`` PR corresponding to
+this backport, and double-check that that label is applied to the backport PR as
+well. For example, if the ``main`` PR carries the component label "core", the
+backport PR should also get that label.
+
+In general, it is the responsibility of the `Stable Releases and Backports
+team`_ to ensure that backport PRs are properly labelled. If in doubt, just
+leave the labelling to them.
+
+.. _`backport PR reviewing`:
+.. _`backport PR testing`:
+.. _`backport PR merging`:
+
+Reviewing, testing, and merging of backport PRs
+-----------------------------------------------
+
+Once your backport PR is open and the Milestone is set properly, the
+`Stable Releases and Backports team` will take care of getting the PR
+reviewed and tested. Once the PR is reviewed and tested, it will be merged.
+
+If you would like to facilitate this process, you can solicit reviews and run
+integration tests on the PR. In this case, add comments to the PR describing the
+tests you ran and their results.
+
+Once the PR has been reviewed and deemed to have undergone sufficient testing,
+it will be merged. Even if you have sufficient GitHub permissions to merge the
+PR, please do *not* merge it yourself. (Uncontrolled merging to stable branches
+unnecessarily complicates the release preparation process, which is done by
+volunteers.)
+
+
+Stable Releases and Backports team
+----------------------------------
+
+Ceph has a `Stable Releases and Backports`_ team, staffed by volunteers,
+which is charged with maintaining the stable releases and backporting bugfixes
+from the ``main`` branch to them. (That team maintains a wiki, accessible by
+clicking the `Stable Releases and Backports`_ link, which describes various
+workflows in the backporting lifecycle.)
+
+.. _`Stable Releases and Backports`: http://tracker.ceph.com/projects/ceph-releases/wiki
+
+Ordinarily, it is enough to fill out the "Backport" field in the bug (tracker
+issue). The volunteers from the Stable Releases and Backports team will
+backport the fix, run regression tests on it, and include it in one or more
+future point releases.
+
+