mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
Release checklist updates in the wake of 0.80.
'Merge the release branch to main' shouldn't be half way down the procedure of actually _doing_ the release. Sometimes it's not trivial! This time, for example, major changes in windows/console.c had taken place on main (the ConsoleIO abstraction) which conflicted with also- major changes on the release branch (the rework of the weak-crypto warning messages to use SeatDialogText, for the Terrapin warning). Suddenly I realise it makes more sense to prepare the merge in advance, and then if it's difficult you get time to think about that and solve it at leisure. Also, I'm on Mastodon these days, and that seems like an obviously useful place to announce releases. Added a checklist item to draft a release toot, and another one to send it. Lastly, I managed to miss my own suggested template wording for MS Store 'what's new' text, even though it was right there in the checklist! Expanded it out into a display paragraph or two, so that it's more obvious.
This commit is contained in:
parent
968ac6dbf0
commit
f0265167b1
40
CHECKLST.txt
40
CHECKLST.txt
@ -164,13 +164,24 @@ Preparing to make the release
|
|||||||
|
|
||||||
- Prepare some 'what's new in this release' blurb for the Windows
|
- Prepare some 'what's new in this release' blurb for the Windows
|
||||||
Store. This should be very brief - even briefer than the website
|
Store. This should be very brief - even briefer than the website
|
||||||
news item. Keep it to a couple of sentences in a single paragraph,
|
news item.
|
||||||
templated along the lines of 'X.YZ adds support for this, that and
|
* Keep it to a couple of sentences in a single paragraph,
|
||||||
the other, and fixes bugs including this and that', or 'X.YZ is a
|
templated along the lines of
|
||||||
bug-fix release, mostly in the area of Foo, with one important fix
|
X.YZ adds support for this, that and the other, and fixes bugs
|
||||||
to Bar'.
|
including this and that.
|
||||||
|
or
|
||||||
|
X.YZ is a bug-fix release, mostly in the area of Foo, with one
|
||||||
|
important fix to Bar.
|
||||||
* Might as well check this into putty-aux too.
|
* Might as well check this into putty-aux too.
|
||||||
|
|
||||||
|
- Prepare a toot! I'm on Mastodon, so I should announce the release
|
||||||
|
there. This means writing a cut-down 500-char announcement, maybe
|
||||||
|
more like the website news item than like the email.
|
||||||
|
* Include any relevant hashtags. Refer to the software as #PuTTY;
|
||||||
|
if you mention SSH then write it as #SSH; similarly if we're
|
||||||
|
fixing a #vulnerability. That's how people will find the toot.
|
||||||
|
* Again, commit to putty-aux for team review.
|
||||||
|
|
||||||
- Update the wishlist, in a local checkout:
|
- Update the wishlist, in a local checkout:
|
||||||
* If there are any last-minute wishlist entries (e.g. security
|
* If there are any last-minute wishlist entries (e.g. security
|
||||||
vulnerabilities fixed in the new release), write entries for
|
vulnerabilities fixed in the new release), write entries for
|
||||||
@ -196,6 +207,14 @@ Preparing to make the release
|
|||||||
sh sign.sh -r putty # and enter the release key passphrase
|
sh sign.sh -r putty # and enter the release key passphrase
|
||||||
chmod -R a-w putty
|
chmod -R a-w putty
|
||||||
|
|
||||||
|
- If the release is on a branch (which I expect it generally will
|
||||||
|
be), prepare a merge of that branch to main. Even if the branch
|
||||||
|
consists of nothing but cherry-picks _from_ main, this will mean
|
||||||
|
that the 'update version number' change appears on main and the
|
||||||
|
snapshots start announcing themselves as post-X.YZ. But also, if
|
||||||
|
there's anything new on the branch, this is how it gets on to main
|
||||||
|
as well.
|
||||||
|
|
||||||
The actual release procedure
|
The actual release procedure
|
||||||
----------------------------
|
----------------------------
|
||||||
|
|
||||||
@ -219,18 +238,12 @@ locally, this is the procedure for putting it up on the web.
|
|||||||
correctly and work:
|
correctly and work:
|
||||||
../putty/release.pl --version=X.YZ --postcheck
|
../putty/release.pl --version=X.YZ --postcheck
|
||||||
|
|
||||||
- If the release is on a branch (which I expect it generally will
|
|
||||||
be), merge that branch to main, so that the 'update version number'
|
|
||||||
change appears on main and the snapshots start announcing
|
|
||||||
themselves as post-X.YZ.
|
|
||||||
|
|
||||||
- Push all the git repositories:
|
- Push all the git repositories:
|
||||||
* run 'git push' in the website checkout
|
* run 'git push' in the website checkout
|
||||||
* run 'git push' in the wishlist checkout
|
* run 'git push' in the wishlist checkout
|
||||||
* push from the main PuTTY checkout. Typically this one will be
|
* push from the main PuTTY checkout. Typically this one will be
|
||||||
pushing both the release tag and the merge we just made to the
|
pushing both the release tag and the merge to the main branch,
|
||||||
main branch, plus removing the pre-release branch, so you'll
|
plus removing the pre-release branch, so you'll want some
|
||||||
want some
|
|
||||||
commands along these lines:
|
commands along these lines:
|
||||||
git push origin main # update the main branch
|
git push origin main # update the main branch
|
||||||
git push origin --tags # should push the new release tag
|
git push origin --tags # should push the new release tag
|
||||||
@ -276,6 +289,7 @@ locally, this is the procedure for putting it up on the web.
|
|||||||
+ Mail that release announcement to
|
+ Mail that release announcement to
|
||||||
<putty-announce@lists.tartarus.org>.
|
<putty-announce@lists.tartarus.org>.
|
||||||
+ Post it to comp.security.ssh.
|
+ Post it to comp.security.ssh.
|
||||||
|
+ Post the prepared toot to Mastodon.
|
||||||
+ Mention it in <TDHTT> on mono.
|
+ Mention it in <TDHTT> on mono.
|
||||||
|
|
||||||
- Edit the master ~/adm/puttysnap.sh to disable pre-release builds,
|
- Edit the master ~/adm/puttysnap.sh to disable pre-release builds,
|
||||||
|
Loading…
Reference in New Issue
Block a user