@kontourai/flow-agents 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.githooks/pre-push +11 -0
- package/.github/workflows/ci.yml +210 -0
- package/.github/workflows/docs-pages.yml +52 -0
- package/.github/workflows/publish-npm.yml +104 -0
- package/AGENTS.md +26 -0
- package/CHANGELOG.md +66 -0
- package/CODE_OF_CONDUCT.md +25 -0
- package/CONTEXT.md +300 -0
- package/CONTRIBUTING.md +44 -0
- package/LICENSE +201 -0
- package/README.md +129 -0
- package/SECURITY.md +33 -0
- package/agent-cards/dev.json +19 -0
- package/agents/dev.json +127 -0
- package/agents/tool-code-reviewer.json +61 -0
- package/agents/tool-dependencies-updater.json +118 -0
- package/agents/tool-explore-config.json +92 -0
- package/agents/tool-explore-deps.json +92 -0
- package/agents/tool-explore-entry.json +92 -0
- package/agents/tool-explore-patterns.json +92 -0
- package/agents/tool-explore-structure.json +92 -0
- package/agents/tool-explore-tests.json +92 -0
- package/agents/tool-planner.json +57 -0
- package/agents/tool-playwright.json +145 -0
- package/agents/tool-security-reviewer.json +56 -0
- package/agents/tool-verifier.json +61 -0
- package/agents/tool-worker.json +58 -0
- package/build/src/cli/console-learning-projection.js +123 -0
- package/build/src/cli/docs-preview.js +39 -0
- package/build/src/cli/effective-backlog-settings.js +102 -0
- package/build/src/cli/export-bookmarks.js +38 -0
- package/build/src/cli/fixture-retirement-audit.js +140 -0
- package/build/src/cli/flow-kit.js +138 -0
- package/build/src/cli/import-bookmarks.js +50 -0
- package/build/src/cli/init.js +239 -0
- package/build/src/cli/instinct-cli.js +93 -0
- package/build/src/cli/promote-workflow-artifact.js +63 -0
- package/build/src/cli/publish-change-helper.js +154 -0
- package/build/src/cli/pull-work-provider.js +469 -0
- package/build/src/cli/runtime-adapter.js +23 -0
- package/build/src/cli/telemetry-doctor.js +221 -0
- package/build/src/cli/usage-feedback.js +443 -0
- package/build/src/cli/validate-hook-influence.js +152 -0
- package/build/src/cli/validate-source-tree.js +31 -0
- package/build/src/cli/validate-workflow-artifacts.js +486 -0
- package/build/src/cli/veritas-governance.js +262 -0
- package/build/src/cli/workflow-artifact-cleanup-audit.js +272 -0
- package/build/src/cli/workflow-sidecar.js +816 -0
- package/build/src/cli.js +89 -0
- package/build/src/flow-kit/validate.js +75 -0
- package/build/src/lib/args.js +45 -0
- package/build/src/lib/fs.js +62 -0
- package/build/src/lib/workflow-learning-projection.js +334 -0
- package/build/src/runtime-adapters.js +146 -0
- package/build/src/tools/build-universal-bundles.js +397 -0
- package/build/src/tools/common.js +56 -0
- package/build/src/tools/filter-installed-packs.js +132 -0
- package/build/src/tools/generate-context-map.js +198 -0
- package/build/src/tools/validate-package.js +64 -0
- package/build/src/tools/validate-source-tree.js +622 -0
- package/console.telemetry.json +176 -0
- package/context/base-rules.md +17 -0
- package/context/code-review-standards.md +62 -0
- package/context/coding-standards.md +42 -0
- package/context/common/orchestrators.md +12 -0
- package/context/common/subagents.md +28 -0
- package/context/contracts/artifact-contract.md +182 -0
- package/context/contracts/builder-kit-workflow-state-contract.md +319 -0
- package/context/contracts/delivery-contract.md +69 -0
- package/context/contracts/execution-contract.md +53 -0
- package/context/contracts/governance-adapter-contract.md +67 -0
- package/context/contracts/planning-contract.md +85 -0
- package/context/contracts/review-contract.md +104 -0
- package/context/contracts/sandbox-policy.md +52 -0
- package/context/contracts/verification-contract.md +134 -0
- package/context/contracts/work-item-contract.md +215 -0
- package/context/deferred/demo-mode.md +33 -0
- package/context/deferred/languages/go.md +31 -0
- package/context/deferred/languages/python.md +31 -0
- package/context/deferred/languages/typescript.md +34 -0
- package/context/deferred/parallelization.md +35 -0
- package/context/deferred/worktree-isolation.md +24 -0
- package/context/development-workflow.md +50 -0
- package/context/scripts/context-budget/budget-scan.sh +166 -0
- package/context/scripts/detect-tools.sh +3 -0
- package/context/scripts/discover-agents.sh +28 -0
- package/context/scripts/git-status.sh +49 -0
- package/context/scripts/hooks/config-protection.js +79 -0
- package/context/scripts/hooks/desktop-notify.sh +39 -0
- package/context/scripts/hooks/governance-audit.sh +135 -0
- package/context/scripts/hooks/lib/audit-transport.sh +40 -0
- package/context/scripts/hooks/lib/hook-flags.js +49 -0
- package/context/scripts/hooks/lib/patterns.sh +57 -0
- package/context/scripts/hooks/lib/resolve-formatter.js +80 -0
- package/context/scripts/hooks/post-edit-accumulator.js +66 -0
- package/context/scripts/hooks/pre-commit-quality.js +194 -0
- package/context/scripts/hooks/quality-gate.js +93 -0
- package/context/scripts/hooks/report-only-guard.js +21 -0
- package/context/scripts/hooks/run-hook.js +136 -0
- package/context/scripts/hooks/stop-format-typecheck.js +141 -0
- package/context/scripts/hooks/stop-goal-fit.js +337 -0
- package/context/scripts/hooks/workflow-steering.js +250 -0
- package/context/scripts/telemetry/console-presets.sh +14 -0
- package/context/scripts/telemetry/install-console-config.sh +214 -0
- package/context/scripts/telemetry/lib/config.sh +85 -0
- package/context/scripts/telemetry/lib/enrich.sh +115 -0
- package/context/scripts/telemetry/lib/redact.sh +22 -0
- package/context/scripts/telemetry/lib/session.sh +63 -0
- package/context/scripts/telemetry/lib/transport.sh +183 -0
- package/context/scripts/telemetry/lib/usage.sh +29 -0
- package/context/scripts/telemetry/sync-agents.sh +173 -0
- package/context/scripts/telemetry/telemetry.conf +23 -0
- package/context/scripts/telemetry/telemetry.sh +387 -0
- package/context/scripts/validate-package.sh +89 -0
- package/context/settings/backlog-provider-settings.json +54 -0
- package/context/templates/core/identity.md +26 -0
- package/context/templates/core/user.md +15 -0
- package/docs/_config.yml +15 -0
- package/docs/_layouts/default.html +87 -0
- package/docs/adr/0001-flow-agents-consumes-flow.md +77 -0
- package/docs/adr/0002-flow-kits-as-extension-unit.md +13 -0
- package/docs/adr/0003-flow-agents-coordinates-kits-and-adapters.md +13 -0
- package/docs/adr/0004-gates-expect-surface-claims.md +15 -0
- package/docs/adr/0005-kubernetes-inspired-resource-contracts.md +48 -0
- package/docs/adr/0006-typescript-first-source-policy.md +98 -0
- package/docs/agent-system-guidebook.md +391 -0
- package/docs/agent-usage-feedback-loop.md +351 -0
- package/docs/assets/favicon.svg +13 -0
- package/docs/assets/og-image.png +0 -0
- package/docs/assets/site.css +774 -0
- package/docs/assets/site.js +139 -0
- package/docs/configurable-workflow-routing.md +174 -0
- package/docs/context-map.md +145 -0
- package/docs/developer-architecture.md +145 -0
- package/docs/developer-hook-setup.md +61 -0
- package/docs/fixture-ownership.md +44 -0
- package/docs/flow-kit-repository-contract.md +180 -0
- package/docs/index.md +129 -0
- package/docs/kontour-resource-contract.md +358 -0
- package/docs/migrations.md +64 -0
- package/docs/north-star.md +322 -0
- package/docs/operating-layers.md +110 -0
- package/docs/repository-structure.md +132 -0
- package/docs/sandbox-policy.md +56 -0
- package/docs/skills-map.md +203 -0
- package/docs/standards-register.md +96 -0
- package/docs/veritas-integration.md +165 -0
- package/docs/work-item-adapters.md +72 -0
- package/docs/workflow-artifact-lifecycle.md +141 -0
- package/docs/workflow-eval-strategy.md +295 -0
- package/docs/workflow-shared-contracts.md +51 -0
- package/docs/workflow-usage-guide.md +443 -0
- package/evals/ARCHITECTURE.md +143 -0
- package/evals/CONVENTIONS.md +58 -0
- package/evals/README.md +128 -0
- package/evals/acceptance/run.sh +29 -0
- package/evals/acceptance/test_claude_harness.sh +242 -0
- package/evals/acceptance/test_codex_harness.sh +108 -0
- package/evals/acceptance/test_kiro_harness.sh +128 -0
- package/evals/cases/dev/404.html +97 -0
- package/evals/cases/dev/code-review.yaml +44 -0
- package/evals/cases/dev/dashboard.html +300 -0
- package/evals/cases/dev/deliver.yaml +66 -0
- package/evals/cases/dev/dependency-update.yaml +16 -0
- package/evals/cases/dev/explore.yaml +20 -0
- package/evals/cases/dev/index.html +370 -0
- package/evals/cases/dev/package-lock.json +28 -0
- package/evals/cases/dev/package.json +16 -0
- package/evals/cases/dev/plan-work.yaml +20 -0
- package/evals/cases/dev/promptfooconfig.yaml +666 -0
- package/evals/cases/dev/search-first.yaml +20 -0
- package/evals/cases/dev/tdd-workflow.yaml +48 -0
- package/evals/cases/dev/verify-work.yaml +44 -0
- package/evals/cases/dev/workflow.yaml +34 -0
- package/evals/ci/run-baseline.sh +283 -0
- package/evals/fixtures/backlog-provider-settings/global-default.json +44 -0
- package/evals/fixtures/backlog-provider-settings/project-override.json +53 -0
- package/evals/fixtures/builder-kit-workflow-state/baseline-freshness-resolution-hint.json +139 -0
- package/evals/fixtures/builder-kit-workflow-state/direct-primitive-stop.json +59 -0
- package/evals/fixtures/builder-kit-workflow-state/empty-board-route-shape.json +55 -0
- package/evals/fixtures/builder-kit-workflow-state/happy-path.json +71 -0
- package/evals/fixtures/builder-kit-workflow-state/mid-work-resume.json +80 -0
- package/evals/fixtures/builder-kit-workflow-state/missing-prestep-recovery.json +65 -0
- package/evals/fixtures/builder-kit-workflow-state/product-build-chaining.json +60 -0
- package/evals/fixtures/builder-kit-workflow-state/stale-continuation-requires-new-probe.json +57 -0
- package/evals/fixtures/console-learning-projection/artifacts/console-learning-correction/learning.json +50 -0
- package/evals/fixtures/console-learning-projection/artifacts/console-learning-open-route/learning.json +41 -0
- package/evals/fixtures/flow-kit-repository/invalid-absolute-path/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/invalid-asset-section/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-asset-section/kit.json +11 -0
- package/evals/fixtures/flow-kit-repository/invalid-duplicate-flow/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-duplicate-flow/kit.json +9 -0
- package/evals/fixtures/flow-kit-repository/invalid-id/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-id/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/invalid-malformed-json/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/invalid-missing-flow/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/invalid-missing-id/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-missing-id/kit.json +7 -0
- package/evals/fixtures/flow-kit-repository/invalid-missing-schema-version/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-missing-schema-version/kit.json +7 -0
- package/evals/fixtures/flow-kit-repository/invalid-name/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-name/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/invalid-schema-version/flows/review.flow.json +6 -0
- package/evals/fixtures/flow-kit-repository/invalid-schema-version/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/invalid-traversal/kit.json +8 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/adapters/example.json +3 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/assets/example.txt +1 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/docs/README.md +3 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/flows/runtime.flow.json +26 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/kit-evals/example.json +3 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/kit-skills/mixed/SKILL.md +3 -0
- package/evals/fixtures/flow-kit-repository/mixed-runtime-kit/kit.json +44 -0
- package/evals/fixtures/flow-kit-repository/valid-local-kit/docs/README.md +3 -0
- package/evals/fixtures/flow-kit-repository/valid-local-kit/flows/review.flow.json +26 -0
- package/evals/fixtures/flow-kit-repository/valid-local-kit/kit.json +20 -0
- package/evals/fixtures/hook-influence/cases.json +336 -0
- package/evals/fixtures/pull-work-provider/github-issues.json +170 -0
- package/evals/fixtures/pull-work-wip-shepherding/global-wip-informs.json +43 -0
- package/evals/fixtures/pull-work-wip-shepherding/personal-wip-blocks.json +42 -0
- package/evals/fixtures/surface-trust/accepted-claim-trust-report.json +31 -0
- package/evals/fixtures/surface-trust/artifact-absent.json +19 -0
- package/evals/fixtures/surface-trust/integrity-mismatch-trust-report.json +32 -0
- package/evals/fixtures/surface-trust/missing-authority-trust-report.json +27 -0
- package/evals/fixtures/surface-trust/provider-absent.json +19 -0
- package/evals/fixtures/surface-trust/rejected-claim-trust-report.json +30 -0
- package/evals/fixtures/surface-trust/stale-claim-trust-snapshot.json +31 -0
- package/evals/fixtures/usage-feedback/sample-full.jsonl +11 -0
- package/evals/fixtures/usage-feedback/sample-outcomes.jsonl +1 -0
- package/evals/fixtures/veritas-governance-adapter/fake-veritas-pass.sh +18 -0
- package/evals/fixtures/veritas-governance-adapter/fake-veritas-secret-fail.sh +10 -0
- package/evals/fixtures/veritas-governance-adapter/fake-veritas-unconfigured.sh +4 -0
- package/evals/integration/test_bundle_install.sh +541 -0
- package/evals/integration/test_console_learning_projection.sh +192 -0
- package/evals/integration/test_context_map.sh +65 -0
- package/evals/integration/test_effective_backlog_settings.sh +58 -0
- package/evals/integration/test_fixture_retirement_audit.sh +58 -0
- package/evals/integration/test_flow_agents_statusline.sh +93 -0
- package/evals/integration/test_flow_kit_repository.sh +90 -0
- package/evals/integration/test_goal_fit_hook.sh +482 -0
- package/evals/integration/test_hook_category_behaviors.sh +190 -0
- package/evals/integration/test_hook_influence_cases.sh +69 -0
- package/evals/integration/test_local_flow_kit_install.sh +145 -0
- package/evals/integration/test_publish_change_helper.sh +176 -0
- package/evals/integration/test_pull_work_provider.sh +140 -0
- package/evals/integration/test_runtime_adapter_activation.sh +106 -0
- package/evals/integration/test_telemetry.sh +485 -0
- package/evals/integration/test_telemetry_doctor.sh +193 -0
- package/evals/integration/test_usage_feedback_dashboard.sh +169 -0
- package/evals/integration/test_usage_feedback_global.sh +117 -0
- package/evals/integration/test_usage_feedback_import.sh +227 -0
- package/evals/integration/test_usage_feedback_outcomes.sh +165 -0
- package/evals/integration/test_usage_feedback_report.sh +263 -0
- package/evals/integration/test_veritas_governance_adapter.sh +235 -0
- package/evals/integration/test_workflow_artifact_cleanup_audit.sh +287 -0
- package/evals/integration/test_workflow_artifacts.sh +1247 -0
- package/evals/integration/test_workflow_sidecar_writer.sh +2112 -0
- package/evals/integration/test_workflow_steering_hook.sh +337 -0
- package/evals/lib/assertions/delegated-to.js +40 -0
- package/evals/lib/assertions/max-tool-calls.js +15 -0
- package/evals/lib/assertions/no-write-tools.js +27 -0
- package/evals/lib/assertions/pass-at-k.js +39 -0
- package/evals/lib/assertions/telemetry-utils.js +105 -0
- package/evals/lib/assertions/tool-called.js +39 -0
- package/evals/lib/assertions/verify-after-fix.js +61 -0
- package/evals/lib/claude-judge.sh +40 -0
- package/evals/lib/claude-provider.sh +74 -0
- package/evals/lib/codex-judge.sh +39 -0
- package/evals/lib/codex-provider.sh +81 -0
- package/evals/lib/eval-dev.sh +5 -0
- package/evals/lib/eval-judge.sh +22 -0
- package/evals/lib/eval-provider.sh +26 -0
- package/evals/lib/eval-report.sh +73 -0
- package/evals/lib/kiro-dev.sh +4 -0
- package/evals/lib/kiro-judge.sh +17 -0
- package/evals/lib/kiro-provider.sh +62 -0
- package/evals/lib/node.sh +111 -0
- package/evals/promptfooconfig.yaml +70 -0
- package/evals/run.sh +309 -0
- package/evals/static/test_evidence_refs.sh +141 -0
- package/evals/static/test_package.sh +407 -0
- package/evals/static/test_repo_hooks.sh +68 -0
- package/evals/static/test_universal_bundles.sh +274 -0
- package/evals/static/test_workflow_skills.sh +1207 -0
- package/install.sh +64 -0
- package/integrations/veritas/flow-agents.adapter.json +138 -0
- package/integrations/veritas/flow-agents.authority-settings.json +26 -0
- package/integrations/veritas/flow-agents.repo-standards.json +82 -0
- package/kits/builder/flows/build.flow.json +218 -0
- package/kits/builder/flows/shape.flow.json +127 -0
- package/kits/builder/kit.json +19 -0
- package/kits/catalog.json +11 -0
- package/package.json +130 -0
- package/packaging/README.md +60 -0
- package/packaging/manifest.json +173 -0
- package/packaging/packs.json +69 -0
- package/powers/dependency-checker/POWER.md +20 -0
- package/powers/dependency-checker/mcp.json +20 -0
- package/powers/playwright/POWER.md +25 -0
- package/powers/playwright/mcp.json +12 -0
- package/prompts/code-audit.md +123 -0
- package/prompts/kcommit.md +88 -0
- package/schemas/backlog-provider-settings.schema.json +138 -0
- package/schemas/workflow-acceptance.schema.json +216 -0
- package/schemas/workflow-critique.schema.json +113 -0
- package/schemas/workflow-evidence.schema.json +357 -0
- package/schemas/workflow-handoff.schema.json +52 -0
- package/schemas/workflow-learning.schema.json +223 -0
- package/schemas/workflow-release.schema.json +172 -0
- package/schemas/workflow-state.schema.json +80 -0
- package/scripts/README.md +111 -0
- package/scripts/build-universal-bundles.js +3 -0
- package/scripts/check-content-boundary.cjs +99 -0
- package/scripts/context-budget/budget-scan.sh +166 -0
- package/scripts/detect-tools.sh +3 -0
- package/scripts/discover-agents.sh +28 -0
- package/scripts/effective-backlog-settings.js +2 -0
- package/scripts/filter-installed-packs.js +2 -0
- package/scripts/flow-kit.js +2 -0
- package/scripts/generate-context-map.js +2 -0
- package/scripts/git-status.sh +49 -0
- package/scripts/hooks/claude-hook-adapter.js +174 -0
- package/scripts/hooks/claude-telemetry-hook.js +115 -0
- package/scripts/hooks/codex-hook-adapter.js +176 -0
- package/scripts/hooks/codex-telemetry-hook.js +95 -0
- package/scripts/hooks/config-protection.js +79 -0
- package/scripts/hooks/desktop-notify.sh +39 -0
- package/scripts/hooks/governance-audit.sh +135 -0
- package/scripts/hooks/lib/audit-transport.sh +40 -0
- package/scripts/hooks/lib/hook-flags.js +49 -0
- package/scripts/hooks/lib/patterns.sh +57 -0
- package/scripts/hooks/lib/resolve-formatter.js +80 -0
- package/scripts/hooks/post-edit-accumulator.js +66 -0
- package/scripts/hooks/pre-commit-quality.js +194 -0
- package/scripts/hooks/quality-gate.js +93 -0
- package/scripts/hooks/report-only-guard.js +21 -0
- package/scripts/hooks/run-hook.js +136 -0
- package/scripts/hooks/stop-format-typecheck.js +141 -0
- package/scripts/hooks/stop-goal-fit.js +337 -0
- package/scripts/hooks/workflow-steering.js +250 -0
- package/scripts/install-codex-home.sh +106 -0
- package/scripts/package.json +3 -0
- package/scripts/promote-workflow-artifact.js +2 -0
- package/scripts/publish-change-helper.js +2 -0
- package/scripts/pull-work-provider.js +2 -0
- package/scripts/setup-repo-hooks.sh +8 -0
- package/scripts/statusline/flow-agents-statusline.js +157 -0
- package/scripts/telemetry/console-presets.sh +14 -0
- package/scripts/telemetry/install-console-config.sh +214 -0
- package/scripts/telemetry/lib/config.sh +85 -0
- package/scripts/telemetry/lib/enrich.sh +115 -0
- package/scripts/telemetry/lib/redact.sh +22 -0
- package/scripts/telemetry/lib/session.sh +63 -0
- package/scripts/telemetry/lib/transport.sh +183 -0
- package/scripts/telemetry/lib/usage.sh +29 -0
- package/scripts/telemetry/sync-agents.sh +173 -0
- package/scripts/telemetry/telemetry.conf +23 -0
- package/scripts/telemetry/telemetry.sh +387 -0
- package/scripts/usage-feedback.js +2 -0
- package/scripts/validate-hook-influence-cases.js +2 -0
- package/scripts/validate-package.sh +89 -0
- package/scripts/validate-source-tree.js +9 -0
- package/skills/agentic-engineering/SKILL.md +62 -0
- package/skills/browser-test/SKILL.md +51 -0
- package/skills/builder-shape/SKILL.md +76 -0
- package/skills/context-budget/SKILL.md +40 -0
- package/skills/deliver/SKILL.md +241 -0
- package/skills/dependency-update/SKILL.md +68 -0
- package/skills/design-probe/SKILL.md +107 -0
- package/skills/eval-rebuild/SKILL.md +39 -0
- package/skills/evidence-gate/SKILL.md +186 -0
- package/skills/execute-plan/SKILL.md +110 -0
- package/skills/explore/SKILL.md +137 -0
- package/skills/feedback-loop/SKILL.md +87 -0
- package/skills/fix-bug/SKILL.md +133 -0
- package/skills/frontend-design/SKILL.md +80 -0
- package/skills/github-cli/SKILL.md +63 -0
- package/skills/idea-to-backlog/SKILL.md +267 -0
- package/skills/knowledge-capture/SKILL.md +55 -0
- package/skills/learning-review/SKILL.md +115 -0
- package/skills/pickup-probe/SKILL.md +114 -0
- package/skills/plan-work/SKILL.md +176 -0
- package/skills/pull-work/SKILL.md +309 -0
- package/skills/release-readiness/SKILL.md +121 -0
- package/skills/review-work/SKILL.md +161 -0
- package/skills/search-first/SKILL.md +66 -0
- package/skills/tdd-workflow/SKILL.md +140 -0
- package/skills/verify-work/SKILL.md +109 -0
- package/src/cli/console-learning-projection.ts +140 -0
- package/src/cli/effective-backlog-settings.ts +99 -0
- package/src/cli/fixture-retirement-audit.ts +154 -0
- package/src/cli/flow-kit.ts +139 -0
- package/src/cli/init.ts +248 -0
- package/src/cli/promote-workflow-artifact.ts +64 -0
- package/src/cli/publish-change-helper.ts +143 -0
- package/src/cli/pull-work-provider.ts +481 -0
- package/src/cli/runtime-adapter.ts +24 -0
- package/src/cli/telemetry-doctor.ts +243 -0
- package/src/cli/usage-feedback.ts +418 -0
- package/src/cli/validate-hook-influence.ts +119 -0
- package/src/cli/validate-source-tree.ts +30 -0
- package/src/cli/validate-workflow-artifacts.ts +411 -0
- package/src/cli/veritas-governance.ts +322 -0
- package/src/cli/workflow-artifact-cleanup-audit.ts +281 -0
- package/src/cli/workflow-sidecar.ts +676 -0
- package/src/cli.ts +95 -0
- package/src/flow-kit/validate.ts +74 -0
- package/src/lib/args.ts +43 -0
- package/src/lib/fs.ts +62 -0
- package/src/lib/workflow-learning-projection.ts +491 -0
- package/src/runtime-adapters.ts +154 -0
- package/src/tools/build-universal-bundles.ts +366 -0
- package/src/tools/common.ts +61 -0
- package/src/tools/filter-installed-packs.ts +129 -0
- package/src/tools/generate-context-map.ts +199 -0
- package/src/tools/validate-package.ts +57 -0
- package/src/tools/validate-source-tree.ts +488 -0
- package/tsconfig.json +19 -0
- package/veritas.claims.json +6 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
mixed asset fixture
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
{
|
|
2
|
+
"id": "mixed.runtime",
|
|
3
|
+
"version": "1.0",
|
|
4
|
+
"steps": [
|
|
5
|
+
{ "id": "start", "next": "done" },
|
|
6
|
+
{ "id": "done", "next": null }
|
|
7
|
+
],
|
|
8
|
+
"gates": {
|
|
9
|
+
"runtime-gate": {
|
|
10
|
+
"step": "start",
|
|
11
|
+
"expects": [
|
|
12
|
+
{
|
|
13
|
+
"id": "runtime-evidence",
|
|
14
|
+
"kind": "surface.claim",
|
|
15
|
+
"required": true,
|
|
16
|
+
"description": "Runtime activation evidence exists.",
|
|
17
|
+
"claim": {
|
|
18
|
+
"type": "mixed.runtime.evidence",
|
|
19
|
+
"subject": "artifact",
|
|
20
|
+
"accepted_statuses": ["trusted", "accepted"]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
]
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
{
|
|
2
|
+
"schema_version": "1.0",
|
|
3
|
+
"id": "mixed-runtime-kit",
|
|
4
|
+
"name": "Mixed Runtime Kit",
|
|
5
|
+
"product_name": "Mixed Runtime Kit",
|
|
6
|
+
"description": "A fixture with one Flow Definition and unsupported runtime asset classes.",
|
|
7
|
+
"flows": [
|
|
8
|
+
{
|
|
9
|
+
"id": "mixed.runtime",
|
|
10
|
+
"path": "flows/runtime.flow.json",
|
|
11
|
+
"description": "Exercise Codex-local activation."
|
|
12
|
+
}
|
|
13
|
+
],
|
|
14
|
+
"skills": [
|
|
15
|
+
{
|
|
16
|
+
"id": "mixed.skill",
|
|
17
|
+
"path": "kit-skills/mixed/SKILL.md"
|
|
18
|
+
}
|
|
19
|
+
],
|
|
20
|
+
"docs": [
|
|
21
|
+
{
|
|
22
|
+
"id": "mixed.docs",
|
|
23
|
+
"path": "docs/README.md"
|
|
24
|
+
}
|
|
25
|
+
],
|
|
26
|
+
"adapters": [
|
|
27
|
+
{
|
|
28
|
+
"id": "mixed.adapter",
|
|
29
|
+
"path": "adapters/example.json"
|
|
30
|
+
}
|
|
31
|
+
],
|
|
32
|
+
"evals": [
|
|
33
|
+
{
|
|
34
|
+
"id": "mixed.eval",
|
|
35
|
+
"path": "kit-evals/example.json"
|
|
36
|
+
}
|
|
37
|
+
],
|
|
38
|
+
"assets": [
|
|
39
|
+
{
|
|
40
|
+
"id": "mixed.asset",
|
|
41
|
+
"path": "assets/example.txt"
|
|
42
|
+
}
|
|
43
|
+
]
|
|
44
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
{
|
|
2
|
+
"id": "example.review",
|
|
3
|
+
"version": "1.0",
|
|
4
|
+
"steps": [
|
|
5
|
+
{ "id": "review", "next": "done" },
|
|
6
|
+
{ "id": "done", "next": null }
|
|
7
|
+
],
|
|
8
|
+
"gates": {
|
|
9
|
+
"review-gate": {
|
|
10
|
+
"step": "review",
|
|
11
|
+
"expects": [
|
|
12
|
+
{
|
|
13
|
+
"id": "review-evidence",
|
|
14
|
+
"kind": "surface.claim",
|
|
15
|
+
"required": true,
|
|
16
|
+
"description": "Review evidence has been recorded.",
|
|
17
|
+
"claim": {
|
|
18
|
+
"type": "example.review.evidence",
|
|
19
|
+
"subject": "artifact",
|
|
20
|
+
"accepted_statuses": ["trusted", "accepted"]
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
]
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
{
|
|
2
|
+
"schema_version": "1.0",
|
|
3
|
+
"id": "example-kit",
|
|
4
|
+
"name": "Example Kit",
|
|
5
|
+
"product_name": "Example Kit",
|
|
6
|
+
"description": "A local external kit fixture for repository contract validation.",
|
|
7
|
+
"flows": [
|
|
8
|
+
{
|
|
9
|
+
"id": "example.review",
|
|
10
|
+
"path": "flows/review.flow.json",
|
|
11
|
+
"description": "Review a small change."
|
|
12
|
+
}
|
|
13
|
+
],
|
|
14
|
+
"docs": [
|
|
15
|
+
{
|
|
16
|
+
"id": "example.readme",
|
|
17
|
+
"path": "docs/README.md"
|
|
18
|
+
}
|
|
19
|
+
]
|
|
20
|
+
}
|
|
@@ -0,0 +1,336 @@
|
|
|
1
|
+
{
|
|
2
|
+
"schema_version": "1.0",
|
|
3
|
+
"description": "Behavioral expectations for proving hook guidance changes agent behavior, not only that hooks emit text.",
|
|
4
|
+
"cases": [
|
|
5
|
+
{
|
|
6
|
+
"id": "prompt-submit-unverified-state",
|
|
7
|
+
"runtime_scope": ["claude-code"],
|
|
8
|
+
"hook": "workflow-steering",
|
|
9
|
+
"event": "UserPromptSubmit",
|
|
10
|
+
"fixture_state": {
|
|
11
|
+
"task_slug": "live-hook",
|
|
12
|
+
"status": "not_verified",
|
|
13
|
+
"phase": "verification",
|
|
14
|
+
"next_action_status": "needs_user"
|
|
15
|
+
},
|
|
16
|
+
"guidance_must_include": [
|
|
17
|
+
"WORKFLOW STATE ATTENTION",
|
|
18
|
+
"STATE: live-hook is status:not_verified phase:verification",
|
|
19
|
+
"Do not deliver as complete"
|
|
20
|
+
],
|
|
21
|
+
"agent_must_do": [
|
|
22
|
+
"acknowledge the unresolved live-hook workflow",
|
|
23
|
+
"avoid claiming delivery is complete",
|
|
24
|
+
"route to verification or user decision before final delivery"
|
|
25
|
+
],
|
|
26
|
+
"evidence": {
|
|
27
|
+
"tier": "live-acceptance",
|
|
28
|
+
"command": "bash evals/acceptance/test_claude_harness.sh",
|
|
29
|
+
"status": "available-with-FLOW_AGENTS_ACCEPTANCE_CLAUDE_LLM=1"
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
"id": "kiro-live-strict-stop-incomplete-goal-fit",
|
|
34
|
+
"runtime_scope": ["kiro-cli"],
|
|
35
|
+
"hook": "stop-goal-fit",
|
|
36
|
+
"event": "Stop",
|
|
37
|
+
"fixture_state": {
|
|
38
|
+
"task_slug": "live-stop",
|
|
39
|
+
"artifact_status": "executing",
|
|
40
|
+
"missing": ["Definition Of Done", "Goal Fit Gate"]
|
|
41
|
+
},
|
|
42
|
+
"guidance_must_include": [
|
|
43
|
+
"Goal Fit warning",
|
|
44
|
+
"Definition Of Done",
|
|
45
|
+
"Goal Fit Gate"
|
|
46
|
+
],
|
|
47
|
+
"agent_must_do": [
|
|
48
|
+
"continue instead of producing a final delivery answer",
|
|
49
|
+
"fill missing goal-fit or evidence state",
|
|
50
|
+
"surface the exact blocker if the runtime blocks stop"
|
|
51
|
+
],
|
|
52
|
+
"evidence": {
|
|
53
|
+
"tier": "live-acceptance",
|
|
54
|
+
"command": "bash evals/acceptance/test_kiro_harness.sh",
|
|
55
|
+
"status": "available-when-kiro-cli-installed"
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
"id": "codex-claude-strict-stop-adapter-contract",
|
|
60
|
+
"runtime_scope": ["codex", "claude-code"],
|
|
61
|
+
"hook": "stop-goal-fit",
|
|
62
|
+
"event": "Stop",
|
|
63
|
+
"fixture_state": {
|
|
64
|
+
"task_slug": "feedback-loop",
|
|
65
|
+
"artifact_status": "executing",
|
|
66
|
+
"missing": ["Definition Of Done", "Goal Fit Gate"]
|
|
67
|
+
},
|
|
68
|
+
"guidance_must_include": [
|
|
69
|
+
"Goal Fit warning",
|
|
70
|
+
"Definition Of Done",
|
|
71
|
+
"Goal Fit Gate"
|
|
72
|
+
],
|
|
73
|
+
"agent_must_do": [
|
|
74
|
+
"treat strict Stop guidance as a blocker when the runtime exposes the adapter result",
|
|
75
|
+
"continue or report the exact stop gate instead of final delivery"
|
|
76
|
+
],
|
|
77
|
+
"evidence": {
|
|
78
|
+
"tier": "adapter",
|
|
79
|
+
"command": "bash evals/integration/test_goal_fit_hook.sh",
|
|
80
|
+
"status": "always-run-in-integration"
|
|
81
|
+
}
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
"id": "installed-command-protocol-guidance",
|
|
85
|
+
"runtime_scope": ["codex", "claude-code", "kiro-cli"],
|
|
86
|
+
"hook": "workflow-steering",
|
|
87
|
+
"event": "UserPromptSubmit",
|
|
88
|
+
"fixture_state": {
|
|
89
|
+
"task_slug": "steering-demo",
|
|
90
|
+
"status": "not_verified",
|
|
91
|
+
"phase": "verification",
|
|
92
|
+
"critique_status": "fail"
|
|
93
|
+
},
|
|
94
|
+
"guidance_must_include": [
|
|
95
|
+
"STATE: steering-demo is status:not_verified phase:verification",
|
|
96
|
+
"CRITIQUE: required critique is status:fail",
|
|
97
|
+
"CONTEXT MAP: use docs/context-map.md before broad repo rediscovery"
|
|
98
|
+
],
|
|
99
|
+
"agent_must_do": [
|
|
100
|
+
"treat hook guidance as additional context when the runtime exposes it",
|
|
101
|
+
"avoid final delivery while critique or evidence is unresolved",
|
|
102
|
+
"use context-map recovery guidance before broad rediscovery"
|
|
103
|
+
],
|
|
104
|
+
"evidence": {
|
|
105
|
+
"tier": "installed-command",
|
|
106
|
+
"command": "bash evals/integration/test_bundle_install.sh",
|
|
107
|
+
"status": "always-run-in-integration"
|
|
108
|
+
}
|
|
109
|
+
},
|
|
110
|
+
{
|
|
111
|
+
"id": "dev-builder-review-before-verify-after-execute",
|
|
112
|
+
"description": "After execute-plan completes in the Builder Kit build flow, the next gate is review-work critique before verify-work evidence. Review is report-only and cannot be treated as verification evidence. Open critique findings route back through execution before re-review and re-verify.",
|
|
113
|
+
"runtime_scope": ["claude-code", "codex", "kiro-cli"],
|
|
114
|
+
"hook": "workflow-steering",
|
|
115
|
+
"event": "PostToolUse",
|
|
116
|
+
"fixture_state": {
|
|
117
|
+
"task_slug": "dev-review-before-verify-demo",
|
|
118
|
+
"status": "in_progress",
|
|
119
|
+
"current_step": "execute",
|
|
120
|
+
"completed_step": "execute-plan",
|
|
121
|
+
"next_step": "review-work",
|
|
122
|
+
"flow_ref": "kits/builder/flows/build.flow.json",
|
|
123
|
+
"critique_status": "pending",
|
|
124
|
+
"evidence_status": "pending"
|
|
125
|
+
},
|
|
126
|
+
"guidance_must_include": [
|
|
127
|
+
"EXECUTION COMPLETE",
|
|
128
|
+
"Next: review",
|
|
129
|
+
"then verify",
|
|
130
|
+
"report only"
|
|
131
|
+
],
|
|
132
|
+
"agent_must_do": [
|
|
133
|
+
"delegate to review-work for report-only critique before verify-work",
|
|
134
|
+
"not count critique.json as verification evidence or evidence.json as critique",
|
|
135
|
+
"route open critique findings back through execute-plan, then re-review and re-verify"
|
|
136
|
+
],
|
|
137
|
+
"evidence": {
|
|
138
|
+
"tier": "adapter",
|
|
139
|
+
"command": "bash evals/integration/test_workflow_steering_hook.sh",
|
|
140
|
+
"status": "always-run-in-integration"
|
|
141
|
+
}
|
|
142
|
+
},
|
|
143
|
+
{
|
|
144
|
+
"id": "codex-live-context-gap",
|
|
145
|
+
"runtime_scope": ["codex"],
|
|
146
|
+
"hook": "workflow-steering",
|
|
147
|
+
"event": "UserPromptSubmit",
|
|
148
|
+
"fixture_state": {
|
|
149
|
+
"task_slug": "codex-hook-gap",
|
|
150
|
+
"status": "not_verified",
|
|
151
|
+
"phase": "verification"
|
|
152
|
+
},
|
|
153
|
+
"guidance_must_include": [
|
|
154
|
+
"STATE:",
|
|
155
|
+
"not_verified"
|
|
156
|
+
],
|
|
157
|
+
"agent_must_do": [
|
|
158
|
+
"record NOT_VERIFIED for live influence until codex exec exposes project hook guidance as model context",
|
|
159
|
+
"continue using adapter and installed-command evidence for protocol coverage"
|
|
160
|
+
],
|
|
161
|
+
"evidence": {
|
|
162
|
+
"tier": "documented-runtime-gap",
|
|
163
|
+
"command": "bash evals/acceptance/test_codex_harness.sh",
|
|
164
|
+
"status": "acceptance-covers-routing-not-live-hook-influence"
|
|
165
|
+
}
|
|
166
|
+
},
|
|
167
|
+
{
|
|
168
|
+
"id": "dev-shape-gate-blocks-early-implementation",
|
|
169
|
+
"description": "When a user sends 'let's build X' and the shape step gate is incomplete, the hook must steer the agent to explore the repo and collect shape evidence instead of implementing. Agent must ask one question at a time with a recommended answer. See Builder Kit shape flow step:shape.",
|
|
170
|
+
"runtime_scope": ["claude-code", "codex", "kiro-cli"],
|
|
171
|
+
"hook": "workflow-steering",
|
|
172
|
+
"event": "UserPromptSubmit",
|
|
173
|
+
"fixture_state": {
|
|
174
|
+
"task_slug": "dev-shape-demo",
|
|
175
|
+
"status": "in_progress",
|
|
176
|
+
"current_step": "shape",
|
|
177
|
+
"gate_evidence": {},
|
|
178
|
+
"missing_evidence": ["problem_statement", "desired_outcome", "constraints", "non_goals", "success_signal", "risk_level", "open_decisions"]
|
|
179
|
+
},
|
|
180
|
+
"user_message": "let's build the front-door routing",
|
|
181
|
+
"guidance_must_include": [
|
|
182
|
+
"WORKFLOW STEP: shape",
|
|
183
|
+
"problem_statement",
|
|
184
|
+
"do not implement"
|
|
185
|
+
],
|
|
186
|
+
"agent_must_do": [
|
|
187
|
+
"explore the repo (AGENTS.md, docs/) before asking the first question",
|
|
188
|
+
"ask for problem_statement before doing any implementation",
|
|
189
|
+
"ask one question at a time — not all shape fields at once",
|
|
190
|
+
"include a recommended answer with each question",
|
|
191
|
+
"not start implementing routing logic before shape gate is complete"
|
|
192
|
+
],
|
|
193
|
+
"evidence": {
|
|
194
|
+
"tier": "design-target",
|
|
195
|
+
"command": "bash evals/acceptance/test_claude_harness.sh",
|
|
196
|
+
"status": "requires-flow-step-aware-hook-implementation",
|
|
197
|
+
"flow_ref": "kits/builder/flows/shape.flow.json step:shape"
|
|
198
|
+
}
|
|
199
|
+
},
|
|
200
|
+
{
|
|
201
|
+
"id": "dev-pull-work-checks-backlog-before-asking",
|
|
202
|
+
"description": "At the pull-work step, the agent must check the backlog (gh issue list --label ready) before asking the user which item to take. WIP conflicts must also be checked before confirming. See Builder Kit build flow step:pull-work.",
|
|
203
|
+
"runtime_scope": ["claude-code", "codex", "kiro-cli"],
|
|
204
|
+
"hook": "workflow-steering",
|
|
205
|
+
"event": "UserPromptSubmit",
|
|
206
|
+
"fixture_state": {
|
|
207
|
+
"task_slug": "dev-pull-demo",
|
|
208
|
+
"status": "in_progress",
|
|
209
|
+
"current_step": "pull-work",
|
|
210
|
+
"gate_evidence": {},
|
|
211
|
+
"missing_evidence": ["selected_item", "wip_clear", "worktree_decision"]
|
|
212
|
+
},
|
|
213
|
+
"user_message": "let's work on issue 51",
|
|
214
|
+
"guidance_must_include": [
|
|
215
|
+
"WORKFLOW STEP: pull-work",
|
|
216
|
+
"selected_item",
|
|
217
|
+
"wip_clear"
|
|
218
|
+
],
|
|
219
|
+
"agent_must_do": [
|
|
220
|
+
"run `gh issue list --label ready` before asking user which issue to take",
|
|
221
|
+
"check git status and open PRs for WIP conflicts before confirming",
|
|
222
|
+
"record worktree_decision with justification based on risk level"
|
|
223
|
+
],
|
|
224
|
+
"evidence": {
|
|
225
|
+
"tier": "design-target",
|
|
226
|
+
"command": "bash evals/acceptance/test_claude_harness.sh",
|
|
227
|
+
"status": "requires-flow-step-aware-hook-implementation",
|
|
228
|
+
"flow_ref": "kits/builder/flows/build.flow.json step:pull-work"
|
|
229
|
+
}
|
|
230
|
+
},
|
|
231
|
+
{
|
|
232
|
+
"id": "dev-builder-build-requires-pickup-probe-before-plan",
|
|
233
|
+
"description": "When Builder Kit build flow reaches planning without recorded pickup Probe decisions or accepted gaps, the hook must steer back to design-probe instead of allowing plan-work to proceed. Direct pull-work and plan-work remain valid when the user invokes those primitives outside Builder Kit build flow.",
|
|
234
|
+
"runtime_scope": ["claude-code", "codex", "kiro-cli"],
|
|
235
|
+
"hook": "workflow-steering",
|
|
236
|
+
"event": "UserPromptSubmit",
|
|
237
|
+
"fixture_state": {
|
|
238
|
+
"task_slug": "dev-builder-pickup-probe-demo",
|
|
239
|
+
"status": "needs_decision",
|
|
240
|
+
"current_step": "plan",
|
|
241
|
+
"flow_ref": "kits/builder/flows/build.flow.json",
|
|
242
|
+
"route_reason": "decision_gap",
|
|
243
|
+
"gate_evidence": {
|
|
244
|
+
"selected-work": "trusted"
|
|
245
|
+
},
|
|
246
|
+
"missing_evidence": [
|
|
247
|
+
"pickup_probe_readiness",
|
|
248
|
+
"probe_decisions_or_accepted_gaps",
|
|
249
|
+
"provider_state",
|
|
250
|
+
"conflict_risks"
|
|
251
|
+
]
|
|
252
|
+
},
|
|
253
|
+
"user_message": "Use Builder Kit build flow and start plan-work now.",
|
|
254
|
+
"guidance_must_include": [
|
|
255
|
+
"WORKFLOW STEP: design-probe",
|
|
256
|
+
"decision_gap",
|
|
257
|
+
"accepted gaps",
|
|
258
|
+
"provider_state",
|
|
259
|
+
"conflict_risks"
|
|
260
|
+
],
|
|
261
|
+
"agent_must_do": [
|
|
262
|
+
"route decision_gap back to design-probe/pickup Probe before retrying plan-work",
|
|
263
|
+
"record Probe decisions or explicitly accepted gaps in the pull-work or plan handoff artifact",
|
|
264
|
+
"ask one alignment question at a time only if repo/provider context leaves a genuine decision gap",
|
|
265
|
+
"preserve direct pull-work and direct plan-work primitive usage outside the Builder Kit build flow"
|
|
266
|
+
],
|
|
267
|
+
"evidence": {
|
|
268
|
+
"tier": "design-target",
|
|
269
|
+
"command": "bash evals/acceptance/test_claude_harness.sh",
|
|
270
|
+
"status": "requires-flow-step-aware-hook-implementation",
|
|
271
|
+
"flow_ref": "kits/builder/flows/build.flow.json step:design-probe"
|
|
272
|
+
}
|
|
273
|
+
},
|
|
274
|
+
{
|
|
275
|
+
"id": "dev-verify-fail-preserves-trace-before-rework",
|
|
276
|
+
"description": "When verify produces a FAIL verdict, the agent must record the FAIL script evidence artifact before routing back. The failure trace must not be discarded. Code-fix failures route to plan; fundamental/design failures route to design-probe and require a user decision. See Builder Kit build flow step:verify.",
|
|
277
|
+
"runtime_scope": ["claude-code", "codex", "kiro-cli"],
|
|
278
|
+
"hook": "workflow-steering",
|
|
279
|
+
"event": "UserPromptSubmit",
|
|
280
|
+
"fixture_state": {
|
|
281
|
+
"task_slug": "dev-verify-fail-demo",
|
|
282
|
+
"status": "in_progress",
|
|
283
|
+
"current_step": "verify",
|
|
284
|
+
"gate_evidence": {},
|
|
285
|
+
"missing_evidence": ["script_runs", "verdict"]
|
|
286
|
+
},
|
|
287
|
+
"guidance_must_include": [
|
|
288
|
+
"WORKFLOW STEP: verify",
|
|
289
|
+
"script_runs",
|
|
290
|
+
"If verdict=FAIL: record the FAIL artifact"
|
|
291
|
+
],
|
|
292
|
+
"agent_must_do": [
|
|
293
|
+
"run deterministic scripts and record command, exit_code, output_summary, artifact_path, verdict for each",
|
|
294
|
+
"when verdict=FAIL: write the FAIL artifact before routing back — do not discard it",
|
|
295
|
+
"route to plan (code fix, no user decision) or design-probe (fundamental gap, user decision required)"
|
|
296
|
+
],
|
|
297
|
+
"evidence": {
|
|
298
|
+
"tier": "design-target",
|
|
299
|
+
"command": "bash evals/acceptance/test_claude_harness.sh",
|
|
300
|
+
"status": "requires-flow-step-aware-hook-implementation",
|
|
301
|
+
"flow_ref": "kits/builder/flows/build.flow.json step:verify"
|
|
302
|
+
}
|
|
303
|
+
},
|
|
304
|
+
{
|
|
305
|
+
"id": "dev-merge-ready-runs-twice-local-then-ci",
|
|
306
|
+
"description": "merge-ready runs twice: once locally before opening the PR (lint, tests, diff review), and once after CI completes (ci_run, pr_approved, rollback_plan). Each has its own gate evidence. See Builder Kit build flow steps:merge-ready and merge-ready-ci.",
|
|
307
|
+
"runtime_scope": ["claude-code", "codex", "kiro-cli"],
|
|
308
|
+
"hook": "workflow-steering",
|
|
309
|
+
"event": "UserPromptSubmit",
|
|
310
|
+
"fixture_state": {
|
|
311
|
+
"task_slug": "dev-merge-ready-demo",
|
|
312
|
+
"status": "in_progress",
|
|
313
|
+
"current_step": "merge-ready",
|
|
314
|
+
"gate_evidence": {},
|
|
315
|
+
"missing_evidence": ["lint_check", "test_check", "diff_review", "verdict"]
|
|
316
|
+
},
|
|
317
|
+
"guidance_must_include": [
|
|
318
|
+
"WORKFLOW STEP: merge-ready",
|
|
319
|
+
"lint_check",
|
|
320
|
+
"diff_review"
|
|
321
|
+
],
|
|
322
|
+
"agent_must_do": [
|
|
323
|
+
"run lint and test checks as ScriptEvidence before opening PR",
|
|
324
|
+
"review the diff and confirm scope matches plan before recording verdict",
|
|
325
|
+
"not open the PR until local merge-ready verdict is READY",
|
|
326
|
+
"run merge-ready-ci as a separate step after CI completes — not skip it"
|
|
327
|
+
],
|
|
328
|
+
"evidence": {
|
|
329
|
+
"tier": "design-target",
|
|
330
|
+
"command": "bash evals/acceptance/test_claude_harness.sh",
|
|
331
|
+
"status": "requires-flow-step-aware-hook-implementation",
|
|
332
|
+
"flow_ref": "kits/builder/flows/build.flow.json step:merge-ready"
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
]
|
|
336
|
+
}
|