- 
                Notifications
    You must be signed in to change notification settings 
- Fork 168
Home
        Marco Edward Gorelli edited this page Mar 4, 2025 
        ·
        29 revisions
      
    In order for this process to work, you should clone Narwhals locally using ssh.
Then, run verify that you see the following output if you run git remote get-url upstream:
$ git remote get-url upstream
[email protected]:narwhals-dev/narwhals.gitIf not, then you should first do
git remote add upstream [email protected]:narwhals-dev/narwhals.gitAfter you've merged everything you'd like to include, please make sure you're up-to-date with upstream/main:
git checkout main
git fetch upstream
git reset --hard upstream/main
- Check that the cuDF tests pass. You can do this by running this Kaggle notebook: https://www.kaggle.com/code/marcogorelli/narwhals-pre-release-test-cudf and verifying that the tests are all green. If they are not, please post in Narwhals Discord so they can be fixed up.
- Copy/fixup the release notes: go to https://github.com/narwhals-dev/narwhals/releases, click "edit" on the latest (draft) release notes. If anything needs fixing up (e.g. adding missing labels to closed pull requests), you can do so now. Once you're done, copy all the content, and paste it somewhere. You'll need this later.
- Make sure that bump-versionbranch doesn't appear in https://github.com/narwhals-dev/narwhals/branches - if it does, delete it.
- Make a new bump-versionbranch:git checkout -b bump-version
- Run python utils/bump_version.py patch. Replace'patch'with either'minor'or'major', depending on by how much you want to bump the version. In general:- If you're doing a scheduled Monday release, use 'minor'
- If you're doing an emergency mid-week release to patch a serious issue, use 'patch'
 
- If you're doing a scheduled Monday release, use 
- Open a pull request from bump-versiontomain. To do this, go to https://github.com/narwhals-dev/narwhals/pulls, click "new pull request", and open a pull request frombump-versiontomain. Set the "release" label.
- Wait a few minutes, until a new release appears in https://github.com/narwhals-dev/narwhals/releases with empty release notes.
- Go to the latest release in https://github.com/narwhals-dev/narwhals/releases (the one without any release notes). You should see something like "Narwhals Unreleased" in draft (with full release notes), and something like v3.1.4 as published (without any release notes). Copy the "Narwhals Unreleased" release notes into the v3.1.4 release notes, and amend the title to be of the form "Narhwals v<version goes here>", e.g.Narwhals v3.1.4. Do not click "publish" on the "Narwhals Unreleased" notes.
- After you've published the release notes, merge the PR from bump-versiontomain.
NOTE: if you see a message like bypassed rule violations, don't worry about it - we block people from creating tags (as they
trigger releases) so if you see it, it's because you have permission to bypass that rule 😇