From 20c5d75a6ce0b2deb729b81803c9c6440cff029c Mon Sep 17 00:00:00 2001 From: Steph Prince <40640337+stephprince@users.noreply.github.com> Date: Wed, 3 Jul 2024 18:34:11 -0700 Subject: [PATCH] update release process documentation (#1928) Co-authored-by: Ryan Ly --- CHANGELOG.md | 6 +++- docs/source/make_a_release.rst | 59 ++++++++++++++++++++++------------ 2 files changed, 44 insertions(+), 21 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index f8750ffcd..c72e78f58 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,10 @@ # PyNWB Changelog +## PyNWB 2.8.2 (Upcoming) + +### Documentation and tutorial enhancements +- Added pre-release pull request instructions to release process documentation @stephprince [#1928](https://github.com/NeurodataWithoutBorders/pynwb/pull/1928) + ## PyNWB 2.8.1 (July 3, 2024) ### Documentation and tutorial enhancements @@ -10,7 +15,6 @@ ### Bug fixes - Fixed use of `channel_conversion` in `TimeSeries` `get_data_in_units`. @rohanshah [1923](https://github.com/NeurodataWithoutBorders/pynwb/pull/1923) - ## PyNWB 2.8.0 (May 28, 2024) ### Enhancements and minor changes diff --git a/docs/source/make_a_release.rst b/docs/source/make_a_release.rst index f88b627ea..ad258db34 100644 --- a/docs/source/make_a_release.rst +++ b/docs/source/make_a_release.rst @@ -20,25 +20,6 @@ Prerequisites * You have a `GPG signing key`_. -* Dependency versions in ``requirements.txt``, ``requirements-dev.txt``, ``requirements-opt.txt``, - ``requirements-doc.txt``, and ``requirements-min.txt`` are up-to-date. - -* Legal information and copyright dates in ``Legal.txt``, ``license.txt``, ``README.rst``, - ``docs/source/conf.py``, and any other files are up-to-date. - -* Package information in ``setup.py`` is up-to-date. - -* ``README.rst`` information is up-to-date. - -* The ``nwb-schema`` submodule is up-to-date. The version number should be checked manually in case syncing the - git submodule does not work as expected. - -* Documentation reflects any new features and changes in PyNWB functionality. - -* Documentation builds locally. - -* Documentation builds on the `ReadTheDocs project`_ on the "dev" build. - * Release notes have been prepared. * An appropriate new version number has been selected. @@ -56,6 +37,44 @@ Commands to evaluate starts with a dollar sign. For example:: means that ``echo "Hello"`` should be copied and evaluated in the terminal. +----------------------------------------------------- +Make pre-release pull request on GitHub: Step-by-step +----------------------------------------------------- + +1. Create a new branch locally or on GitHub. Update the ``CHANGELOG.md`` with the release date. + + .. code:: + + $ git checkout -b release-X.Y.Z + + +2. Create a pull request for the new release branch, then append the URL with: "&template=release.md". +For example, ``https://github.com/NeurodataWithoutBorders/pynwb/compare/dev...release-X.Y.Z?quick_pull=1&template=release.md`` + + +3. Follow the checklist in the template. The checklist covers the following steps in more detail: + + * Make sure all PRs to be included in this release have been merged to ``dev``. + + * Update package versions in ``requirements.txt``, ``requirements-dev.txt``, ``requirements-opt.txt``, + ``requirements-doc.txt``, ``requirements-min.txt``, ``environment-ros3.yml``, and ``pyproject.toml``. + + * Check legal information and copyright dates in ``Legal.txt``, ``license.txt``, ``README.rst``, + ``docs/source/conf.py``. + + * Update ``pyproject.toml`` and ``README.rst`` as needed. + + * Update ``src/pynwb/nwb-schema`` submodule as needed. Check the version number manually to make sure + we are using the latest release. + + * Update documentation to reflect new features and changes in PyNWB functionality. + + * Run tests locally, inspect all warnings and outputs, and try to remove all warnings. + + * Test documentation builds locally and on the `ReadTheDocs project`_ on the "dev" build. + + + ------------------------------------- Publish release on PyPI: Step-by-step @@ -144,7 +163,7 @@ Publish release on PyPI: Step-by-step python -c "import pynwb; print(pynwb.__version__)" -10. Cleanup +12. Cleanup On bash/zsh: