To release a new version of Spyder you need to follow these steps:
-
Install gettext-helpers from source.
-
Create a new PR to update our
*.pot
and*.po
files by runningspyder-gettext scan spyder
-
Check that no warnings are emitted by that command. If they are, then fix them in the same PR.
-
Merge that PR.
-
Close the current translation PR, i.e. the one with the title
New Crowdin updates
. -
Delete the
translate/<branch-name>
branch associated to that PR. -
Go to the integrations page on Crowdin:
-
Press
Sync now
there to open a new translation PR. -
Send a message to translators on Crowdin to update their translations:
An example of that message can be found in
-
Checkout the translations branch with
git checkout translate/<branch-name>
-
Squash all commits in that branch to leave only one with the command
git rebase --interactive HEAD~N
where N is the number of commits on it.
-
Change the commit message with
git commit --amend
to be
Update and compile translations [ci skip]
-
Generate the
mo
files by runningspyder-gettext compile spyder
-
Remove
mo
files that are still not part of version control. -
Add those files to the previous commit with
git add . git commit --amend --no-edit
-
Push your changes to the translation PR with
git push -f upstream translate/<branch-name>
-
Rename the PR title to be
PR: Update translations from Crowdin
. -
Merge the PR.
-
Don't forget to remove your local checkout of
translate/<branch-name>
because that's going to be outdated for next time. -
Update the
master
branch withgit checkout 5.x git fetch upstream git merge upstream/5.x git checkout master git merge 5.x Merge from 5.x: PR #xxxxx git push upstream master
-
Release a new version of
spyder-kernels
, if required. -
Release a new version of
python-lsp-server
, if required. -
Release a new version of
qtconsole
, if required. -
Merge PRs on Conda-forge that update the
spyder-kernels
,python-lsp-server
andqtconsole
feedstocks (usually an automatic PR will appear that can be either merged as it is or be used as boilerplate):-
spyder-kernels
: https://github.com/conda-forge/spyder-kernels-feedstock -
python-lsp-server
: https://github.com/conda-forge/python-lsp-server-feedstock -
qtconsole
: https://github.com/conda-forge/qtconsole-feedstock
Notes:
- Review carefully the release notes of those packages to see if it's necessary to add new dependencies or update the constraints on the current ones (e.g.
jedi >=0.17.2
).
-
-
Create a new branch in your fork with the name
update-core-deps
-
Update the version of any packages required before the release in the following files:
-
setup.py
(look up for theinstall_requires
variable and also for theLoosen constraints to ensure dev versions still work
patch ) -
spyder/dependencies.py
-
requirements/{main,windows,macos,linux}.yml
-
binder/environment.yml
-
spyder/plugins/ipythonconsole/__init__.py
(look up for the constantsSPYDER_KERNELS_MIN_VERSION
andSPYDER_KERNELS_MAX_VERSION
)Note: Usually, the version of
spyder-kernels
for validation in the IPython Console only needs to be updated for minor or major releases of that package or when doing alphas for Spyder. For bugfix releases the value should remain the same to not hassle users using custom interpreters into updatingspyder-kernels
in their environments. However, this depends on the type of bugs resolved and if it's worthy to reinforce the need of an update even for those versions.
-
-
Commit with
git add . git commit -m "Update core dependencies"
-
Update our subrepos with the following commands, but only if new versions are available!
git subrepo pull external-deps/spyder-kernels git subrepo pull external-deps/python-lsp-server git subrepo pull external-deps/qtconsole
-
Merge this PR following the procedure mentioned on
MAINTENANCE.md
-
Update version in
__init__.py
(set release version, remove '.dev0', add 'rcX'), thengit add . git commit -m "Release X.X.XrcX [ci skip]" git push upstream 5.x
-
Manually activate the following workflows (see Running a workflow):
- Create conda-based installers for Windows, macOS, and Linux
-
Download and test the installation of the resulting artifacts.
-
If one of the previous steps fail, merge a fix PR and start the process again with an incremented 'rcX' commit.
-
Close the current milestone on Github
-
git pull or git fetch/merge
-
Update
changelogs/Spyder-6.md
withloghub spyder-ide/spyder -m vX.X.X
- When releasing the first alpha of a new major version (e.g. Spyder 7), you need to add a new file called
changelogs/Spyder-7.md
to the tree. - After that, add
changelogs/Spyder-7.md
toMANIFEST.in
, removechangelogs/Spyder-6.md
from it and add that path to thecheck-manifest/ignore
section ofsetup.cfg
.
- When releasing the first alpha of a new major version (e.g. Spyder 7), you need to add a new file called
-
Add sections for
New features
,Important fixes
andNew API features
inchangelogs/Spyder-5.md
. For this take a look at closed issues and PRs for the current milestone. -
git add .
andgit commit -m "Update Changelog"
-
Update Announcements.md (this goes to our Google group) removing the outdated announcement of the same kind (major, minor, or beta/release candidate)
-
git add .
andgit commit -m "Update Announcements"
-
git clean -xfdi
and select option1
. -
Update version in
__init__.py
(set release version, remove 'dev0') -
git add .
andgit commit -m "Release X.X.X"
-
python setup.py sdist
Note: This needs to be done on a Linux machine to prevent getting permission errors on executable files (see spyder-ide#21892 and spyder-ide#14494)).
-
Activate environment with pip packages only
-
pip install -U pip setuptools twine wheel
-
python setup.py bdist_wheel
Note: This needs to be done on a Linux machine to prevent getting permission errors in executable files (see spyder-ide#21892 and spyder-ide#14494)).
-
Install generated wheel locally and check for errors
-
twine check dist/*
-
twine upload dist/*
-
Check in PyPI that the new release was published correctly
-
git tag -a vX.X.X -m 'Release X.X.X'
-
Update version in
__init__.py
(add 'dev0' and increment minor) -
git add .
andgit commit -m "Back to work [ci skip]"
-
git checkout master
-
git merge 5.x
-
git commit -m "Release X.X.X [ci skip]"
-
git push upstream master
-
git push upstream 5.x
-
git push upstream --tags
-
Publish release in our Github Releases page:
- Copy the contents of the previous release description (updating the relevant information and links to point to the new Spyder version and changelog entry).
- Edit the previous release description to only have the changelog line.
-
Merge PR on Conda-forge for Spyder. For that you can go to
https://github.com/conda-forge/spyder-feedstock
and merge the corresponding PR for the new release (usually an automatic PR will appear that can be either merged as it is or be use as boilerplate).
Notes:
-
Don't forget to add new dependencies and update constraints on the rest of them. For that, you need to compare line by line the contents of the
recipe/meta.yaml
file in the feedstock with -
After merging, give a ping to
@anaconda-pkg-build
about the new release.
-
-
Update Binder related elements when the new Spyder version is available in Conda-forge:
- Update the Spyder version on the environment file (
binder/environment.yml
) of the (spyder-stable
branch) in thebinder-environments
repo. - Update
environment.yml
files of themaster
and5.x
branches ofbinder-environments
with the contents of thebinder/environment.yml
file present on this repo.
- Update the Spyder version on the environment file (
-
Publish release announcement to our list (following Announcements.md) after the installers have been built.