name: goa-release description: Release Goa v3, including preflight tests, dependency updates, semver version bumps, release preparation commits, examples/plugins repo checks, and babysitting make release. Use when the user asks to release Goa, prepare a Goa release, bump the Goa version, or run make release.
Goa Release
Use this skill only from the Goa repository. make release pushes branches and tags for Goa,
examples, and plugins, so do not run it unless the user explicitly wants to perform the release.
Release Contract
- Goa major version is always
3. Never incrementMAJOR; if it is not3, stop and ask. - Resolve the target version before making dependency-update commits in any repository. The agent should pick the version from the changes, explain the reasoning, and get confirmation before editing files or running dependency updates.
- Apply semver within v3:
- Patch release: increment
BUILD. - Minor release: increment
MINORand resetBUILD=0.
- Patch release: increment
- The preparation commit message must be exactly
Prepare v3.x.y, wherexisMINORandyisBUILD. - Keep the working trees clean between phases. Never discard local changes unless the user explicitly approves it.
- Do not push preparation commits manually.
make release-goarunsgit pull origin <branch>in examples and plugins; local-ahead preparation commits are fine as long asoriginis not ahead. Later,make release-examplesandmake release-pluginspush those preparation commits together with the release commits and tags.
Version Selection
Determine the target version before changing any repository:
- Read
MAJOR,MINOR, andBUILDfrom the GoaMakefile. - Confirm
MAJOR=3. - Inspect the commits and merged PRs since the previous release tag.
- Pick the semver bump:
- Minor when the release includes a user-visible feature, new DSL/runtime capability, or backward-compatible public API addition.
- Patch when the release only includes fixes, dependency updates, docs, tests, or internal maintenance.
- Tell the user the selected target version and the specific changes that justify it, then ask for confirmation. If the user supplied an explicit version, validate it against the same reasoning and call out any mismatch before continuing.
- Use the exact confirmed target version for every preparation commit, tag check, and release command.
Required Repositories
Before release, verify these repositories exist, are on the expected branches, are clean, and are in sync with their upstreams:
- Goa: current repository, expected branch
v3. - Examples:
$(go env GOPATH)/src/goa.design/examples, expected branchmain. - Plugins:
$(go env GOPATH)/src/goa.design/plugins, expected branchv3.
For each repository:
- Run
git status --porcelainand stop if there are uncommitted changes. - Verify the current branch is the expected branch. If not, ask before switching branches.
- Run
git fetch origin. - Verify
git rev-list --left-right --count @{u}...HEADreports0 0. If behind, rungit pull --ff-only. If ahead or diverged, stop and ask. - Verify the target tag does not already exist locally or on
origin.
Preparation Workflow
In the Goa repository, run
make. Fix failures before continuing.In the Goa repository, run:
go get -u -v ./... go mod tidy (cd jsonrpc/integration_tests && go get -u -v ./... && go mod tidy) makeThe JSON-RPC integration tests are a nested Go module; update and tidy it before rerunning
makesointegration-testdoes not fail on stale module metadata.go getshould only updatego.modandgo.sum. If other files changed in any repository, review why before committing.In the examples repository, run:
go list -m -f '{{if .Main}}{{.Dir}}{{end}}' all | while IFS= read -r mod; do [ -n "$mod" ] && (cd "$mod" && go get -u -v ./... && go mod tidy) done makeThe examples repository has no root
go.mod; each example listed ingo.workowns its own module. Update and tidy every example module before runningmake. If files changed, commit them withPrepare v3.x.y. Do not push;make release-examplespushes the branch.In the plugins repository, run:
go get -u -v ./... go mod tidy makeIf files changed, commit them with
Prepare v3.x.y. Do not push;make release-pluginspushes the branch.In the Goa repository, edit only
MINORandBUILDinMakefilefor the target version. LeaveMAJOR=3.If Goa files changed from dependency updates or the version bump, commit them with
Prepare v3.x.y.Re-check all three repositories are clean. They may be ahead of upstream by their preparation commits; that is expected because
make releasepushes them.
Final Pre-Release Check
make release runs its own clean checks and release preflight, but those checks happen inside a
command that can create commits, tags, and pushes. Before running it:
- In all three repositories, run
git fetch origin. - Verify
git status --porcelainis empty. - Verify upstream is not ahead: the first number from
git rev-list --left-right --count @{u}...HEADmust be0. Local-ahead preparation commits are expected. - Do not push the local-ahead preparation commits.
make releasewill push them together with the release commits. - Reconfirm the target version and that the target tag is absent locally and on
originin all three repositories.
Run And Babysit Release
- From the Goa repository, run
make release. - Watch the command until it exits. Track which phase is running:
release-goa,release-examples, orrelease-plugins. - If it fails, stop and inspect the failing repository before rerunning anything. Do not blindly rerun the whole release after a tag or push may have succeeded.
- Before any rerun, inventory local and remote branches and tags for
v3.x.yin all three repositories. Never recreate an existing tag, delete a public tag, or force-push unless the user explicitly approves the recovery plan. - Fix the root cause, verify the affected repository is in the expected state, then rerun the narrowest safe target or command.
- When release completes, report the released version and the branch/tag pushes that succeeded.
GitHub Release Notes
After make release succeeds, create GitHub release notes for the Goa tag.
- Gather the final commit/PR list from the previous Goa tag to the new tag. Include merged PR numbers, titles, authors, and any notable dependency or downstream examples/plugins release work.
- Identify every human contributor in that range from commit authors and PR authors. Do not miss contributors whose commits were merged by someone else. Exclude bots from the thank-you list unless their work is directly meaningful to users.
- Write notes that are clear and useful to someone who does not know Goa internals:
- Start with a short plain-language summary of why the release matters.
- Use sections only when the amount of change justifies them, such as
Highlights,Fixes,Dependencies,Upgrade Notes, andContributors. - Explain user impact before implementation detail. Avoid raw commit-log dumps.
- Include upgrade notes only for actions users may need to take.
- Thank every contributor by name or handle.
- Create or update the GitHub release for
v3.x.ywith the final notes. Do not mention agent or AI tooling in public release notes.
Announcements
After GitHub release notes are ready, draft announcements for Slack, Bluesky, and Substack. Make them exciting and delightful by showing what the release helps users do, not by adding hype.
Voice rules:
- Lead with the most concrete user payoff.
- Use warm, crisp language with one or two memorable details from the release.
- Avoid empty hype, forced jokes, excessive exclamation marks, launch cliches, and insider-only wording.
- Keep contributor thanks visible and sincere.
Channel guidance:
- Slack: 2-4 short paragraphs or bullets. Sound like a maintainer sharing good news with the community. Lead with the most useful user-facing change, link to the GitHub release, and thank contributors.
- Bluesky: Posts are limited to 300 graphemes. Stay under that limit, include the version, one concrete highlight, and a release link. Make the line feel polished enough to repost.
- Substack: Write a short note for readers who may not know Goa deeply. Use a friendly title, a brief explanation of Goa, a user-centered story for the release highlights, upgrade guidance if any, and contributor thanks. Keep it proportional to the release size.