mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Rework the release checklist for current practice.
In recent releases we've taken to making the actual release build (or rather, candidates for it) ahead of time so that we can do some slightly more thorough last-minute testing of the exact binaries that we're going to release to everyone. It's time I actually wrote that procedure down in the checklist, so that I remember what it is. In particular, we had the idea that we should not properly GPG-sign the release until the last moment, and use the presence of a set of full GPG signatures as a means of distinguishing the real release build from an RC that accidentally got out into the wild somehow. This checklist update formalises that too, and documents the method I used of ensuring the binaries weren't tampered with between RC building and release signing (by making a signature on just the sha512sums). I also include in this commit an extra command-line option to sign.sh to make that preliminary signature step more convenient.
This commit is contained in:
parent
ea0ab1c821
commit
5cac6013b7
104
CHECKLST.txt
104
CHECKLST.txt
@ -24,25 +24,28 @@ pre-releases on the website:
|
||||
add a news announcement in components/news. (Previous naming
|
||||
convention has been to name it in the form 'X.YZ-pre.mi'.)
|
||||
|
||||
Preparing to make a release
|
||||
---------------------------
|
||||
Things to do during the branch-stabilisation period:
|
||||
|
||||
Now that PuTTY is in git, a lot of the release preparation can be done
|
||||
in advance, in local checkouts, and not pushed until the actual
|
||||
process of _releasing_ it.
|
||||
- Go through the source (including the documentation), and the
|
||||
website, and review anything tagged with a comment containing the
|
||||
word XXX-REVIEW-BEFORE-RELEASE. (Any such comments should state
|
||||
clearly what needs to be done.)
|
||||
|
||||
To begin with, before dropping the tag, make sure everything is ready
|
||||
for it:
|
||||
- Do some testing of the Windows version with Minefield (you can
|
||||
build a Minefield version using 'bob . XFLAGS=-DMINEFIELD'), and of
|
||||
the Unix version with valgrind. In particular, any headline
|
||||
features for the release should get a workout with memory checking
|
||||
enabled!
|
||||
|
||||
- First of all, go through the source (including the documentation),
|
||||
and the website, and review anything tagged with a comment
|
||||
containing the word XXX-REVIEW-BEFORE-RELEASE.
|
||||
(Any such comments should state clearly what needs to be done.)
|
||||
Making a release candidate build
|
||||
--------------------------------
|
||||
|
||||
- Also, do some testing of the Windows version with Minefield, and
|
||||
of the Unix version with valgrind or efence or both. In
|
||||
particular, any headline features for the release should get a
|
||||
workout with memory checking enabled!
|
||||
- Make a directory to hold all the release paraphernalia. I usually
|
||||
call it ~/src/putty/X.YZ (where X.YZ will stand throughout for the
|
||||
version number). In that directory, make a git clone of the PuTTY
|
||||
repository, where you can make release-related commits and tags
|
||||
tentatively, and keep them out of the way of any 'git push' you
|
||||
might still be doing in other checkouts.
|
||||
|
||||
- Double-check that we have removed anything tagged with a comment
|
||||
containing the words XXX-REMOVE-BEFORE-RELEASE or
|
||||
@ -50,7 +53,8 @@ for it:
|
||||
hits in this file itself.)
|
||||
|
||||
- Now update the version numbers and the transcripts in the docs, by
|
||||
checking out the release branch and running
|
||||
checking out the release branch in the release-specific checkout
|
||||
and running
|
||||
|
||||
./release.pl --version=X.YZ --setver
|
||||
|
||||
@ -71,6 +75,42 @@ for it:
|
||||
- If the release is on a branch (which I expect it generally will
|
||||
be), merge that branch to master.
|
||||
|
||||
- Make a release-candidate build from the release tag, and put the
|
||||
build.out and build.log dfiles somewhere safe. Normally I store
|
||||
these in an adjacent directory, so I'll run a command like
|
||||
bob -o ../X.YZ/build-X.YZ-rcN.out -l ../X.YZ/build-X.YZ-rcN.log -c X.YZ . RELEASE=X.YZ
|
||||
This should generate a basically valid release directory as
|
||||
`build-X.YZ-rcN.out/putty', and provide link maps and sign.sh
|
||||
alongside that.
|
||||
|
||||
- Double-check in build-X.YZ-rcN.log that the release was built from
|
||||
the right git commit.
|
||||
|
||||
- Make a preliminary gpg signature, but don't run the full release-
|
||||
signing procedure. (We use the presence of a full set of GPG
|
||||
signatures to distinguish _abandoned_ release candidates from the
|
||||
one that ended up being the release.) In the 'build.X.YZ-rcN.out'
|
||||
directory, run
|
||||
sh sign.sh -r -p putty
|
||||
and you should only have to enter the release key passphrase once,
|
||||
which will generate a clearsigned file called
|
||||
sha512sums-preliminary.gpg _outside_ the 'putty' subdirectory.
|
||||
|
||||
- For my own safety, make the release candidate build read-only.
|
||||
chmod -R a-w build-X.YZ-rcN.out build-X.YZ-rcN.log
|
||||
|
||||
- Now do some checking of the release binaries, and pass them to the
|
||||
rest of the team to do some as well. Do at least these things:
|
||||
* make sure they basically work
|
||||
* check they report the right version number
|
||||
* if there's any easily observable behaviour difference between
|
||||
the release branch and master, arrange to observe it
|
||||
* test the Windows installer
|
||||
* test the Unix source tarball.
|
||||
|
||||
Preparing to make the release
|
||||
-----------------------------
|
||||
|
||||
- Write a release announcement (basically a summary of the changes
|
||||
since the last release). Squirrel it away in
|
||||
thyestes:src/putty-local/announce-<ver> in case it's needed again
|
||||
@ -96,31 +136,15 @@ for it:
|
||||
them as fixed in the new release), add appropriate Fixed-in
|
||||
headers for those.
|
||||
|
||||
- Make a release-candidate build from the release tag, and put the
|
||||
build.out and build.log dfiles somewhere safe. Normally I store
|
||||
these in an adjacent directory, so I'll run a command like
|
||||
bob -o ../X.YZ/build-X.YZ-rcN.out -l ../X.YZ/build-X.YZ-rcN.log -c X.YZ . RELEASE=X.YZ
|
||||
This should generate a basically valid release directory as
|
||||
`build-X.YZ-rcN.out/putty', and provide link maps and sign.sh
|
||||
alongside that.
|
||||
|
||||
- Double-check in build-X.YZ-rcN.log that the release was built from
|
||||
the right git commit.
|
||||
|
||||
- Do a bit of checking of the release binaries:
|
||||
* make sure they basically work
|
||||
* check they report the right version number
|
||||
* if there's any easily observable behaviour difference between
|
||||
the release branch and master, arrange to observe it
|
||||
* test the Windows installer
|
||||
* test the Unix source tarball.
|
||||
|
||||
- Sign the release: in the `build-X.YZ-rcN.out' directory, type
|
||||
- Sign the release in full. In the `build-X.YZ-rcN.out' directory,
|
||||
re-verify that the preliminary signed checksums file has a correct
|
||||
signature on it and also matches the files you're about to sign for real:
|
||||
gpg -d sha512sums-preliminary.gpg | (cd putty; sha512sum -c)
|
||||
If the combined output of that pipeline reports both a good
|
||||
signature (from the release key) and a successful verification of
|
||||
all the sha512sums, then all is well, so now run
|
||||
sh sign.sh -r putty
|
||||
and enter the passphrases a lot of times.
|
||||
|
||||
- For my own safety, make the release candidate build read-only.
|
||||
chmod -R a-w build-X.YZ-rcN.out build-X.YZ-rcN.log
|
||||
and enter the release key passphrase a lot of times.
|
||||
|
||||
The actual release procedure
|
||||
----------------------------
|
||||
|
43
sign.sh
43
sign.sh
@ -10,11 +10,27 @@
|
||||
set -e
|
||||
|
||||
keyname=EEF20295D15F7E8A
|
||||
preliminary=false
|
||||
|
||||
if test "x$1" = "x-r"; then
|
||||
shift
|
||||
keyname=9DFE2648B43434E4
|
||||
fi
|
||||
while :; do
|
||||
case "$1" in
|
||||
-r)
|
||||
shift
|
||||
keyname=9DFE2648B43434E4
|
||||
;;
|
||||
-p)
|
||||
shift
|
||||
preliminary=true
|
||||
;;
|
||||
-*)
|
||||
echo "Unknown option '$1'" >&2
|
||||
exit 1
|
||||
;;
|
||||
*)
|
||||
break
|
||||
;;
|
||||
esac
|
||||
done
|
||||
|
||||
sign() {
|
||||
# Check for the prior existence of the signature, so we can
|
||||
@ -27,9 +43,16 @@ sign() {
|
||||
|
||||
cd "$1"
|
||||
echo "===== Signing with key '$keyname'"
|
||||
for i in putty*src.zip putty*.tar.gz w32/*.exe w32/*.zip w32/*.msi w64/*.exe w64/*.zip w64/*.msi w32old/*.exe w32old/*.zip; do
|
||||
sign --detach-sign "$i" "$i.gpg"
|
||||
done
|
||||
for i in md5sums sha1sums sha256sums sha512sums; do
|
||||
sign --clearsign "$i" "$i.gpg"
|
||||
done
|
||||
if $preliminary; then
|
||||
sign --clearsign sha512sums ../sha512sums-preliminary.gpg
|
||||
else
|
||||
for i in putty*src.zip putty*.tar.gz \
|
||||
w32/*.exe w32/*.zip w32/*.msi \
|
||||
w64/*.exe w64/*.zip w64/*.msi \
|
||||
w32old/*.exe w32old/*.zip; do
|
||||
sign --detach-sign "$i" "$i.gpg"
|
||||
done
|
||||
for i in md5sums sha1sums sha256sums sha512sums; do
|
||||
sign --clearsign "$i" "$i.gpg"
|
||||
done
|
||||
fi
|
||||
|
Loading…
Reference in New Issue
Block a user