diff --git a/docs/maintainer-guide.txt b/docs/maintainer-guide.txt index 4a78a32e32..1aa6da9e03 100644 --- a/docs/maintainer-guide.txt +++ b/docs/maintainer-guide.txt @@ -79,7 +79,12 @@ I insist on the *validation* to enter the trunk, since some changes might have to wait for major releases, to match our current release process. -SANDBOX (to be completed and pushed) +MAINTAINER SANDBOX (to be completed and pushed) + +* be sure to proceed with the below steps on a system provisioned with all + possible build prerequisites for NUT, especially regarding documentation + and nut-website building and checking, and with maintainer GPG keys in + the chain * clean up "in-development" bits from files, e.g.: ** TODO etc. referring planned future in the `NEWS.adoc` and `UPDATING.adoc` @@ -90,24 +95,67 @@ SANDBOX (to be completed and pushed) ** NOTE: The `docs/docinfo.xml.sh` script can help update the list for existing git tags, if some were skipped before. This can be used to cheat a bit about adding the new entry (with a draft tag). -** commit this change (to add a revert-commit after the release tag) +** commit this change (to add a revert-commit after the release tag), e.g.: +---- +:; git commit -sm 'NEWS.adoc, UPGRADING.adoc, docs/docinfo.xml.in: finalize text before NUT v2.8.0 release' +---- + +* revise the contents of `NEWS.adoc` and `UPDATING.adoc` files; verify that + any recent changes to drivers (including `main.c` and other major impact + from common code) and sub-drivers (`*-hid.c` for `usbhid-ups`, `*-mib.c` + for `snmp-ups`, `nutdrv_qx_*` etc.) have been reflected in bumps to their + `DRIVER_VERSION` or equivalen macros +** ideally maintained during development, as features are getting merged for + community testing and future development baseline in the master branch +* NOTE that the `ChangeLog` file is currently not tracked in SCM +* update this document: `docs/maintainer-guide.txt` as it inevitably requires +* commit these finishing touches * bump the release identification: ** add an entry in `docs/docinfo.xml.in` for the actual fixed release version and date -** update version to (ex: 2.7.3) in `configure.ac` -** revise the `NEWS.adoc` and `UPDATING.adoc` files -** generate/revise `Changelog` file if needed - -* create a GPG-signed tag v (ex: v2.7.3) +** revise `appveyor.yml` for branch naming +** revise `scripts/Windows/build-mingw-nut.sh` for fallback value of `VER_OPT` +** update version to (ex: 2.8.0) in `configure.ac` +** commit with a relevant release message, e.g.: +---- +:; git commit -sm 'Update versions for release of NUT v2.8.0' +---- + +* last-minute update against possible master-branch changes (and be sure to + apply the release-version changes described above to your local copy of + the `master` branch, even if originally staged in another): +---- +:; git fetch --all && git rebase upstream/master +---- +* run the last-minute build to be sure the release is sane (no typos in any + recently changed document files, etc.) with `./ci_build.sh` or full ritual: +---- +:; rm -f Makefile configure +:; ./autogen.sh && \ + ./configure --with-all --with-dev --with-doc --enable-spellcheck \ + --enable-warnings --enable-Werror --enable-maintainer-mode && \ + make -j 8 all && \ + make -j 8 spellcheck && \ + make -j 8 distcheck +---- +* create a GPG-signed tag v (ex: v2.8.0): +---- +:; git tag -sm 'Release NUT v2.8.0' +---- ** try to avoid adding signed tags later (ex. v2.8.0-signed) to avoid the mess in GitHub release URLs (or do amend that post-factum), for more details see e.g. https://github.com/networkupstools/nut/issues/1971 +* don't forget to push not only the code, but also the tag: +---- +:; git push upstream && git push --tags upstream +---- -* `make dist` to store the source tarball, checksum and signature iles +* `make dist` (if you did not `make distcheck` above or had some changes since + then) to store the source tarball, checksum and signature files * post-release update of the "in-development" codebase: -** maybe update nut/configure.ac version to .1 (ex: 2.7.3.1) +** maybe update nut/configure.ac version to .1 (ex: 2.8.0.1) ** `git revert` the commit which cleaned up "in-development" bits above ** Possibly resolve relevant merge conflicts for the changed context