mit einem Klick
release-this
// Orchestrates the full powerball-harness plugin release with build, validation, version bump, CHANGELOG, tag, and GitHub Release. Use when releasing this plugin.
// Orchestrates the full powerball-harness plugin release with build, validation, version bump, CHANGELOG, tag, and GitHub Release. Use when releasing this plugin.
| name | release-this |
| description | Orchestrates the full powerball-harness plugin release with build, validation, version bump, CHANGELOG, tag, and GitHub Release. Use when releasing this plugin. |
| when_to_use | release this plugin, release harness, cut a release, publish harness, ship harness, release-this |
| allowed-tools | ["Read","Write","Edit","Bash","Agent"] |
| argument-hint | [patch|minor|major|--dry-run|--complete] |
| model | sonnet |
| effort | low |
Project-specific release orchestrator for the claude-code-harness plugin. Runs all plugin-specific checks (build, consistency, validation, Codex templates, version sync), then handles the full release: version bump, CHANGELOG update, commit/tag/push, and GitHub Release creation.
| Argument | Behavior |
|---|---|
patch | Patch version bump (bug fixes, x.y.Z+1) |
minor | Minor version bump (new features, x.Y+1.0) |
major | Major version bump (breaking changes, X+1.0.0) |
--dry-run | Run steps 1–5 only; print what would happen; skip publishing |
--complete | Mark release complete only (step 7 — empty commit + push) |
go/ since the last releaseRun make build-all to compile darwin-arm64, darwin-amd64, and linux-amd64 binaries unless there are no changes in go/ source files since the last release. This ensures that any build issues are caught before proceeding with release validation or publishing steps.
make build-all
Fail immediately if make build-all exits non-zero. Do not proceed to step 2.
Run the 13 plugin-specific consistency checks. These verify symlink integrity, template consistency, version alignment, and structural invariants.
bash "${CLAUDE_SKILL_DIR}/scripts/check-consistency.sh"
bash ./tests/validate-plugin.sh
This runs all CI-gated checks: marketplace.json structure, skill frontmatter, hook schemas, section 9 migration residue scan, and section 10 skill-description audit.
Verify that the Codex CLI configuration templates and the Codex-specific skill bodies are present and readable. Missing files would ship a broken Codex experience to users.
4a. Codex CLI config templates (harness/templates/codex/):
ls -la harness/templates/codex/
Confirm AGENTS.md, README.md, config.toml, .codexignore, and rules/ are all present.
4b. Codex skill bodies (harness/templates/codex-skills/):
ls -la harness/templates/codex-skills/
ls harness/templates/codex-skills/*/SKILL.md
Confirm each subdirectory (breezing, harness-schedule-run, harness-work) contains a SKILL.md. A missing SKILL.md means that Codex-variant skill is broken.
Verify that harness/VERSION and harness/harness.toml agree before proceeding.
HARNESS_RELEASE_EXTRA_VERSION_FILES="harness/harness.toml" bash "${CLAUDE_SKILL_DIR}/scripts/sync-version.sh" check
If there is a mismatch, stop and ask the user to run:
HARNESS_RELEASE_EXTRA_VERSION_FILES="harness/harness.toml" bash "${CLAUDE_SKILL_DIR}/scripts/sync-version.sh" sync
or manually reconcile the files before proceeding.
Dry-run stops here. In --dry-run mode, steps 1–5 run normally but no release is published, no files are written, and no git commits or tags are created. Report what the release would contain and what the new version would be, then exit.
Create the wrapper lock:
mkdir -p .claude/state && touch .claude/state/harness-release-wrapper.lock
Phase 0–2 (preflight + version bump): Delegate to releaser agent via setup invocation:
Agent(
subagent_type: "releaser",
description: "run preflight and bump version",
prompt: "{\"schema_version\":\"releaser-request.v1\",\"invocation\":\"setup\",\"bump_type\":\"<patch|minor|major>\"}"
)
Parse new_version from the releaser-response.v1 response. If status is "error", surface the error field and abort.
Phase 3 (CHANGELOG): Move [Unreleased] content into ## [X.Y.Z] - YYYY-MM-DD. Keep empty ## [Unreleased] above it. Format rules: references/writing-changelog.md.
Phase 3.5 (Validate release notes): Validate CHANGELOG and release notes:
bash "${CLAUDE_SKILL_DIR}/scripts/validate-release-notes.sh"
Phase 4–5 (commit/tag/push): Delegate to releaser agent via finalize invocation:
Agent(
subagent_type: "releaser",
description: "commit, tag, push release v<new_version>",
prompt: "{\"schema_version\":\"releaser-request.v1\",\"invocation\":\"finalize\",\"version\":\"<new_version>\"}"
)
Parse git_hash from the response. If status is "error", surface the error and changes fields.
Phase 6 (GitHub Release): Create the GitHub Release:
gh release create "v${NEW_VERSION}" \
--title "v${NEW_VERSION} - <one-line summary>" \
--notes "$(cat <<'EOF'
## What's Changed
...
EOF
)"
Wait for GitHub Release creation to succeed before proceeding to step 7.
After step 6 finishes, create an empty commit to mark the release as fully complete, then push it. Remove the wrapper lock when done.
NEW_VERSION=$(cat harness/VERSION)
git commit --allow-empty -m "chore: mark v${NEW_VERSION} release complete"
git push origin "$(git rev-parse --abbrev-ref HEAD)"
rm -f .claude/state/harness-release-wrapper.lock
This empty commit is the explicit record that "all release work is done." It is separate from the chore: release vX.Y.Z commit created by the releaser agent.
--complete ModeWhen called with --complete, execute only step 7 (the completion marking commit). Use this if step 6 already finished but the completion commit was not created.
NEW_VERSION=$(cat harness/VERSION)
# Verify a GitHub Release exists for this version before marking complete
gh release view "v${NEW_VERSION}" || { echo "ERROR: GitHub Release v${NEW_VERSION} not found. Create it first."; exit 1; }
git commit --allow-empty -m "chore: mark v${NEW_VERSION} release complete"
git push origin "$(git rev-parse --abbrev-ref HEAD)"
harness-review — Run before release to catch issues earlyharness-plan — Plan the next release tasksharness-work — Work on tasksharness/rules/versioning.md — SemVer classification criteria and batch release policyharness/rules/github-release.md — GitHub Release Notes formatreferences/versioning-rules.md — Detailed versioning rulesreferences/writing-changelog.md — CHANGELOG format guidePlans and tracks tasks in .claude/harness/plans.json. Use when creating plans, adding tasks, updating markers, checking progress, or brainstorming an idea into tasks.
Periodic housekeeping and session lifecycle management. Use when performing cleanup, pruning, or session commands.
Runs iterate-until-pass loops with ralph-worker agents in a worktree. Use when running [ralph]-marked tasks or looping until verify passes.
Initializes and configures Harness in a project — CI, memory, duo workflow, Codex. Use when setting up a new project or adding Harness configuration.
Executes plans.json tasks — solo, parallel, or breezing team mode. Use when implementing tasks or running the work loop.
Manages SSOT memory — decisions.md, patterns.md, and cross-session learnings. Use when recording decisions, searching memory, or promoting learnings.