wiki:RFC/4_ReleaseProcedure

Version 13 (modified by smitch, 9 years ago) ( diff )

2 small grammar fixes plus remove tbd based on email list traffic

RFC 4: Release Procedure

Author: GRASS GIS PSC

Contact: grass-psc AT lists.osgeo.org

Status: Early draft (11 June 2014)

Summary

In order to render the release process more fluid, to avoid very long RC periods and to lessen the potential for conflict between developers during release preparations, this RFC defines a procedure that should be followed for each release.

General philosophy

  • The release process should be short. I.e. the time between the first RC and the final release should be a matter of weeks not many months.
  • A release period should be a time of concerted action during which all developers give priority to the release in place of other developments.
  • All developers respect a call for commit freeze during a release process.
  • It is sometimes better to ship a release with a known bug than with unknown consequences of an untested bug fix.

General Procedure

Step 1 - Proposal of release:

When a developer feels that it is time for a new release, she or he should propose the launch of a new release process on the developers mailing list (grass-dev AT lists.osgeo.org). The Project manager (or if exists the Release manager) then collects reactions to decide whether there is sufficient support for this proposal.

Step 2 (day X) - Soft freeze:

  • If support is lacking, a list of outstanding issues (managed via http://trac.osgeo.org/grass/) that need to be solved before a soft freeze should be sent to the developers mailing list.
  • If sufficient support is present, a first announcement is sent to the developers mailing list about the upcoming release. This announcement has as immediate effect a soft freeze meaning that commits should be limited to non-invasive backports from the development branch/trunk. The announcement mail also contains an approximate time table for the release, including begin of hard freeze, RC1, RC2, final release. Sufficient time should be left between the soft freeze and the hard freeze. Any backports during the soft freeze should be announced on the developers mailing list with 24 hours advance to allow possible discussion.

Step 3 (X+30 days) - Hard freeze & RC1:

Once any necessary backports are done, a hard freeze is announced and RC1 is released based on the frozen code.

Step 4 - Bug squashing:

All developers concentrate on fixing the remaining bugs during a defined period of no more than 2 weeks. Any commits from that point on can only be well-tested, non-invasive bug fixes.

Step 5 (X+44 days) - RC2:

RC2 is released as almost final.

Step 6 - Bug squashing: & Release preparation:

A final, concerted bug squashing effort by all developers of no more than one week. During that same time the release announcement is drafted.

Step 7 (X+50 days) - Final release published.

Note: See TracWiki for help on using the wiki.