Skip to content

Release checklist

YoshiRulz edited this page Jan 7, 2025 · 37 revisions

Note that some of these can be done concurrently.

  1. Choose to merge or not merge pending changes
    • Ideally there would be a release candidate and rigorous testing, but there never seems to be enough time...
  2. Test Issues labelled "Patch pending"
  3. Write the changelog
    • You can use git log --pretty='format:[%h %an] %s%n%b%n' 2.x.. (substitute the last release tag for "2.x") as a starting point. TODO write a bespoke tool for editing changelog
    • After parsing through the commits to get a list of user-facing changes (remember only fixes for bugs present in the last release need to be mentioned), group them as in the example below. Use past tense and all lowercase, omitting the period (if you find yourself needing to start a new sentence then you're being too verbose). It really doesn't matter if you use BrE or AmE spellings, just make sure that menu items are as shown in-app, which means AmE because that's the only localisation we provide at the moment. You should include Issue numbers for bugs and feature requests, but only link PRs when no Issue exists (use PR search query is:pr is:closed merged:>YYYY-MM-DD with date of the latest release to quickly see all new PRs).
    • noop
    • It also needs to be prepended to the ReleaseHistory article (TASVideos Wiki markup). Apart from changing markup language, also remember to include download links and the release date (will need to finish this after publishing).
    • There's also the ext. tool changelog. If an ApiHawk change doesn't affect Lua then it might not warrant inclusion on the main changelog, but this one includes even the tiny method signature changes.
  4. Update VersionInfo.MainVersion if it was set for a point release but this will be a minor release
  5. Update the release branch to point to master
    • GitLab CI will build the release branch shortly after pushing it.
  6. Check for AV false positives
    • Separately upload the Windows release archive and EmuHawk.exe alone to VirusTotal. A false positive from the Microsoft engine is the only one that really matters. (And there's no need to check the Linux release since bad AV isn't a concern there.)
    • If it does happen... add a random <EmbeddedResource/> to the assembly or something and try again idk ¯\_(ツ)_/¯
  7. Create a "Release" on GitHub
    • Check the date—if it's April 1st or thereabouts, ABORT MISSION. Seriously, it's just not worth it.
    • Set it to create a new tag.
    • Take the package_release_* artifacts you've already downloaded, replace "VERSIONHERE" in the filenames, recompress the Linux release as .tar.gz, and attach them to the Release.
      • unzip BizHawk-VERSIONHERE-linux-x64.tar.zip; mv BizHawk-linux-x64-*.tar <final filename>; gzip -9 <final filename> (this deletes the .tar when it's done, but unzip didn't delete the .zip)
    • For the description, list any new or graduating cores, and optionally some large improvements.
    • Click "Publish" and pray.
  8. Update Issues, Labels, and Milestone on GitHub
    • (where this release will be 2.x.1)
    • Rename "Fixed/added in 2.x.1 dev" to "Fixed/added in 2.x.1" (i.e. remove "dev"; do not rename "Affects 2.x.1 dev", these should be re-triaged).
    • Add "Affects 2.x.1", "Regression from 2.x.1", "Affects 2.x.2 dev", and "Fixed/added in 2.x.2 dev".
    • Add/update core labels
    • Create a new Milestone "2.x.2" with target date 3 months from this release.
    • Move some or all open Issues to the new Milestone. There's no policy for this as we don't really use it for project management.
    • Close the "2.x.1" Milestone.
    • If any Issue was critical enough to warrant pinning, but was fixed for this release, unpin it.
    • Re-triage Issues which were only reproduced on dev builds ("Repro: Affects 2.x.1 dev"), and Issues which affected cores that were updated in this release.
  9. Update VersionInfo.MainVersion and VersionInfo.ReleaseDate
    • ReleaseDate is overwritten by CI for release builds, but needs to be checked-in. MainVersion should be set to e.g. "2.x.2" after releasing 2.x.1.
    • The value is duplicated in default.nix, in the parameter list at the top.
  10. Update readme and other documentation pages
    • The latest release version isn't explicitly written in any links or text in the readme, but the information itself might become outdated, especially the core list.
    • LuaFunctions on TASVideos Wiki
  11. Update Nix expression
    • Mainly Dist/historical.nix, plus copy Dist/deps.nix into Dist/deps-historical.nix and dedup, and just bump the lists in Dist/nix_expr_check_attrs.sh and Dist/nix_expr_usage_docs.md.
  12. Hype
    • TASVideos news, Discord, etc.

Release candidates

The same steps, but abridged.

  1. Merge PRs
  2. Re-triage Issues
  3. Write changelog
  4. Push release (+ download and repackage builds)
  5. Run VirusTotal
  6. Create Release (+ tag)
  7. That's it. Don't touch VersionInfo.MainVersion. Don't update any docs "for latest release" on the repo or on TASVideos.

Changelog structure

(see "Write the changelog" above)

Treat Libretro as just another core in this context. The cores under "Other cores:" are in alphabetical order, new/graduating aren't. The changes should be sorted with the most important first, but that's kinda subjective so don't try too hard. Obviously, omit empty headings.

- New and graduating cores:
	- new core:
		- change
	- graduating core:
		- change
- Other cores:
	- a core:
		- change
	- another core:
		- change
- Misc. changes to EmuHawk:
	- change
- Linux port:
	- change
- TAStudio:
	- change
- Lua/ApiHawk:
	- change
- DiscoHawk:
	- change