Files
moltbot/docs/ci.md
2026-03-03 02:42:32 +00:00

3.1 KiB

title, description, summary, read_when
title description summary read_when
CI Pipeline How the OpenClaw CI pipeline works CI job graph, scope gates, and local command equivalents
You need to understand why a CI job did or did not run
You are debugging failing GitHub Actions checks

CI Pipeline

The CI runs on every push to main and every pull request. It uses smart scoping to skip expensive jobs when only docs or native code changed.

Job Overview

Job Purpose When it runs
docs-scope Detect docs-only changes Always
changed-scope Detect which areas changed (node/macos/android) Non-docs PRs
check TypeScript types, lint, format Push to main, or PRs with Node-relevant changes
check-docs Markdown lint + broken link check Docs changed
code-analysis LOC threshold check (1000 lines) PRs only
secrets Detect leaked secrets Always
build-artifacts Build dist once, share with other jobs Non-docs, node changes
release-check Validate npm pack contents After build
checks Node/Bun tests + protocol check Non-docs, node changes
checks-windows Windows-specific tests Non-docs, node changes
macos Swift lint/build/test + TS tests PRs with macos changes
android Gradle build + tests Non-docs, android changes

Fail-Fast Order

Jobs are ordered so cheap checks fail before expensive ones run:

  1. docs-scope + code-analysis + check (parallel, ~1-2 min)
  2. build-artifacts (blocked on above)
  3. checks, checks-windows, macos, android (blocked on build)

Scope logic lives in scripts/ci-changed-scope.mjs and is covered by unit tests in src/scripts/ci-changed-scope.test.ts.

Runners

Runner Jobs
blacksmith-16vcpu-ubuntu-2404 Most Linux jobs, including scope detection
blacksmith-32vcpu-windows-2025 checks-windows
macos-latest macos, ios

Local Equivalents

pnpm check          # types + lint + format
pnpm test           # vitest tests
pnpm check:docs     # docs format + lint + broken links
pnpm release:check  # validate npm pack