tahoe-lafs/docs/release-checklist.rst

219 lines
6.3 KiB
ReStructuredText
Raw Normal View History

2020-10-15 20:56:55 +00:00
=================
Release Checklist
=================
2020-10-30 00:50:22 +00:00
These instructions were produced while making the 1.15.0 release. They
are based on the original instructions (in old revisions in the file
`docs/how_to_make_a_tahoe-lafs_release.org`).
2020-10-15 20:56:55 +00:00
2020-10-30 01:11:34 +00:00
Any contributor can do the first part of the release preparation. Only
certain contributors can perform other parts. These are the two main
2020-10-30 00:50:22 +00:00
sections of this checklist (and could be done by different people).
2020-10-15 20:56:55 +00:00
2020-10-30 01:11:34 +00:00
A final section describes how to announce the release.
2020-10-15 20:57:55 +00:00
2020-10-15 20:56:55 +00:00
Any Contributor
---------------
Anyone who can create normal PRs should be able to complete this
portion of the release process.
Prepare for the Release
```````````````````````
The `master` branch should always be releasable.
It may be worth asking (on IRC or mailing-ist) if anything will be
merged imminently (for example, "I will prepare a release this coming
Tuesday if you want to get anything in").
2020-10-15 20:56:55 +00:00
- Create a ticket for the release in Trac
- Ticket number needed in next section
Create Branch and Apply Updates
```````````````````````````````
2020-10-30 01:13:01 +00:00
- Create a branch for release-candidates (e.g. `XXXX.release-1.15.0.rc0`)
2020-10-15 20:56:55 +00:00
- run `tox -e news` to produce a new NEWS.txt file (this does a commit)
- create the news for the release
2020-10-15 20:56:55 +00:00
- newsfragments/<ticket number>.minor
- commit it
2020-10-15 20:56:55 +00:00
- manually fix NEWS.txt
2020-10-30 01:11:34 +00:00
- proper title for latest release ("Release 1.15.0" instead of "Release ...post1432")
2020-10-30 00:58:19 +00:00
- double-check date (maybe release will be in the future)
2020-10-15 20:56:55 +00:00
- spot-check the release notes (these come from the newsfragments
files though so don't do heavy editing)
- commit these changes
2020-10-15 20:56:55 +00:00
- update "relnotes.txt"
2020-10-15 20:56:55 +00:00
- update all mentions of 1.14.0 -> 1.15.0
- update "previous release" statement and date
- summarize major changes
- commit it
2020-10-15 20:56:55 +00:00
- update "CREDITS"
2020-10-30 01:11:34 +00:00
- are there any new contributors in this release?
2020-10-15 20:56:55 +00:00
- one way: git log release-1.14.0.. | grep Author | sort | uniq
- commit it
2020-10-15 20:56:55 +00:00
- update "docs/known_issues.rst" if appropriate
- update "docs/INSTALL.rst" references to the new release
- Push the branch to github
- Create a (draft) PR; this should trigger CI (note that github
doesn't let you create a PR without some changes on the branch so
2020-10-30 01:11:34 +00:00
running + committing the NEWS.txt file achieves that without changing
2020-10-15 20:56:55 +00:00
any code)
- Confirm CI runs successfully on all platforms
Create Release Candidate
````````````````````````
Before "officially" tagging any release, we will make a
release-candidate available. So there will be at least 1.15.0rc0 (for
example). If there are any problems, an rc1 or rc2 etc may also be
released. Anyone can sign these releases (ideally they'd be signed
"officially" as well, but it's better to get them out than to wait for
that).
Typically expert users will be the ones testing release candidates and
2020-10-30 01:11:34 +00:00
they will need to evaluate which contributors' signatures they trust.
2020-10-15 20:56:55 +00:00
- (all steps above are completed)
- sign the release
2020-10-30 00:58:31 +00:00
- git tag -s -u 0xE34E62D06D0E69CFCA4179FFBDE0D31D68666A7A -m "release Tahoe-LAFS-1.15.0rc0" tahoe-lafs-1.15.0rc0
2020-10-15 20:56:55 +00:00
- (replace the key-id above with your own)
2020-10-15 20:56:55 +00:00
- build all code locally
- these should all pass:
2020-10-15 20:56:55 +00:00
- tox -e py27,codechecks,docs,integration
2020-10-15 20:56:55 +00:00
- these can fail (ideally they should not of course):
2020-10-15 20:56:55 +00:00
- tox -e deprecations,upcoming-deprecations
2020-10-15 20:56:55 +00:00
- build tarballs
2020-10-15 20:56:55 +00:00
- tox -e tarballs
- confirm it at least exists:
- ls dist/ | grep 1.15.0rc0
2020-10-15 20:56:55 +00:00
- inspect and test the tarballs
2020-10-15 20:56:55 +00:00
- install each in a fresh virtualenv
2020-10-30 01:01:26 +00:00
- run `tahoe` command
2020-10-15 20:56:55 +00:00
- when satisfied, sign the tarballs:
2020-10-15 20:56:55 +00:00
- gpg --pinentry=loopback --armor --sign dist/tahoe_lafs-1.15.0rc0-py2-none-any.whl
- gpg --pinentry=loopback --armor --sign dist/tahoe_lafs-1.15.0rc0.tar.bz2
- gpg --pinentry=loopback --armor --sign dist/tahoe_lafs-1.15.0rc0.tar.gz
- gpg --pinentry=loopback --armor --sign dist/tahoe_lafs-1.15.0rc0.zip
Privileged Contributor
-----------------------
Steps in this portion require special access to keys or
infrastructure. For example, **access to tahoe-lafs.org** to upload
binaries or edit HTML.
2020-10-15 20:57:55 +00:00
2020-10-15 20:56:55 +00:00
Hack Tahoe-LAFS
```````````````
Did anyone contribute a hack since the last release? If so, then
https://tahoe-lafs.org/hacktahoelafs/ needs to be updated.
Upload Artifacts
````````````````
Any release-candidate or actual release plus signature (.asc file)
2020-10-30 00:50:29 +00:00
need to be uploaded to https://tahoe-lafs.org in `~source/downloads`
2020-10-15 20:56:55 +00:00
2020-10-15 21:02:50 +00:00
- secure-copy all release artifacts to the download area on the
tahoe-lafs.org host machine. `~source/downloads` on there maps to
https://tahoe-lafs.org/downloads/ on the Web.
2020-10-30 00:50:29 +00:00
- scp dist/*1.15.0* username@tahoe-lafs.org:/home/source/downloads
2020-10-15 21:02:50 +00:00
- the following developers have access to do this:
2020-10-15 21:02:50 +00:00
- exarkun
- meejah
- warner
2020-10-15 20:56:55 +00:00
For the actual release, the tarball and signature files need to be
2020-10-15 21:02:50 +00:00
uploaded to PyPI as well.
2020-10-15 20:56:55 +00:00
- how to do this?
- (original guide says only `twine upload dist/*`)
2020-10-15 21:02:50 +00:00
- the following developers have access to do this:
2020-10-15 21:02:50 +00:00
- warner
- exarkun (partial?)
- meejah (partial?)
2020-10-30 01:11:34 +00:00
2020-10-30 01:23:48 +00:00
Announcing the Release Candidate
````````````````````````````````
The release-candidate should be announced by posting to the
mailing-list (tahoe-dev@tahoe-lafs.org). For example:
https://tahoe-lafs.org/pipermail/tahoe-dev/2020-October/009995.html
Is The Release Done Yet?
````````````````````````
If anyone reports a problem with a release-candidate then a new
release-candidate should be made once a fix has been merged to
master. Repeat the above instructions with `rc1` or `rc2` or whatever
is appropriate.
Once a release-candidate has marinated for some time then it can be
made into a the actual release.
XXX Write this section when doing 1.15.0 actual release
(In general, this means dropping the "rcX" part of the release and the
tag, uploading those artifacts, uploading to PyPI, ... )
2020-10-30 01:11:34 +00:00
Announcing the Release
----------------------
mailing-lists
`````````````
A new Tahoe release is traditionally announced on our mailing-list
(tahoe-dev@tahoe-lafs.org). The former version of these instructions
also announced the release on the following other lists:
2020-10-30 01:23:48 +00:00
- tahoe-announce@tahoe-lafs.org
2020-10-30 01:11:34 +00:00
- twisted-python@twistedmatrix.com
- liberationtech@lists.stanford.edu
- lwn@lwn.net
- p2p-hackers@lists.zooko.com
- python-list@python.org
- http://listcultures.org/pipermail/p2presearch_listcultures.org/
- cryptopp-users@googlegroups.com
wiki
````
Edit the "News" section of the front page of https://tahoe-lafs.org
with a link to the mailing-list archive of the announcement message.