Cut Release Tag
Bump all version strings, open a release PR, and after merge create annotated semver +
tags on
.
This skill delegates the version-bump work to
(invoked via
). That script updates package.json (root + plugin), blueprint.yaml, installer defaults, docs config, and versioned doc links — then runs the build and tests before opening a PR.
Prerequisites
- You must be in the NemoClaw git repository.
- You must have push access to (NVIDIA/NemoClaw).
- The nightly E2E suite should have passed before tagging. Check with the user if unsure.
Step 1: Determine the Current Version
Fetch all tags and find the latest semver tag:
bash
git fetch origin --tags
git tag --sort=-v:refname | grep -E '^v[0-9]+\.[0-9]+\.[0-9]+$' | head -1
Parse the major, minor, and patch components from this tag.
Step 2: Ask the User Which Bump
Present the options with the patch bump as default:
- Patch (default): — bug fixes, small changes
- Minor: — new features, larger changes
- Major: — breaking changes
Show the concrete version strings. Example prompt:
Which version bump?
- Patch → (default)
- Minor →
- Major →
Wait for the user to confirm before proceeding. If they just say "yes", "go", "do it", or similar, use the patch default.
Step 3: Show What's Being Tagged
Show the user the commit that will be tagged and the changelog since the last tag:
bash
git log --oneline origin/main -1
git log --oneline <previous-tag>..origin/main
Ask for confirmation before proceeding.
Step 4: Run the Version Bump Script
First, preview the plan with
:
bash
npm run bump:version -- <version-without-v-prefix> --dry-run
Show the dry-run output to the user. After confirmation, ask the user which mode they want:
Option A: PR mode (default, recommended)
bash
npm run bump:version -- <version-without-v-prefix>
This will:
- Update all version strings across the repo
- Run the build and tests
- Create a branch and open a release PR against
In PR mode, tagging is deferred — proceed to Step 5 after the PR merges.
Option B: Direct mode (no PR)
bash
npm run bump:version -- <version-without-v-prefix> --no-create-pr --push
This will:
- Update all version strings across the repo
- Run the build and tests
- Commit directly on
- Create annotated and tags
- Push the commit and both tags to origin
In direct mode, tagging and pushing are handled by the script — skip to Step 6.
If the user wants to skip tests (e.g., they already ran them), add
to either mode.
Step 5: Create and Push Tags (PR mode only, after PR merge)
Skip this step if you used direct mode in Step 4 — the script already tagged and pushed.
Once the release PR is merged into
, create the annotated tag, move
, and push:
bash
git fetch origin main --tags
git tag -a <new-version> origin/main -m "<new-version>"
# Move the latest tag (delete old, create new)
git tag -d latest 2>/dev/null || true
git tag -a latest origin/main -m "latest"
# Push both tags (force-push latest since it moves)
git push origin <new-version>
git push origin latest --force
Step 6: Verify
bash
git ls-remote --tags origin | grep -E '(<new-version>|latest)'
Confirm both tags point to the same commit on the remote.
Important Notes
- NEVER tag without explicit user confirmation of the version.
- NEVER tag a branch other than .
- Always use annotated tags (), not lightweight tags.
- The tag is a floating tag that always points to the most recent release — it requires to push.
- The version string passed to should NOT have a prefix (e.g., , not ). The script adds the prefix for tags internally.