Welcome to Squad development. This guide explains how to build, test, and contribute.
- Node.js ≥20.0.0
- npm ≥10.0.0 (for workspace support)
- Git with SSH agent (for package resolution)
- gh CLI (for GitHub integration testing)
Squad is an npm workspace monorepo with two packages:
squad/
├── packages/squad-cli/ # CLI tool (@bradygaster/squad-cli)
├── packages/squad-sdk/ # Runtime SDK (@bradygaster/squad-sdk)
├── src/ # Legacy CLI code (migrating to packages/)
├── dist/ # Compiled output
├── .squad/ # Team state and agent history
├── docs/ # Documentation and proposals
└── test-fixtures/ # Test data
- squad-sdk: Core runtime, agent orchestration, tool registry. No CLI dependencies.
- squad-cli: Command-line interface. Depends on squad-sdk.
Each package has independent versioning via changesets. A change to squad-sdk may bump only squad-sdk; a change to CLI bumps only squad-cli.
Step 1: Fork the repo on GitHub
Go to https://github.com/bradygaster/squad and click "Fork" to create your own copy.
Step 2: Clone your fork
git clone git@github.com:{yourusername}/squad.git
cd squadStep 3: Add upstream remote
git remote add upstream git@github.com:bradygaster/squad.gitStep 4: Fetch the dev branch
git fetch upstream devStep 5: Install dependencies
npm installnpm workspaces automatically links local packages. @bradygaster/squad-cli can import from @bradygaster/squad-sdk without publishing.
# Compile TypeScript to dist/
npm run build
# Build + bundle CLI (includes esbuild)
npm run build:cli
# Watch mode (auto-recompile on changes)
npm run dev# Run all tests (Vitest)
npm test
# Watch mode
npm run test:watch# Type check only (no emit)
npm run lintBefore opening or updating a PR, rebase your branch on the latest upstream dev:
git fetch upstream
git rebase upstream/dev
git push origin your-branch --force-with-leaseAlways rebase before opening or updating a PR to ensure your changes are based on the latest integration branch.
Follow the branch naming convention from .squad/decisions.md:
# For user-facing work, use user_name/issue-number-slug format
git checkout -b bradygaster/217-readme-help-update
# or
git checkout -b keaton/210-resolution-api
# For team-internal work, use agent_name/issue-number-slug
git checkout -b mcmanus/documentation
git checkout -b edie/refactor-router- Compile:
npm run build(ornpm run devwatch mode) - Test:
npm test - Type check:
npm run lint
All checks must pass before commit.
Keep messages clear and concise. Reference the issue number:
Brief description of change
Longer explanation if needed. Reference #210, #217, etc.
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
The Co-authored-by trailer is required for all commits (added by Copilot CLI).
- Add a changeset:
npx changeset add(required before PR — see Changesets section) - Push your branch:
git push origin {yourusername}/217-readme-help-update - Create a PR with explicit base and head:
gh pr create --base dev --repo bradygaster/squad --head {yourusername}:your-branch - Link the issue: Add
Closes #217to PR description - Wait for CI checks to pass
- Request review from the team (agents will respond via comments)
Squad follows strict TypeScript conventions:
- Type Safety:
strict: true,noUncheckedIndexedAccess: true - No
@ts-ignore— if a type error exists, fix the code - ESM-only — no CommonJS, no dual-package
- Async/await — use async iterators for streaming
- Error handling: Structured errors with
fatal(),error(),warn(),info() - No hype in docs — factual, substantiated claims only (tone ceiling)
- README.md — User-facing guide, quick start, architecture overview
- CONTRIBUTING.md — This file
- docs/proposals/ — Design docs for significant changes (required before code)
- .squad/agents/[name]/history.md — Agent learnings and project context
All docs in v1 are internal only. No public docs site until v2.
When developing Squad locally, set the package version to {next-version}-preview. For example, if the last published version is 0.8.5.1, the local dev version should be 0.8.6-preview.
This convention makes squad version show the preview tag locally, clearly indicating you're running unreleased source code, not the published npm package. The release agent will bump this to the final version at publish time, then immediately back to the next preview version for continued development.
To make the squad CLI command globally available and pointing to your local development build:
npm run build -w packages/squad-sdk && npm run build -w packages/squad-cli
npm link -w packages/squad-cliAfter this, squad version will show 0.8.6-preview (or the current preview version). When you make code changes and rebuild, the squad command automatically picks up the changes—no need to reinstall. To verify your local build is active, the version output should include the -preview tag.
To revert back to the globally installed npm package version, run:
npm unlink -w packages/squad-cliSquad uses @changesets/cli for independent package versioning.
Before your PR is merged, add a changeset describing your changes:
npx changeset addThis prompts:
- Which packages changed? (squad-sdk, squad-cli, both)
- What type? (patch, minor, major)
- Brief summary of changes
Creates a file in .changeset/ that's merged with your PR.
---
"@bradygaster/squad-sdk": patch
"@bradygaster/squad-cli": patch
---
Update help text and README for npm distribution. Add squad status command to docs.The team runs changesets on the main branch (via GitHub Actions):
npx changeset publishThis:
- Bumps versions in
package.json - Generates
CHANGELOG.mdentries - Publishes to npm
- Creates GitHub releases
You don't need to manually version — changesets handle it.
- main — Stable, published releases. All merges include changesets.
- insider — Pre-release features, edge cases. Tag releases as
@insider. - bradygaster/dev — Integration branch. All PRs from forks must target this branch, not
main. - user/issue-slug — Feature branches from users or agents.
GitHub Actions runs on every push:
- Build:
npm run buildandnpm run build:cli - Test:
npm test - Lint:
npm run lint - Changeset status:
npm run changeset:check(ensures PRs include a changeset)
All checks must pass before merge.
- Create the command file in
src/cli/commands/[name].js - Add the route in
src/index.ts(themain()function) - Update help text in the
--helphandler - Add tests in
test/cli/commands/[name].test.ts - Document in README.md
- Implement the feature in
src/[module]/ - Export from
src/index.ts - Add tests
- Document in README.md SDK section
The src/ directory contains legacy code migrating to packages/squad-cli/ and packages/squad-sdk/. When moving code:
- Create the new file in the target package
- Update imports in both locations
- Ensure tests follow the file
- Delete the old
src/file once all references are updated - Document the migration in
.squad/agents/[name]/history.md
- src/index.ts — CLI entry point and routing
- src/resolution.ts — Squad path resolution (repo vs. global)
- .squad/decisions.md — Team decisions and conventions
- .squad/agents/[name]/charter.md — Agent identity and expertise
- package.json — Workspace and script definitions
Open an issue or ask in .squad/ discussion channels. The team is here to help.
All contributions are MIT-licensed. By submitting a PR, you agree to this license.