File: development_release.rst

package info (click to toggle)
nbconvert 7.17.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,056 kB
  • sloc: python: 8,449; makefile: 199; javascript: 2
file content (125 lines) | stat: -rw-r--r-- 3,911 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
.. _nbconvert_release:

Making an ``nbconvert`` release
===============================

This document guides a contributor through creating a release of ``nbconvert``.


Assign all merged PRs to milestones
-----------------------------------

Go to GitHub and assign all PRs that have been merged to milestones.  This will
be helpful when you update the changelog. If you go to this `GitHub page <Github
no milestones_>`_ you will find all the PRs that currently have no milestones.

.. _GitHub no milestones: https://github.com/jupyter/nbconvert/pulls?utf8=%E2%9C%93&q=is%3Amerged%20is%3Apr%20no%3Amilestone%20

Gather all PRs related to milestone
-----------------------------------

`ghpro <ghpro_>`_ can be used to extract the pull requests by call the following from nbconvert directory (will ask for an API token the first time):

    .. code:: bash

        github-stats --milestone=$VERSION --since-tag $LAST_VERSION --links

.. _ghpro: https://github.com/mpacer/ghpro/tree/alternate_styling

Manually categorize tickets
---------------------------

Group the tickets by these general categories (or others if they are relevant). This usually a manual processes to evaluate the changes in each PR.

#. New Features
#. Deprecations
#. Fixing Problems
#. Testing, Docs, and Builds

Collect major changes
---------------------

From the tickets write up any major features / changes that deserve a paragraph to describe how they work.

Update docs/source/changelog.rst
--------------------------------

Copy these changes with the new version to the top of changelog.rst. Prior release changelogs can be used to pick formatting of the message.

Check installed tools
---------------------

Review ``CONTRIBUTING.md``, particularly the testing and release sections.

Clean the repository
--------------------

You can remove all non-tracked files with:

    .. code:: bash

        git clean -xfdi

This would ask you for confirmation before removing all untracked files.

Make sure the ``dist/`` and ``build/`` folders are clean and avoid stale builds from
previous attempts.

Create the release
------------------

#.  Update the :doc:`changelog <changelog>` to account for all the PRs assigned to this milestone.

#.  Update version number in ``nbconvert/_version.py`` and remove ``.dev`` from dev_info. Note that the version may already be on the dev version of the number you're releasing.

#.  Commit and tag the release with the current version number:

    .. code:: bash

        git commit -am "release $VERSION"
        git tag $VERSION

#.  You are now ready to build the ``sdist`` and ``wheel``:

    .. code:: bash

        pip install build
        python -m build .

#.  You can now test the ``wheel`` and the ``sdist`` locally before uploading
    to PyPI. Make sure to use `twine <https://github.com/pypa/twine>`_ to
    upload the archives over SSL.

    .. code:: bash

        twine upload dist/*

#.  The conda-forge bot will automatically add a PR on your behalf to the `nbconvert-feedstock repo <conda-forge-nbconvert_>`_. You may want to review this PR to ensure conda-forge will be updated cleanly.

.. _conda-forge-nbconvert: https://github.com/conda-forge/nbconvert-feedstock

Release the new version
-----------------------

Push directly on main, including --tags separately

    .. code:: bash

        git push upstream
        git push upstream --tags


Return to development state
---------------------------

If all went well, change the ``nbconvert/_version.py`` back by adding the
    ``.dev`` suffix and moving the version forward to the next patch
    release number.


Email googlegroup with update letter
------------------------------------

Make sure to email jupyter@googlegroups.com with the subject line of
"[ANN] NBConvert $VERSION -- ..." and include at least the significant changes,
contributors, and individual PR notes (if not many significant changes).