release-cherry-pick
$
npx mdskill add NVIDIA/skills/release-cherry-pickCherry-pick merged release PRs into target branches automatically.
- Automates merging labeled PRs into specific release branches.
- Integrates with GitHub API and Git for branch management.
- Filters PRs by merge date and cherry-pick labels.
- Applies cherry-pick-done labels after successful merges.
SKILL.md
.github/skills/release-cherry-pickView on GitHub ↗
--- name: release-cherry-pick description: Cherry-pick merged PRs labeled for a release branch into that branch, then open a PR and apply the cherry-pick-done label. Use when asked to "cherry-pick PRs for release/X.Y.Z", "pick PRs to release branch", or "cherry-pick labeled PRs". --- # Cherry-pick PRs to a Release Branch Cherry-pick all merged `main` PRs labeled `cherry-pick-<version>` (but not `cherry-pick-done`) into the corresponding `release/<version>` branch, one by one in merge order. ## Step 1 — Identify the target version Ask the user for the release version (e.g. `0.44.0`) if not already provided. Set `VERSION=<version>` for use in subsequent steps. ## Step 2 — Fetch pending PRs Use the GitHub search API to list PRs that have the cherry-pick label but not cherry-pick-done, sorted by merge date ascending: ```bash gh api "search/issues?q=repo:NVIDIA/Model-Optimizer+is:pr+is:merged+base:main+label:cherry-pick-<VERSION>+-label:cherry-pick-done&sort=updated&order=asc&per_page=50" \ --jq '.items[] | [.number, .title, .pull_request.merged_at] | @tsv' \ | sort -t$'\t' -k3 ``` Present the list to the user before proceeding. ## Step 3 — Set up the release branch Check out `release/<VERSION>`, creating it from the remote if it doesn't exist locally: ```bash git fetch origin release/<VERSION> git checkout release/<VERSION> ``` ## Step 4 — Get merge commit SHAs All PRs are squash-merged, so each has a single-parent commit. Retrieve the SHA for each PR: ```bash gh pr view <NUM> --repo NVIDIA/Model-Optimizer --json mergeCommit --jq '.mergeCommit.oid' ``` ## Step 5 — Cherry-pick in merge order Cherry-pick each commit with `-s` (DCO sign-off). GPG signing is handled automatically by the repo's git config. ```bash git cherry-pick -s <SHA> ``` **On conflict:** Tell the user which PR caused the conflict and ask them to fix it, then continue: ```bash git cherry-pick --continue ``` ## Step 6 — Create a PR to the release branch Push the cherry-picks to a new branch and open a PR targeting `release/<VERSION>`. The PR title lists every cherry-picked PR number. The body uses `## Cherry-picked PRs` as the only heading with one `- #<NUM>` bullet per PR — no titles, no links, no extra text. ```bash git checkout -B cherry-picks/release-<VERSION> git push -u origin cherry-picks/release-<VERSION> gh pr create \ --title "[Cherry-pick] PRs #<NUM1> #<NUM2> ..." \ --base release/<VERSION> \ --head cherry-picks/release-<VERSION> \ --body "$(cat <<'EOF' ## Cherry-picked PRs - #<NUM1> - #<NUM2> ... EOF )" ``` ## Step 7 — Apply cherry-pick-done label Add the `cherry-pick-done` label to every PR that was successfully cherry-picked: ```bash for pr in <NUM1> <NUM2> ...; do gh pr edit $pr --repo NVIDIA/Model-Optimizer --add-label "cherry-pick-done" done ```
More from NVIDIA/skills
- accessing-mlflowQuery and browse evaluation results stored in MLflow. Use when the user wants to look up runs by invocation ID, compare metrics across models, fetch artifacts (configs, logs, results), or set up the MLflow MCP server. ALWAYS triggers on mentions of MLflow, experiment results, run comparison, invocation IDs in the context of results, or MLflow MCP setup.
- ad-add-fusion-transformation>
- ad-conf-check>
- ad-graph-dump>
- ad-model-onboard>
- ad-pipeline-failure-pr>
- add-benchmark>
- aiq-deploy|
- aiq-research|
- byobCreate custom LLM evaluation benchmarks using the BYOB decorator framework. Use when the user wants to (1) create a new benchmark from a dataset, (2) pick or write a scorer, (3) compile and run a BYOB benchmark, (4) containerize a benchmark, or (5) use LLM-as-Judge evaluation. Triggers on mentions of BYOB, custom benchmark, bring your own benchmark, scorer, or benchmark compilation.