mirror of https://github.com/OISF/suricata
parent
de8bffd244
commit
9fbdfd219c
@ -0,0 +1,128 @@
|
||||
========================
|
||||
Suricata Backports Guide
|
||||
========================
|
||||
|
||||
This document describes the processes used to backport content to current stable
|
||||
Suricata releases. Most often, this means security and/or bug fixes;
|
||||
however, in some cases, features may be backported to previous Suricata releases.
|
||||
|
||||
There are multiple versions of Suricata at any given time:
|
||||
* Master
|
||||
* Major stable release
|
||||
* Old stable release
|
||||
|
||||
For example, at the moment, there are 3 releases based on these Suricata branches:
|
||||
* master: 8.0.0-dev, current development branch
|
||||
* main-7.0.x: major stable release (note we're changing our naming conventions)
|
||||
* master-6.0.x: old stable release
|
||||
|
||||
For Suricata's release cadence and *end of life* policies, please check
|
||||
https://suricata.io/our-story/eol-policy/.
|
||||
|
||||
The next sections discuss when and what to backport, and some guidelines when
|
||||
doing so.
|
||||
|
||||
What should be backported?
|
||||
--------------------------
|
||||
|
||||
Usually, when the team creates a ticket, we'll add the *Needs backport* related
|
||||
labels, so necessary backporting tickets will be automatically created. If you
|
||||
are working on a ticket that doesn't have such labels, nor backporting tasks
|
||||
associated, it probably doesn't need backporting. If you understand that the
|
||||
issue should be backported, please let us know in the ticket or related PR. But
|
||||
sometimes we'll miss those.
|
||||
|
||||
The general principle used to determine what will be backported is:
|
||||
* security fixes (please see our `Security Policy <https://github.com/OISF/suricata/blob/master/SECURITY.md>`_)
|
||||
* bug fixes
|
||||
* in some cases, new features are backported if there are sufficient reasons to
|
||||
backport a new feature.
|
||||
|
||||
.. Note:: Exceptions
|
||||
|
||||
There can be cases where backports may be "missed" -- some issues may not be
|
||||
labeled as needing backports and some PRs may be merged without an issue.
|
||||
|
||||
This guide may be insufficient for some situations. When in doubt, please reach
|
||||
out to the team on the backport ticket or PR.
|
||||
|
||||
Selection overview
|
||||
------------------
|
||||
|
||||
All items considered for backports should be reviewed with the following:
|
||||
* risk estimate: will the change introduce new bugs? Consider the scope and
|
||||
items affected by the change.
|
||||
* behavioral change: how much will the behavior of the system be changed by the
|
||||
backport. For example, a small change to decode additional encapsulation
|
||||
protocols may result in more traffic being presented to Suricata.
|
||||
* default settings: if the issue alters behavior, can it be made optional, and
|
||||
at what cost?
|
||||
|
||||
Creating backport tickets -- new issues
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
Redmine: for security and bug fixes, when creating a new Redmine issue,
|
||||
label the Redmine issue with "Needs backport to x.0", where x.0 is a supported
|
||||
Suricata release, e.g, 7.0.x.
|
||||
|
||||
Creating backports tickets -- existing issues/PRs
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
|
||||
We want to minimize the occurrence of "missed backports" -- that is, work that
|
||||
should be backported but wasn't. Sometimes this happens when there is no Redmine
|
||||
issue, or the Redmine issue wasn't labeled as needing a backport.
|
||||
|
||||
Therefore, we will be periodically reviewing:
|
||||
* Redmine issues without backport labels, including recently closed issues, to
|
||||
see which require backport labels.
|
||||
* PRs without associated Redmine issues. Those requiring backports should be
|
||||
labeled with *needs backport*.
|
||||
|
||||
Then, also periodically, we will create backport issues from those items
|
||||
identified in the previous steps. When doing so, we will evaluate what are the
|
||||
relevant target backport releases. Some issues reported against master or the
|
||||
current Suricata release may not apply to older releases.
|
||||
|
||||
Git Backport Workflow
|
||||
---------------------
|
||||
|
||||
If you are working on a task that needs to be backported, only start the
|
||||
backporting process once the PR for master has been merged. Then:
|
||||
|
||||
* *Identify the commit(s) needed* for the backport. Start with the PR that merged
|
||||
the commits into master and select only the commits from the issue being
|
||||
backported.
|
||||
* *Bring each commit into the new branch,* one at a time -- starting with the
|
||||
oldest commit. Use ``git cherry-pick -x commit-hash``, where ``commit-hash``
|
||||
is the hash to the commit already in master or main-7.0x that is being
|
||||
backported, as it maintains the linkage with said cherry-picked commit.
|
||||
* *Resolve conflicts:* Some of the cherry-picked commits may contain merge
|
||||
conflicts. If the conflicts are small, include the corrections in the
|
||||
cherry-picked commit.
|
||||
* *Add additional commits*, if any are needed (e.g., to adjust cherry-picked code
|
||||
to old behavior).
|
||||
|
||||
.. Note:: Commit hashes
|
||||
|
||||
We have a CI check that ensures the validity of the cherry-pick line.
|
||||
|
||||
.. Note:: Exceptions
|
||||
|
||||
Sometimes, the fix for master will not work for the stable or old releases.
|
||||
In such cases, the backporting process won't be through cherry-picking, but
|
||||
through actually implementing a fix for the specific version.
|
||||
|
||||
Create a PR:
|
||||
~~~~~~~~~~~~
|
||||
|
||||
Please indicate in the title that this is a backport PR, with something like
|
||||
*(7.0.x-backport)*, and add the related milestone label.
|
||||
|
||||
In the PR description, indicate the backport ticket.
|
||||
|
||||
QA
|
||||
--
|
||||
|
||||
Add suricata-verify PRs when needed. Some existing suricata-verify tests may require
|
||||
version specification changes.
|
||||
|
Loading…
Reference in New Issue