File: release.rst

package info (click to toggle)
python-briefcase 0.3.22-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,300 kB
  • sloc: python: 59,405; makefile: 57
file content (131 lines) | stat: -rw-r--r-- 5,208 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
126
127
128
129
130
131
==============================
How to cut a Briefcase release
==============================

The release infrastructure for Briefcase is semi-automated, using GitHub
Actions to formally publish releases.

This guide assumes that you have an ``upstream`` remote configured on your
local clone of the Briefcase repository, pointing at the official repository.
If all you have is a checkout of a personal fork of the Briefcase repository,
you can configure that checkout by running:

.. code-block:: console

  $ git remote add upstream https://github.com/beeware/briefcase.git

The procedure for cutting a new release is as follows:

#. Check the contents of the upstream repository's main branch:

   .. code-block:: console

     $ git fetch upstream
     $ git checkout --detach upstream/main

   Check that the HEAD of release now matches upstream/main.

#. Ensure that the release notes are up to date. Run:

   .. code-block:: console

     $ tox -e towncrier -- --draft

   to review the release notes that will be included, and then:

   .. code-block:: console

     $ tox -e towncrier

   to generate the updated release notes.

#. Build the documentation to ensure that the new release notes don't include any
   spelling errors or markup problems:

   .. code-block:: console

     $ tox -e docs-lint,docs

#. Ensure that there is a version branch for the new Briefcase version in
   every template that Briefcase will use at runtime:

   * ``briefcase-template``
   * ``briefcase-macOS-app-template``
   * ``briefcase-macOS-Xcode-template``
   * ``briefcase-windows-app-template``
   * ``briefcase-windows-VisualStudio-template``
   * ``briefcase-linux-appimage-template``
   * ``briefcase-linux-flatpak-template``
   * ``briefcase-linux-system-template``
   * ``briefcase-iOS-Xcode-template``
   * ``briefcase-android-gradle-template``
   * ``briefcase-web-static-template``

#. Tag the release, and push the branch and tag upstream:

   .. code-block:: console

     $ git tag v1.2.3
     $ git push upstream HEAD:main
     $ git push upstream v1.2.3

#. Pushing the tag will start a workflow to create a draft release on GitHub.
   You can `follow the progress of the workflow on GitHub
   <https://github.com/beeware/briefcase/actions?query=workflow%3A%22Create+Release%22>`__;
   once the workflow completes, there should be a new `draft release
   <https://github.com/beeware/briefcase/releases>`__, and an entry on the
   `Test PyPI server <https://test.pypi.org/project/briefcase/>`__.

   Confirm that this action successfully completes. If it fails, there's a
   couple of possible causes:

   a. The final upload to Test PyPI failed. Test PyPI is not have the same
      service monitoring as PyPI-proper, so it sometimes has problems. However,
      it's also not critical to the release process; if this step fails, you can
      perform Step 6 by manually downloading the "packages" artifact from the
      GitHub workflow instead.
   b. The test apps fail to build. This is likely because you forgot to branch
      one (or more) of the templates mentioned in Step 3. If this happens, you
      can correct the missing template, and re-run the action through the GitHub
      Actions GUI.
   c. Something else fails in the build process. If the problem can be fixed
      without a code change to the Briefcase repository (e.g., a transient
      problem with build machines not being available), you can re-run the
      action that failed through the GitHub Actions GUI. If the fix requires a
      code change, delete the old tag, make the code change, and re-tag the
      release.

#. Create a clean virtual environment, install the new release from Test PyPI, and
   perform any pre-release testing that may be appropriate:

   .. code-block:: console

     $ python3 -m venv testvenv
     $ . ./testvenv/bin/activate
     (testvenv) $ pip install --extra-index-url https://test.pypi.org/simple/ briefcase==1.2.3
     (testvenv) $ briefcase --version
     briefcase 1.2.3
     (testvenv) $ #... any other manual checks you want to perform ...

#. Log into ReadTheDocs, visit the `Versions tab
   <https://readthedocs.org/projects/briefcase/versions/>`__, and activate the
   new version. Ensure that the build completes; if there's a problem, you
   may need to correct the build configuration, roll back and re-tag the release.

#. Edit the GitHub release to add release notes. You can use the text generated
   by towncrier, but you'll need to update the format to Markdown, rather than
   ReST. If necessary, check the pre-release checkbox.

#. Double check everything, then click Publish. This will trigger a
   `publication workflow on GitHub
   <https://github.com/beeware/briefcase/actions?query=workflow%3A%22Upload+Python+Package%22>`__.

#. Wait for the `package to appear on PyPI
   <https://pypi.org/project/briefcase/>`__.

Congratulations, you've just published a release!

If anything went wrong during steps 4-10, you will need to re-start from step 4
with a new version number. Once the release has successfully appeared on PyPI
(or Test PyPI), it cannot be changed; if you spot a problem in a published
package, you'll need to tag a completely new release.