Version 29 (modified by 14 years ago) ( diff ) | ,
---|
Release Manager's Checklist
This page is gradually being rewritten to reflect the current Boost release process. Until the rewrite is complete, some sections are out-of-date
Introduction
Release cycle initialization
- Update Trac milestones: https://svn.boost.org/trac/boost/admin/ticket/milestones
- In trunk, change version number in:
- trunk/index.html (2 places; H1 and Release History link)
- trunk/Jamroot (1 place)
- trunk/boost/version.hpp (2 places)
- trunk/more/getting_started/detail/release-variables.rst (3 places)
- In trunk,
- In more/getting_started, run bjam.
- Inspect results.
- Commit version number and Getting Started doc changes:
- To trunk.
- Merge and commit to branches/release.
- Update ReleaseSchedule
- Post the "Open for merges" heads up message. See Heads up messages to notify developers as deadlines loom
- Verify the root/index.htm, root/boost/version.hpp, root/Jamfile.v2 and root/Jamrules release numbers are correct and agree.
- Verify via jamboost@… that bjam pre-built executables up-to-date.
- Create a placeholder for release information at: website/public_html/beta/feed/history/, for example for boost 1.39.0:
svn co https://svn.boost.org/svn/boost/website/public_html/beta beta-website svn cp beta-website/feed/templates/boost_x_xx_x.qbk beta-website/feed/history/boost_1_39_0.qbk
Then edit the new entry and commit.
- For each new library added this release:
- Verify root/index.html includes the library in it's new library list.
- Verify root/libs/libraries.htm entry has been made, both in the alphabetic list and in the category lists.
- Verify root/libs/maintainers.txt entry has been made.
- Verify website/public_html/beta/feed/history/ entry has been made and reads well.
- Verify library has been added to the website documentation list
- Verify the root/libs/xxx directory contains an index.htm or index.html file; either the main docs or a redirection to the main docs. To do: automate this.
- Skim read the primary docs pages to make sure they meet Boost requirements and guidelines. Don't leave this until too late; it has turned up lots of issues in the past.
- Generate the header dependency table and update the CVS. To do: coordinate with John Maddock's new dependency tools.
- Add to component list on Trac (this could possibly be done when the library is accepted, or even added to the review queue).
- Monitor http://boost.sourceforge.net/regression-logs/inspection_report.html to verify problems are actively being reduced. Make sure none of the problems are in files the release manager is responsible for.
- Monitor regression tests (http://boost.sourceforge.net/regression-logs) to verify that errors are actively being reduced or accounted for on key platforms and compilers.
- Boost errors are being actively worked on by library maintainers.
- Compiler or standard library errors are at least identified, and preferably reported to the supplier.
- No errors remain uninvestigated or unclassified.
- Monitor the developer and user mailing lists to verify that all posted patches are being applied, rejected, or otherwise dealt with.
- Monitor the developer and user mailing lists, and outstanding tickets, to verify that all posted bug reports are being investigated, fixed, rejected, or otherwise dealt with.
- Monitor SVN commits to verify that all the expected and/or promised content actually gets committed. Try to get developers to avoid last minute commits of major changes.
Beta Release
Follow the tagging and release procedures below as for regular releases.
Between Beta and Release
See ReleasePractices/PostBetaMerges
Build Distribution packages
- If it hasn't already been done, run a snapshot using tools/release/snapshot.bat.
- Build the distribution packages using tools/release/build_release_packages.bat.
- Upload distribution packages to snapshot ftp site.
- Important: Request final review from release team, developers list.
Releases
- Important: Release team must have signed off on packages. Ignoring this in the past has led to mistakes!
- See http://alexandria.wiki.sourceforge.net/File+Release+System+-+Offering+Files+for+Download for SourceForge File Release System documentation.
- Upload release packages.
cd <snapshot-directory> dir boost_* // verify this gets only the desired files rsync -avP -e ssh boost_* beman_dawes@frs.sourceforge.net:uploads/
- Create or edit a release. Admin | File Releases: Click "Add Release" for Package Name "boost".
- Step 1: New release name: 1.37.2 [beta] | create this release
- Step 2: paste in release notes (in HTML). Submit/Refresh
Boost source files with types .bz2 and .gz are created with POSIX-style (\n) line endings. Source files with types .7z and .zip are created with Windows-style (\r\n) line endings. The content is otherwise identical.
If you are new to Boost, be sure to read the Getting Started Guide. See www.boost.org
- Step 3: Check appropriate files. Add Files and/or Refresh View
- Step 4: For each file, select Processor "Platform-Independent" and File Type, Update/Refresh
- Step 5: Email Release Notice: Check "I'm sure", click "Send Notice"
- Wait a bit. The docs say 30 minutes, but that seems to have been reduced to less than 5 minutes.
- Apply Subversion release tag. (See Subversion Release Tag)
- Check SourceForge release page and release notes with web browser.
- Update the web site:
- Upload boost_n_n_n.zip to the web server, using scp, to "/u/grafik/www.boost.org/archives/live". (Requires server keys/access; currently only Rene and Beman.)
- Merge the website/beta to website/live. (Anyone with website svn write permission.)
- Check actual www.boost.org site with browser. Look at a bunch of files that should have been updated to make sure the updates actually "took".
- Post a message announcing the release and recapping "Latest News". Post as separate messages to: boost, boost-announce, boost-users, comp.lang.c++.moderated, c++std-news
Subversion Release Tag
With TortoiseSVN:
- Do a log on an updated local working copy of branches/release.
- Select the revision number for the release; right-click and select "Create branch/tag from revision".
- To URL: https://svn.boost.org/svn/boost/tags/release/Boost_n_nn_n
- Specific revision in repository: should already be set to correct revision number.
- Log message: Release 1.37.0
- Click OK
Copyright Beman Dawes 2001, 2008
Distributed under the Boost Software License, Version 1.0. (See http://www.boost.org/LICENSE_1_0.txt)