This document outlines logistics around how releases are handled in the nteract project, specifically the applications and npm packages within this repository.
Production releases of nteract's npm packages, desktop app, and Jupyter extension will happen on a monthly cadence. Dev releases of nteract's npm packages will happen on a weekly basis. This segmentation allows users who are eager to grab the latest changes to do so at the existing pace of the weekly release cadence. Users who want more stable and less frequent releases can opt to consume from the production tag.
lerna will be used to publish packages in the dev channel on a weekly cadence. To publish nteract's npm packages to the dev channel, you must complete the following steps.
- Ensure that you are on the master branch with the latest changes synced.
- Create a new branch with the
release/yyyymmdd
naming convention.- Note: Before continuing, you will need to push this branch to
origin
usinggit push origin HEAD
. This is becauselerna
expects the branch to be exist in the remote before it can push tags.
- Note: Before continuing, you will need to push this branch to
- Run
yarn clean && yarn && yarn build:all:ci
and validate that the project builds successfully.- Validate that
yarn start
successfully launches the desktop app.
- Validate that
- Run the
npx lerna publish --dist-tag=prerelease
command in the root of the nteract repo.- Use the
pre
version tags for each release. These are the version tags that end withalpha.x
.
- Use the
- Follow the prompts to increment the versions of each package as appropriate.
- Note that lerna will provide an output that lists the newly published versions of each package. Copy this as it will be relevant in later steps.
- Create a new Markdown file in the
changelogs
directory that captures the changes in this release.- The filename for this Markdown file should follow the
YYYY-MM-DD.md
naming convention. - The contents of the file should be based on the
changelogs/changelog_template.md
template file.
- The filename for this Markdown file should follow the
- Commit the changes with the new markdown file.
- Open a PR against master from your
release/yyyymmdd
branch. In the description of the PR, include the versions of the published npm packages that thelerna publish
command provides. - Merge the PR into master.
The release process for production packages is the same as the release process for dev packages. However, use npx lerna publish
in Step #4 to publish the packages to the release channel.
After the release, you'll need to publish the latest version of the documentation sites. To publish the documentation site for the npm packages you will need to do the following.
- Ensure that you are added to the nteract team on now. You will need permissions in order to deploy the changes.
- Navigate to the root of the nteract repo directory.
- Run the
yarn package:docs:deploy
command. This will deploy a new instance of the site. - Run the
yarn package:docs:promote
command. This will map thepackages.nteract.io
domain tothe newly deployed instance.
To publish the documentation site for the components, you will need to do the same steps as above. However, use the yarn docs:deploy
and yarn docs:promote
command respectively.
You'll also need to publish the monorepo documentation. To do this, you'll need to have the appropriate mkdocs dependencies.
- Ensure that
mkdocs
is installed by runningpip install mkdocs
. - Ensure that the mkdocs-monorepo-plugin is installed by running
pip install mkdocs-monorepo-plugin
. - Finally, ensure that you have the
gitbook
theme formkdocs
installed. This is the theme that we use to style mkdocs. You can install it by runningpip install mkdocs-gitbook
. - Run
mkdocs build
to generate the documentation site to a newsite
directory. - Run
now site/ --prod --name docs
to deploy the documentation directory.
Snap for nteract Desktop App is created and published using following steps:
- Install snap
- Install snapcraft by
$ sudo snap install snapcraft
- Login to snapcraft CLI with Snapcraft developer account credentials by running
$ snapcraft login
- Run
$ yarn dist
in the root of the project. it will create a.snap
file at/applications/desktop/dist
. - Run
$ cd ./applications/desktop/dist
in root and then run$ snapcraft push --release=edge nteract_xx.xx.xx-alpha.x_amd64.snap
In step 2, make sure you are publishing to the right
--release
channel. It can bestable
,candidate
,beta
oredge
.
Both, nteract desktop app and snapd automatically update the app when a new version is released. nteract desktop app auto-update when there is a release on the GitHub, while snapd auto-update when there is a release on snap-store.
The conflict is, its really hard to predict the behaviour when a new version is released, as both the desktop app and snapd will try to update the app. Three possible cases are:
Case 1: Snap update first
- Then desktop won't auto-update, as it will already be on the latest release.
Case 2: Desktop update first
- Then Snap will still update.
Case 3: Both trigger the update at the same time
- It's a very rare case so possible outcome is very hard to predict.
The nteract desktop app is shipped on a monthly cadence. You can ship nteract desktop releases from any operating system, with one notable exception. Due to technical limitations, macOS releases can only be shipped on macOS. On the topic of macOS...
In order to build a signed copy with working auto-update, you will need to join the Apple developer program and get a certificate. The Electron docs have a document on submitting your app to the app store, you only have to get through to the certificate step. Note, that the certificate that you will need to download from the Apple Developer Program portal is called the "3rd Party Mac Developer Application" certificate.
To be able to publish a release you'll need to generate a GitHub access token by going to https://github.com/settings/tokens/new. The access token should have the repo
scope/permission. Once you have the token, assign it to an environment variable (on macOS/linux):
export GH_TOKEN="<YOUR_TOKEN_HERE>"
If you are on Windows, you can assign it as an environment using the following command in Command Prompt.
> setx GH_TOKEN "<YOUR_TOKEN_HERE>"
Note that setx
will apply the environment variable in subsequence Command Prompt sessions.
Note: Make sure that your remote origin is set as [email protected]:nteract/nteract.git
.
-
Make sure the release is working by running
yarn dist
and testing the built app inside the./applications/desktop/dist/
folder. You can build for all platforms usingyarn dist:all
. -
Double check that publish will really work by running
yarn verifyBeforePublish
first -
Run
npx lerna publish
to publish everything, which also runs the verification steps. You will have to pick versions for everything. -
Run the following to ship the built desktop app. This will generate the platform-specific assets and create a draft release on GitHub with the assets.
yarn ship:desktop
- From GitHub go to nteract's releases, verify everything works and edit the release notes. The name should follow our naming guidelines, namely that we use the last name of the next scientist in the list with an adjective in front. Example:
Last release: Avowed Avogadro
Next Scientist: Babbage
Next release: Babbling Babbage
You can pick alliterative adjectives by using the local dictionary and our friend grep
:
$ cat /usr/share/dict/words | grep "^babb"
babbitt
babbitter
babblative
babble
babblement
babbler
babblesome
babbling
babblingly
babblish
babblishly
babbly
babby
- Once you're ready click "Publish release". On macOS and Windows, the update will be automatically downloaded and installed on user's machines.
To release the nteract Jupyter Extension, you will need to complete the following steps.
- Navigate to the
applications/jupyter-extension
directory within the nteract repo. - Ensure that you are signed into PyPi on your machine and have permissions to publish the
nteract_on_jupyter
package. - Run the
yarn build:python
command. - Run the
yarn upload:pypi
command.