2026-02-09 12:24:11 -08:00
---
title: CI Pipeline
2026-02-22 20:36:39 +01:00
summary: "CI job graph, scope gates, and local command equivalents"
read_when:
- You need to understand why a CI job did or did not run
- You are debugging failing GitHub Actions checks
2026-02-09 12:24:11 -08:00
---
# CI Pipeline
2026-03-13 19:42:08 +00:00
The CI runs on every push to `main` and every pull request. It uses smart scoping to skip expensive jobs when only unrelated areas changed.
2026-02-09 12:24:11 -08:00
2026-02-09 18:30:05 -08:00
## Job Overview
2026-02-09 12:24:11 -08:00
2026-04-04 10:24:24 +01:00
| Job | Purpose | When it runs |
| ------------------------ | ---------------------------------------------------------------------------------------- | ----------------------------------- |
| `preflight` | Detect docs-only changes, changed scopes, changed extensions, and build the CI manifest | Always on non-draft pushes and PRs |
| `security-fast` | Private key detection, workflow audit via `zizmor` , production dependency audit | Always on non-draft pushes and PRs |
| `build-artifacts` | Build `dist/` and the Control UI once, upload reusable artifacts for downstream jobs | Node-relevant changes |
| `checks-fast-core` | Fast Linux correctness lanes such as bundled/plugin-contract/protocol checks | Node-relevant changes |
| `checks-fast-extensions` | Aggregate the extension shard lanes after `checks-fast-extensions-shard` completes | Node-relevant changes |
| `extension-fast` | Focused tests for only the changed bundled plugins | When extension changes are detected |
| `check` | Main local gate in CI: `pnpm check` plus `pnpm build:strict-smoke` | Node-relevant changes |
| `check-additional` | Architecture and boundary guards plus the gateway watch regression harness | Node-relevant changes |
| `build-smoke` | Built-CLI smoke tests and startup-memory smoke | Node-relevant changes |
| `checks` | Heavier Linux Node lanes: full tests, channel tests, and push-only Node 22 compatibility | Node-relevant changes |
| `check-docs` | Docs formatting, lint, and broken-link checks | Docs changed |
| `skills-python` | Ruff + pytest for Python-backed skills | Python-skill-relevant changes |
| `checks-windows` | Windows-specific test lanes | Windows-relevant changes |
| `macos-node` | macOS TypeScript test lane using the shared built artifacts | macOS-relevant changes |
| `macos-swift` | Swift lint, build, and tests for the macOS app | macOS-relevant changes |
| `android` | Android build and test matrix | Android-relevant changes |
2026-02-09 12:24:11 -08:00
2026-02-09 18:30:05 -08:00
## Fail-Fast Order
2026-02-09 12:24:11 -08:00
2026-02-09 18:30:05 -08:00
Jobs are ordered so cheap checks fail before expensive ones run:
2026-02-09 12:24:11 -08:00
2026-04-04 10:24:24 +01:00
1. `preflight` decides which lanes exist at all. The `docs-scope` and `changed-scope` logic are steps inside this job, not standalone jobs.
2. `security-fast` , `check` , `check-additional` , `check-docs` , and `skills-python` fail quickly without waiting on the heavier artifact and platform matrix jobs.
3. `build-artifacts` overlaps with the fast Linux lanes so downstream consumers can start as soon as the shared build is ready.
4. Heavier platform and runtime lanes fan out after that: `checks-fast-core` , `checks-fast-extensions` , `extension-fast` , `checks` , `checks-windows` , `macos-node` , `macos-swift` , and `android` .
2026-02-09 12:24:11 -08:00
2026-03-03 02:37:04 +00:00
Scope logic lives in `scripts/ci-changed-scope.mjs` and is covered by unit tests in `src/scripts/ci-changed-scope.test.ts` .
2026-04-04 10:24:24 +01:00
The separate `install-smoke` workflow reuses the same scope script through its own `preflight` job. It computes `run_install_smoke` from the narrower changed-smoke signal, so Docker/install smoke only runs for install, packaging, and container-relevant changes.
On pushes, the `checks` matrix adds the push-only `compat-node22` lane. On pull requests, that lane is skipped and the matrix stays focused on the normal test/channel lanes.
2026-03-03 02:37:04 +00:00
2026-02-09 18:30:05 -08:00
## Runners
2026-02-09 12:24:11 -08:00
2026-04-04 10:24:24 +01:00
| Runner | Jobs |
| -------------------------------- | ---------------------------------------------------------------------------------------------------- |
| `blacksmith-16vcpu-ubuntu-2404` | `preflight` , `security-fast` , `build-artifacts` , Linux checks, docs checks, Python skills, `android` |
| `blacksmith-32vcpu-windows-2025` | `checks-windows` |
| `macos-latest` | `macos-node` , `macos-swift` |
2026-02-09 12:24:11 -08:00
2026-02-09 18:30:05 -08:00
## Local Equivalents
2026-02-09 12:24:11 -08:00
2026-02-09 18:30:05 -08:00
``` bash
pnpm check # types + lint + format
2026-04-04 10:24:24 +01:00
pnpm build:strict-smoke
pnpm test:gateway:watch-regression
2026-02-09 18:30:05 -08:00
pnpm test # vitest tests
2026-04-04 10:24:24 +01:00
pnpm test:channels
2026-02-09 18:30:05 -08:00
pnpm check:docs # docs format + lint + broken links
2026-04-04 10:24:24 +01:00
pnpm build # build dist when CI artifact/build-smoke lanes matter
2026-02-09 18:30:05 -08:00
```