examples/integrations/_parity/README.md
_parity/ — integration-demo parity toolingKeeps examples/integrations/* demos aligned to a single north-star so
drift doesn't pile up as the canonical demo evolves.
North-star (v1): langgraph-python — the richest demo (todos state, 5
tools, polished prompt, full frontend canvas). Every other integration demo
should track it.
Declared in manifest.json:
docker-compose.test.yml, entrypoint.sh, postcss.config.mjs, etc.)@copilotkit/*, next, react, shared dev scripts). Per-instance
overrides in manifest (packageJsonOverrides) win where the instance
legitimately differs (e.g. dev:agent runs npm install in JS but
uv sync in FastAPI)._parity/canonical/PROMPT.md. Each agent
inlines the prompt as a string literal in its source (matching the
north-star's main.py pattern). Verifier greps the canonical prompt's
first non-blank line against instance agent source — drift = error.Per-instance allowedDivergence list in manifest.json:
agent/** — agents are written in different languages/runtimes (Python
create_agent, TS StateGraph, Python StateGraph+FastAPI). Human-authored.src/app/api/copilotkit/** — north-star uses LangGraphAgent, Docker
instances use HttpAgent. Different routes.Dockerfile, docker/Dockerfile.agent, serve.py, scripts/** —
language-specific build/run tooling.Anything outside both tracked and allowedDivergence is "no-op" — the
verifier neither checks nor touches it.
From the repo root:
# Sync a single instance to north-star (copies verbatim files, rewrites
# package.json keys, writes canonical prompt to agent/PROMPT.md)
pnpm parity:sync --target=langgraph-js
# Dry-run: show what would change without writing
pnpm parity:sync --target=langgraph-js --dry-run
# Sync every non-north-star instance
pnpm parity:sync --all
# Verify — exits non-zero on unexpected drift
pnpm parity:verify
pnpm parity:verify --target=langgraph-js
# CI invocation (same as verify, no color)
pnpm parity:check
pnpm parity:sync --all
pnpm parity:verify
# fix any agent-surface drift manually in the relevant agent/src/ files
git add . && git commit
examples/integrations/<name>/ with a
Next.js frontend at the root and an agent/ dir.manifest.json under instances:
"new-demo": {
"role": "instance",
"agent": { "language": "python", "runtime": "..." },
"allowedDivergence": ["agent/**", "src/app/api/copilotkit/**",
"Dockerfile", "docker/Dockerfile.agent",
"serve.py", "scripts/**"],
"packageJsonOverrides": { "scripts.dev:agent": "..." }
}
pnpm parity:sync --target=new-demo.tracked.agentSurface tells you what tool names and state keys are
required.pnpm parity:verify --target=new-demo until green.Edit manifest.json → tracked.agentSurface.toolNames / stateKeys.
The verifier will then flag every instance that hasn't caught up.
_parity/canonical/PROMPT.md.agent/main.py to use the new prompt string
(north-star is where humans read; canonical file is what the
verifier reads).pnpm parity:verify — verifier greps first line of canonical against
each instance's agent source. Passes when all instances inline it..github/workflows/integrations_parity.yml runs pnpm parity:check on
every PR that touches examples/integrations/**. Failures link the
contributor back to this README.
fixtures/default.json per instance)
are the real correctness check; this is the "did someone rip out
manage_todos" safety net.sync.ts refuses to write
into the north-star directory even if asked. Verifier never touches
anything.