Files
gastown/RELEASING.md
gastown/crew/max 5f8d13203b docs: Add OSS project files (CHANGELOG, linter config, release docs)
- CHANGELOG.md: Initial release notes for v0.1.0
- .golangci.yml: Linter configuration adapted from beads
- RELEASING.md: Release process documentation

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-02 01:33:33 -08:00

239 lines
4.8 KiB
Markdown

# Release Process for Gas Town
This document describes the release process for Gas Town, including GitHub releases and npm packages.
## Table of Contents
- [Overview](#overview)
- [Prerequisites](#prerequisites)
- [Release Checklist](#release-checklist)
- [1. Prepare Release](#1-prepare-release)
- [2. GitHub Release](#2-github-release)
- [3. npm Package Release](#3-npm-package-release)
- [4. Verify Release](#4-verify-release)
- [Hotfix Releases](#hotfix-releases)
## Overview
A Gas Town release involves multiple distribution channels:
1. **GitHub Release** - Binary downloads for all platforms
2. **npm** - Node.js package for cross-platform installation (`@gastown/gt`)
## Prerequisites
### Required Tools
- `git` with push access to steveyegge/gastown
- `goreleaser` for building binaries
- `npm` with authentication (for npm releases)
- `gh` CLI (GitHub CLI, recommended)
### Required Access
- GitHub: Write access to repository and ability to create releases
- npm: Publish access to `@gastown` organization
### Verify Setup
```bash
# Check git
git remote -v # Should show steveyegge/gastown
# Check goreleaser
goreleaser --version
# Check GitHub CLI
gh auth status
# Check npm
npm whoami # Should show your npm username
```
## Release Checklist
Before starting a release:
- [ ] All tests passing (`go test ./...`)
- [ ] npm package tests passing (`cd npm-package && npm test`)
- [ ] CHANGELOG.md updated with release notes
- [ ] No uncommitted changes
- [ ] On `main` branch and up to date with origin
## 1. Prepare Release
### Update CHANGELOG.md
Add release notes to CHANGELOG.md following the Keep a Changelog format:
```markdown
## [0.2.0] - 2026-01-15
### Added
- New feature X
### Changed
- Improved Y
### Fixed
- Bug in Z
```
Commit the CHANGELOG changes:
```bash
git add CHANGELOG.md
git commit -m "docs: Add CHANGELOG entry for v0.2.0"
git push origin main
```
### Update Version
Update version in relevant files:
1. `internal/cmd/version.go` - CLI version constant
2. `npm-package/package.json` - npm package version
```bash
# Update versions
vim internal/cmd/version.go
vim npm-package/package.json
# Commit
git add -A
git commit -m "chore: Bump version to 0.2.0"
git push origin main
```
### Create Release Tag
```bash
git tag -a v0.2.0 -m "Release v0.2.0"
git push origin v0.2.0
```
This triggers GitHub Actions to build release artifacts automatically.
## 2. GitHub Release
### Using GoReleaser (Recommended)
GoReleaser automates binary building and GitHub release creation:
```bash
# Clean any previous builds
rm -rf dist/
# Create release (uses GITHUB_TOKEN from gh CLI)
GITHUB_TOKEN=$(gh auth token) goreleaser release --clean
```
This will:
- Build binaries for all platforms (macOS, Linux, Windows - amd64/arm64)
- Create checksums
- Generate release notes from CHANGELOG.md
- Upload everything to GitHub releases
### Verify GitHub Release
1. Visit https://github.com/steveyegge/gastown/releases
2. Verify the new version is marked as "Latest"
3. Check all platform binaries are present
## 3. npm Package Release
The npm package wraps the native binary for Node.js environments.
### Test Installation Locally
```bash
cd npm-package
# Run tests
npm test
# Pack and test install
npm pack
npm install -g ./gastown-gt-0.2.0.tgz
gt version # Should show 0.2.0
# Cleanup
npm uninstall -g @gastown/gt
rm gastown-gt-0.2.0.tgz
```
### Publish to npm
```bash
# IMPORTANT: Ensure GitHub release with binaries is live first!
cd npm-package
npm publish --access public
```
### Verify npm Release
```bash
npm install -g @gastown/gt
gt version # Should show 0.2.0
```
## 4. Verify Release
After all channels are updated:
### GitHub
```bash
# Download and test binary
curl -LO https://github.com/steveyegge/gastown/releases/download/v0.2.0/gastown_0.2.0_darwin_arm64.tar.gz
tar -xzf gastown_0.2.0_darwin_arm64.tar.gz
./gt version
```
### npm
```bash
npm install -g @gastown/gt
gt version
```
## Hotfix Releases
For urgent bug fixes:
```bash
# Create hotfix branch from tag
git checkout -b hotfix/v0.2.1 v0.2.0
# Make fixes and bump version
# ... edit files ...
# Commit, tag, and release
git add -A
git commit -m "fix: Critical bug fix"
git tag -a v0.2.1 -m "Hotfix release v0.2.1"
git push origin hotfix/v0.2.1
git push origin v0.2.1
# Follow normal release process
GITHUB_TOKEN=$(gh auth token) goreleaser release --clean
# Merge back to main
git checkout main
git merge hotfix/v0.2.1
git push origin main
```
## Version Numbering
Gas Town follows [Semantic Versioning](https://semver.org/):
- **MAJOR** (x.0.0): Breaking changes
- **MINOR** (0.x.0): New features, backwards compatible
- **PATCH** (0.0.x): Bug fixes, backwards compatible
## Questions?
- Open an issue: https://github.com/steveyegge/gastown/issues
- Check existing releases: https://github.com/steveyegge/gastown/releases