File: release_process.md

package info (click to toggle)
vtk9 9.5.2%2Bdfsg4-3
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 206,640 kB
  • sloc: cpp: 2,340,827; ansic: 327,116; python: 114,881; yacc: 4,104; java: 3,977; sh: 3,032; xml: 2,771; perl: 2,189; lex: 1,787; javascript: 1,261; makefile: 194; objc: 153; tcl: 59
file content (186 lines) | stat: -rw-r--r-- 7,392 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
# Release Process

This document provides a high-level overview of the VTK release cycle and
associated release process.

## Overview

We aim to release a new version of VTK every six months. However, we recognize
that this schedule is flexible. The project is funded and developed by many
different groups, each of which works towards their own particular sets of
features.

VTK releases are named with a `Major.Minor.Patch` scheme.

VTK releases are handled by the VTK release group, which currently consists of:
 - @vbolea
 - @sankhesh
 - @mwestphal

## Branching Scheme

The overall release history resembles a skinny tree. Development proceeds along
the `master` branch, consisting of topic branches that start from and are merged
into `master`. Every so often, a release is tagged and branched from it.

In general, no work takes place on the `release` branch, but some bug fixes from
master can be backported and will be used for occasional patch releases.

:::{hint}
Steps for contributing changes specific to the `release` branch are documented in
[](git/develop.md#create-a-topic).
:::

On the `master` branch, bug fixes and new features are continuously
developed. At release time, the focus temporarily shifts to producing
a library that is as stable and robust as possible.

## Steps

The process for cutting releases is as follows:

1. Announce upcoming release

   A few weeks before the intended `release` branch, the VTK release group
   announce on [VTK Discourse](https://discourse.vtk.org/) that a new release is coming.
   This alerts developers to avoid making drastic changes that might delay the release
   and gives them a chance to push important and nearly completed features in time for the release.
   For example, see [this post](https://discourse.vtk.org/t/vtk-9-4-0-release/14577).

2. Polish the dashboards and bug tracker by addressing outstanding issue and
   coordinate effort with relevant developers.

   Persistent compilation and regression test problems are fixed. Serious
   outstanding bugs are fixed.

   This is an effort involving the whole community of developers.

3. [Create a new issue](https://gitlab.kitware.com/vtk/vtk/-/issues/new) titled
   `Release X.Y.Z[rcN]` based of the [new-release](https://gitlab.kitware.com/vtk/vtk/-/blob/master/.gitlab/issue_templates/new-release.md?plain=1) template.

   :::{Important}
   Specific steps to create eiter the candidate or the official release are found
   in the newly created issue.
   :::

   This is handled by the VTK release group.

4. Perform the release candidate cycle

    1. Tag the release branch and create and publish release candidate
       artifacts and change summaries.

    2. Announce the release candidate and request feedback from the
       community, especially third-party packagers.

       :::{hint}
       Bug reports should be entered into the bug tracker with the upcoming
       release number as the milestone.
       :::

    3. If the community reports bugs, classify them in the bug tracker and ensure
       they are fixed.

       This is not handled by the VTK release group but by the whole community
       of VTK developers.

       Only serious bugs and regressions need to be fixed before the release.
       Such merge requests must be acknowledged (`+1`) by the VTK release group
       before being merged.
       New features and minor problems should be merged into `master` as usual.

       Patches for the release branch should start from the release branch, be
       submitted through GitLab, and then merged into `master`. Once fully
       tested there, reviewed and acknowloedge by the VTK release group,
       the branch can be merged into the release branch.

       When the selected issues are fixed in the release branch, tag the tip
       of the release branch and release it as the next candidate, then the
       cycle continues.

   4. Distribution specific patches can accumulate over time. Consider reviewing the
      following distribution specific pages to identify potential fixes and improvements
      that could be integrated in VTK itself:

      * Debian:
        - https://tracker.debian.org/pkg/vtk9
        - https://udd.debian.org/patches.cgi?src=vtk9

      * Gentoo:
        - https://packages.gentoo.org/packages/sci-libs/vtk
        - https://gitweb.gentoo.org/repo/gentoo.git/tree/sci-libs/vtk/files

      * openSUSE:
        - https://build.opensuse.org/package/show/openSUSE:Factory/vtk

5. Package the official release

   The official VTK package consists of tar balls and ZIP files of the source,
   Python Wheels, Doxygen documentation, and regression test data, all at the
   tag point.

   Volunteer third-party packagers create binary packages from the official
   release for various platforms, so their input is especially valuable during
   the release cycle.

   The VTK release group also compiles release notes for the official release
   announcement. Release notes are compiled from various [standardized topic documents](https://gitlab.kitware.com/vtk/vtk/-/tree/master/Documentation/release)
   added to the `Documentation/release/dev` folder while features or issues
   are fixed. The aggregation of these topic files is done manually and
   results in the creation of a file named `Documentation/release/X.Y.md` for
   the current release.

## GitLab and Releases

GitLab milestones are used for keeping track of branches for the release. They
allow keeping track of issues and merge requests which should be "done" for
the milestone to be considered complete.

For each release (including release candidates), a milestone is created with a
plausible due date. The milestone page allows for an easy overview of branches
which need wrangling for a release.

### Merge Requests

Merge requests which need to be rebased onto the relevant release branch
should be marked with the `needs-rebase-for-release` tag and commented on how
the branch can be rebased properly:

    This branch is marked for a release, but includes other commits in
    `master`. Please either rebase the branch on top of the release branch and
    remove the `needs-rebase-for-release` tag from the merge request:

    ```sh
    $ git rebase --onto=origin/release origin/master $branch_name
    $ git gitlab-push -f
    ```

    or, if there are conflicts when using a single branch, open a new branch
    and open a merge request against the `release` branch:

    ```sh
    $ git checkout -b ${branch_name}-release $branch_name
    $ git rebase --onto=origin/release origin/master ${branch_name}-release
    $ git gitlab-push
    ```

    Thanks!

### Wrangling Branches

Branches may be wrangled using the filters in the merge request page. Replace
`$release` at the end with the relevant milestone name:

    https://gitlab.kitware.com/vtk/vtk/-/merge_requests?state=all&milestone_title=$release

The following states of a merge request indicate where they are in the flow:

  - open for `master`: get into `master` first
  - open for `release`: ensure it is already in `master`
  - open with `needs-rebase-for-release` tag: wait for contributor to rebase
    properly; ping if necessary
  - `MERGED`: merge into `release`

There is currently no good way of marking a branch that went towards `master`
is also in `release` already since tags cannot be added to closed merge
requests. Suggestions welcome :) .