@harness-engineering/cli 1.14.0 → 1.16.0
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/dist/agents/commands/codex/AGENTS.md +39 -0
- package/dist/agents/commands/codex/harness/add-harness-component/SKILL.md +195 -0
- package/dist/agents/commands/codex/harness/add-harness-component/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/cleanup-dead-code/SKILL.md +248 -0
- package/dist/agents/commands/codex/harness/cleanup-dead-code/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/detect-doc-drift/SKILL.md +182 -0
- package/dist/agents/commands/codex/harness/detect-doc-drift/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/enforce-architecture/SKILL.md +299 -0
- package/dist/agents/commands/codex/harness/enforce-architecture/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-architecture-advisor/SKILL.md +452 -0
- package/dist/agents/commands/codex/harness/harness-architecture-advisor/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-autopilot/SKILL.md +919 -0
- package/dist/agents/commands/codex/harness/harness-autopilot/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-brainstorming/SKILL.md +409 -0
- package/dist/agents/commands/codex/harness/harness-brainstorming/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-code-review/SKILL.md +860 -0
- package/dist/agents/commands/codex/harness/harness-code-review/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-codebase-cleanup/SKILL.md +227 -0
- package/dist/agents/commands/codex/harness/harness-codebase-cleanup/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-debugging/SKILL.md +369 -0
- package/dist/agents/commands/codex/harness/harness-debugging/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-dependency-health/SKILL.md +182 -0
- package/dist/agents/commands/codex/harness/harness-dependency-health/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-docs-pipeline/SKILL.md +463 -0
- package/dist/agents/commands/codex/harness/harness-docs-pipeline/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-execution/SKILL.md +513 -0
- package/dist/agents/commands/codex/harness/harness-execution/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-hotspot-detector/SKILL.md +164 -0
- package/dist/agents/commands/codex/harness/harness-hotspot-detector/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-impact-analysis/SKILL.md +187 -0
- package/dist/agents/commands/codex/harness/harness-impact-analysis/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-integrity/SKILL.md +170 -0
- package/dist/agents/commands/codex/harness/harness-integrity/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-onboarding/SKILL.md +291 -0
- package/dist/agents/commands/codex/harness/harness-onboarding/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-perf/SKILL.md +263 -0
- package/dist/agents/commands/codex/harness/harness-perf/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-planning/SKILL.md +582 -0
- package/dist/agents/commands/codex/harness/harness-planning/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-refactoring/SKILL.md +172 -0
- package/dist/agents/commands/codex/harness/harness-refactoring/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-release-readiness/SKILL.md +692 -0
- package/dist/agents/commands/codex/harness/harness-release-readiness/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-roadmap/SKILL.md +598 -0
- package/dist/agents/commands/codex/harness/harness-roadmap/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-security-scan/SKILL.md +157 -0
- package/dist/agents/commands/codex/harness/harness-security-scan/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-skill-authoring/SKILL.md +295 -0
- package/dist/agents/commands/codex/harness/harness-skill-authoring/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-soundness-review/SKILL.md +1270 -0
- package/dist/agents/commands/codex/harness/harness-soundness-review/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-supply-chain-audit/SKILL.md +247 -0
- package/dist/agents/commands/codex/harness/harness-supply-chain-audit/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-tdd/SKILL.md +180 -0
- package/dist/agents/commands/codex/harness/harness-tdd/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-test-advisor/SKILL.md +163 -0
- package/dist/agents/commands/codex/harness/harness-test-advisor/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-verification/SKILL.md +424 -0
- package/dist/agents/commands/codex/harness/harness-verification/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/harness-verify/SKILL.md +162 -0
- package/dist/agents/commands/codex/harness/harness-verify/agents/openai.yaml +3 -0
- package/dist/agents/commands/codex/harness/initialize-harness-project/SKILL.md +235 -0
- package/dist/agents/commands/codex/harness/initialize-harness-project/agents/openai.yaml +3 -0
- package/dist/agents/commands/cursor/harness/add-harness-component.mdc +200 -0
- package/dist/agents/commands/cursor/harness/cleanup-dead-code.mdc +253 -0
- package/dist/agents/commands/cursor/harness/detect-doc-drift.mdc +187 -0
- package/dist/agents/commands/cursor/harness/enforce-architecture.mdc +304 -0
- package/dist/agents/commands/cursor/harness/harness-architecture-advisor.mdc +457 -0
- package/dist/agents/commands/cursor/harness/harness-autopilot.mdc +924 -0
- package/dist/agents/commands/cursor/harness/harness-brainstorming.mdc +414 -0
- package/dist/agents/commands/cursor/harness/harness-code-review.mdc +865 -0
- package/dist/agents/commands/cursor/harness/harness-codebase-cleanup.mdc +232 -0
- package/dist/agents/commands/cursor/harness/harness-debugging.mdc +374 -0
- package/dist/agents/commands/cursor/harness/harness-dependency-health.mdc +187 -0
- package/dist/agents/commands/cursor/harness/harness-docs-pipeline.mdc +468 -0
- package/dist/agents/commands/cursor/harness/harness-execution.mdc +518 -0
- package/dist/agents/commands/cursor/harness/harness-hotspot-detector.mdc +169 -0
- package/dist/agents/commands/cursor/harness/harness-impact-analysis.mdc +192 -0
- package/dist/agents/commands/cursor/harness/harness-integrity.mdc +175 -0
- package/dist/agents/commands/cursor/harness/harness-onboarding.mdc +296 -0
- package/dist/agents/commands/cursor/harness/harness-perf.mdc +268 -0
- package/dist/agents/commands/cursor/harness/harness-planning.mdc +587 -0
- package/dist/agents/commands/cursor/harness/harness-refactoring.mdc +177 -0
- package/dist/agents/commands/cursor/harness/harness-release-readiness.mdc +697 -0
- package/dist/agents/commands/cursor/harness/harness-roadmap.mdc +603 -0
- package/dist/agents/commands/cursor/harness/harness-security-scan.mdc +162 -0
- package/dist/agents/commands/cursor/harness/harness-skill-authoring.mdc +300 -0
- package/dist/agents/commands/cursor/harness/harness-soundness-review.mdc +1275 -0
- package/dist/agents/commands/cursor/harness/harness-supply-chain-audit.mdc +252 -0
- package/dist/agents/commands/cursor/harness/harness-tdd.mdc +185 -0
- package/dist/agents/commands/cursor/harness/harness-test-advisor.mdc +168 -0
- package/dist/agents/commands/cursor/harness/harness-verification.mdc +429 -0
- package/dist/agents/commands/cursor/harness/harness-verify.mdc +167 -0
- package/dist/agents/commands/cursor/harness/initialize-harness-project.mdc +240 -0
- package/dist/agents/skills/claude-code/enforce-architecture/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-api-design/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-architecture-advisor/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-auth/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-autopilot/SKILL.md +355 -45
- package/dist/agents/skills/claude-code/harness-autopilot/skill.yaml +12 -0
- package/dist/agents/skills/claude-code/harness-code-review/SKILL.md +97 -3
- package/dist/agents/skills/claude-code/harness-code-review/skill.yaml +6 -0
- package/dist/agents/skills/claude-code/harness-codebase-cleanup/SKILL.md +2 -4
- package/dist/agents/skills/claude-code/harness-database/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-deployment/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-planning/SKILL.md +99 -3
- package/dist/agents/skills/claude-code/harness-planning/skill.yaml +6 -0
- package/dist/agents/skills/claude-code/harness-pre-commit-review/SKILL.md +1 -1
- package/dist/agents/skills/claude-code/harness-product-spec/SKILL.md +5 -5
- package/dist/agents/skills/claude-code/harness-security-review/SKILL.md +27 -7
- package/dist/agents/skills/claude-code/harness-security-scan/SKILL.md +52 -0
- package/dist/agents/skills/claude-code/harness-supply-chain-audit/SKILL.md +281 -0
- package/dist/agents/skills/claude-code/harness-supply-chain-audit/skill.yaml +51 -0
- package/dist/agents/skills/codex/add-harness-component/SKILL.md +192 -0
- package/dist/agents/skills/codex/add-harness-component/skill.yaml +33 -0
- package/dist/agents/skills/codex/align-documentation/SKILL.md +213 -0
- package/dist/agents/skills/codex/align-documentation/skill.yaml +32 -0
- package/dist/agents/skills/codex/check-mechanical-constraints/SKILL.md +191 -0
- package/dist/agents/skills/codex/check-mechanical-constraints/skill.yaml +33 -0
- package/dist/agents/skills/codex/cleanup-dead-code/SKILL.md +245 -0
- package/dist/agents/skills/codex/cleanup-dead-code/skill.yaml +34 -0
- package/dist/agents/skills/codex/detect-doc-drift/SKILL.md +179 -0
- package/dist/agents/skills/codex/detect-doc-drift/skill.yaml +31 -0
- package/dist/agents/skills/codex/enforce-architecture/SKILL.md +296 -0
- package/dist/agents/skills/codex/enforce-architecture/skill.yaml +35 -0
- package/dist/agents/skills/codex/harness-accessibility/SKILL.md +281 -0
- package/dist/agents/skills/codex/harness-accessibility/skill.yaml +52 -0
- package/dist/agents/skills/codex/harness-api-design/SKILL.md +356 -0
- package/dist/agents/skills/codex/harness-api-design/skill.yaml +74 -0
- package/dist/agents/skills/codex/harness-architecture-advisor/SKILL.md +449 -0
- package/dist/agents/skills/codex/harness-architecture-advisor/skill.yaml +49 -0
- package/dist/agents/skills/codex/harness-auth/SKILL.md +331 -0
- package/dist/agents/skills/codex/harness-auth/skill.yaml +81 -0
- package/dist/agents/skills/codex/harness-autopilot/SKILL.md +916 -0
- package/dist/agents/skills/codex/harness-autopilot/skill.yaml +67 -0
- package/dist/agents/skills/codex/harness-brainstorming/SKILL.md +406 -0
- package/dist/agents/skills/codex/harness-brainstorming/skill.yaml +50 -0
- package/dist/agents/skills/codex/harness-caching/SKILL.md +309 -0
- package/dist/agents/skills/codex/harness-caching/skill.yaml +73 -0
- package/dist/agents/skills/codex/harness-chaos/SKILL.md +295 -0
- package/dist/agents/skills/codex/harness-chaos/skill.yaml +72 -0
- package/dist/agents/skills/codex/harness-code-review/SKILL.md +857 -0
- package/dist/agents/skills/codex/harness-code-review/skill.yaml +52 -0
- package/dist/agents/skills/codex/harness-codebase-cleanup/SKILL.md +224 -0
- package/dist/agents/skills/codex/harness-codebase-cleanup/skill.yaml +65 -0
- package/dist/agents/skills/codex/harness-compliance/SKILL.md +303 -0
- package/dist/agents/skills/codex/harness-compliance/skill.yaml +78 -0
- package/dist/agents/skills/codex/harness-containerization/SKILL.md +284 -0
- package/dist/agents/skills/codex/harness-containerization/skill.yaml +80 -0
- package/dist/agents/skills/codex/harness-data-pipeline/SKILL.md +274 -0
- package/dist/agents/skills/codex/harness-data-pipeline/skill.yaml +81 -0
- package/dist/agents/skills/codex/harness-data-validation/SKILL.md +343 -0
- package/dist/agents/skills/codex/harness-data-validation/skill.yaml +75 -0
- package/dist/agents/skills/codex/harness-database/SKILL.md +310 -0
- package/dist/agents/skills/codex/harness-database/skill.yaml +80 -0
- package/dist/agents/skills/codex/harness-debugging/SKILL.md +366 -0
- package/dist/agents/skills/codex/harness-debugging/skill.yaml +48 -0
- package/dist/agents/skills/codex/harness-dependency-health/SKILL.md +179 -0
- package/dist/agents/skills/codex/harness-dependency-health/skill.yaml +42 -0
- package/dist/agents/skills/codex/harness-deployment/SKILL.md +307 -0
- package/dist/agents/skills/codex/harness-deployment/skill.yaml +77 -0
- package/dist/agents/skills/codex/harness-design/SKILL.md +265 -0
- package/dist/agents/skills/codex/harness-design/skill.yaml +54 -0
- package/dist/agents/skills/codex/harness-design-mobile/SKILL.md +336 -0
- package/dist/agents/skills/codex/harness-design-mobile/skill.yaml +50 -0
- package/dist/agents/skills/codex/harness-design-system/SKILL.md +282 -0
- package/dist/agents/skills/codex/harness-design-system/skill.yaml +51 -0
- package/dist/agents/skills/codex/harness-design-web/SKILL.md +360 -0
- package/dist/agents/skills/codex/harness-design-web/skill.yaml +53 -0
- package/dist/agents/skills/codex/harness-diagnostics/SKILL.md +318 -0
- package/dist/agents/skills/codex/harness-diagnostics/skill.yaml +51 -0
- package/dist/agents/skills/codex/harness-docs-pipeline/SKILL.md +460 -0
- package/dist/agents/skills/codex/harness-docs-pipeline/skill.yaml +70 -0
- package/dist/agents/skills/codex/harness-dx/SKILL.md +276 -0
- package/dist/agents/skills/codex/harness-dx/skill.yaml +76 -0
- package/dist/agents/skills/codex/harness-e2e/SKILL.md +245 -0
- package/dist/agents/skills/codex/harness-e2e/skill.yaml +78 -0
- package/dist/agents/skills/codex/harness-event-driven/SKILL.md +280 -0
- package/dist/agents/skills/codex/harness-event-driven/skill.yaml +77 -0
- package/dist/agents/skills/codex/harness-execution/SKILL.md +510 -0
- package/dist/agents/skills/codex/harness-execution/skill.yaml +52 -0
- package/dist/agents/skills/codex/harness-feature-flags/SKILL.md +287 -0
- package/dist/agents/skills/codex/harness-feature-flags/skill.yaml +74 -0
- package/dist/agents/skills/codex/harness-git-workflow/SKILL.md +268 -0
- package/dist/agents/skills/codex/harness-git-workflow/skill.yaml +32 -0
- package/dist/agents/skills/codex/harness-hotspot-detector/SKILL.md +161 -0
- package/dist/agents/skills/codex/harness-hotspot-detector/skill.yaml +45 -0
- package/dist/agents/skills/codex/harness-i18n/SKILL.md +484 -0
- package/dist/agents/skills/codex/harness-i18n/skill.yaml +55 -0
- package/dist/agents/skills/codex/harness-i18n-process/SKILL.md +388 -0
- package/dist/agents/skills/codex/harness-i18n-process/skill.yaml +44 -0
- package/dist/agents/skills/codex/harness-i18n-workflow/SKILL.md +512 -0
- package/dist/agents/skills/codex/harness-i18n-workflow/skill.yaml +54 -0
- package/dist/agents/skills/codex/harness-impact-analysis/SKILL.md +184 -0
- package/dist/agents/skills/codex/harness-impact-analysis/skill.yaml +45 -0
- package/dist/agents/skills/codex/harness-incident-response/SKILL.md +223 -0
- package/dist/agents/skills/codex/harness-incident-response/skill.yaml +78 -0
- package/dist/agents/skills/codex/harness-infrastructure-as-code/SKILL.md +279 -0
- package/dist/agents/skills/codex/harness-infrastructure-as-code/skill.yaml +80 -0
- package/dist/agents/skills/codex/harness-integration-test/SKILL.md +271 -0
- package/dist/agents/skills/codex/harness-integration-test/skill.yaml +73 -0
- package/dist/agents/skills/codex/harness-integrity/SKILL.md +167 -0
- package/dist/agents/skills/codex/harness-integrity/skill.yaml +48 -0
- package/dist/agents/skills/codex/harness-knowledge-mapper/SKILL.md +195 -0
- package/dist/agents/skills/codex/harness-knowledge-mapper/skill.yaml +50 -0
- package/dist/agents/skills/codex/harness-load-testing/SKILL.md +274 -0
- package/dist/agents/skills/codex/harness-load-testing/skill.yaml +79 -0
- package/dist/agents/skills/codex/harness-ml-ops/SKILL.md +341 -0
- package/dist/agents/skills/codex/harness-ml-ops/skill.yaml +79 -0
- package/dist/agents/skills/codex/harness-mobile-patterns/SKILL.md +326 -0
- package/dist/agents/skills/codex/harness-mobile-patterns/skill.yaml +82 -0
- package/dist/agents/skills/codex/harness-mutation-test/SKILL.md +251 -0
- package/dist/agents/skills/codex/harness-mutation-test/skill.yaml +70 -0
- package/dist/agents/skills/codex/harness-observability/SKILL.md +283 -0
- package/dist/agents/skills/codex/harness-observability/skill.yaml +78 -0
- package/dist/agents/skills/codex/harness-onboarding/SKILL.md +288 -0
- package/dist/agents/skills/codex/harness-onboarding/skill.yaml +31 -0
- package/dist/agents/skills/codex/harness-parallel-agents/SKILL.md +256 -0
- package/dist/agents/skills/codex/harness-parallel-agents/skill.yaml +34 -0
- package/dist/agents/skills/codex/harness-perf/SKILL.md +260 -0
- package/dist/agents/skills/codex/harness-perf/skill.yaml +51 -0
- package/dist/agents/skills/codex/harness-perf-tdd/SKILL.md +249 -0
- package/dist/agents/skills/codex/harness-perf-tdd/skill.yaml +48 -0
- package/dist/agents/skills/codex/harness-planning/SKILL.md +579 -0
- package/dist/agents/skills/codex/harness-planning/skill.yaml +56 -0
- package/dist/agents/skills/codex/harness-pre-commit-review/SKILL.md +324 -0
- package/dist/agents/skills/codex/harness-pre-commit-review/skill.yaml +34 -0
- package/dist/agents/skills/codex/harness-product-spec/SKILL.md +285 -0
- package/dist/agents/skills/codex/harness-product-spec/skill.yaml +72 -0
- package/dist/agents/skills/codex/harness-property-test/SKILL.md +281 -0
- package/dist/agents/skills/codex/harness-property-test/skill.yaml +71 -0
- package/dist/agents/skills/codex/harness-refactoring/SKILL.md +169 -0
- package/dist/agents/skills/codex/harness-refactoring/skill.yaml +34 -0
- package/dist/agents/skills/codex/harness-release-readiness/SKILL.md +689 -0
- package/dist/agents/skills/codex/harness-release-readiness/skill.yaml +58 -0
- package/dist/agents/skills/codex/harness-resilience/SKILL.md +255 -0
- package/dist/agents/skills/codex/harness-resilience/skill.yaml +76 -0
- package/dist/agents/skills/codex/harness-roadmap/SKILL.md +595 -0
- package/dist/agents/skills/codex/harness-roadmap/skill.yaml +44 -0
- package/dist/agents/skills/codex/harness-secrets/SKILL.md +293 -0
- package/dist/agents/skills/codex/harness-secrets/skill.yaml +76 -0
- package/dist/agents/skills/codex/harness-security-review/SKILL.md +260 -0
- package/dist/agents/skills/codex/harness-security-review/skill.yaml +53 -0
- package/dist/agents/skills/codex/harness-security-scan/SKILL.md +154 -0
- package/dist/agents/skills/codex/harness-security-scan/skill.yaml +42 -0
- package/dist/agents/skills/codex/harness-skill-authoring/SKILL.md +292 -0
- package/dist/agents/skills/codex/harness-skill-authoring/skill.yaml +33 -0
- package/dist/agents/skills/codex/harness-soundness-review/SKILL.md +1267 -0
- package/dist/agents/skills/codex/harness-soundness-review/skill.yaml +49 -0
- package/dist/agents/skills/codex/harness-sql-review/SKILL.md +315 -0
- package/dist/agents/skills/codex/harness-sql-review/skill.yaml +74 -0
- package/dist/agents/skills/codex/harness-state-management/SKILL.md +309 -0
- package/dist/agents/skills/codex/harness-state-management/skill.yaml +33 -0
- package/dist/agents/skills/codex/harness-supply-chain-audit/SKILL.md +281 -0
- package/dist/agents/skills/codex/harness-supply-chain-audit/skill.yaml +51 -0
- package/dist/agents/skills/codex/harness-tdd/SKILL.md +177 -0
- package/dist/agents/skills/codex/harness-tdd/skill.yaml +49 -0
- package/dist/agents/skills/codex/harness-test-advisor/SKILL.md +160 -0
- package/dist/agents/skills/codex/harness-test-advisor/skill.yaml +45 -0
- package/dist/agents/skills/codex/harness-test-data/SKILL.md +268 -0
- package/dist/agents/skills/codex/harness-test-data/skill.yaml +74 -0
- package/dist/agents/skills/codex/harness-ux-copy/SKILL.md +271 -0
- package/dist/agents/skills/codex/harness-ux-copy/skill.yaml +77 -0
- package/dist/agents/skills/codex/harness-verification/SKILL.md +421 -0
- package/dist/agents/skills/codex/harness-verification/skill.yaml +43 -0
- package/dist/agents/skills/codex/harness-verify/SKILL.md +159 -0
- package/dist/agents/skills/codex/harness-verify/skill.yaml +41 -0
- package/dist/agents/skills/codex/harness-visual-regression/SKILL.md +257 -0
- package/dist/agents/skills/codex/harness-visual-regression/skill.yaml +74 -0
- package/dist/agents/skills/codex/initialize-harness-project/SKILL.md +232 -0
- package/dist/agents/skills/codex/initialize-harness-project/skill.yaml +32 -0
- package/dist/agents/skills/codex/validate-context-engineering/SKILL.md +150 -0
- package/dist/agents/skills/codex/validate-context-engineering/skill.yaml +32 -0
- package/dist/agents/skills/cursor/add-harness-component/SKILL.md +192 -0
- package/dist/agents/skills/cursor/add-harness-component/skill.yaml +33 -0
- package/dist/agents/skills/cursor/align-documentation/SKILL.md +213 -0
- package/dist/agents/skills/cursor/align-documentation/skill.yaml +32 -0
- package/dist/agents/skills/cursor/check-mechanical-constraints/SKILL.md +191 -0
- package/dist/agents/skills/cursor/check-mechanical-constraints/skill.yaml +33 -0
- package/dist/agents/skills/cursor/cleanup-dead-code/SKILL.md +245 -0
- package/dist/agents/skills/cursor/cleanup-dead-code/skill.yaml +34 -0
- package/dist/agents/skills/cursor/detect-doc-drift/SKILL.md +179 -0
- package/dist/agents/skills/cursor/detect-doc-drift/skill.yaml +31 -0
- package/dist/agents/skills/cursor/enforce-architecture/SKILL.md +296 -0
- package/dist/agents/skills/cursor/enforce-architecture/skill.yaml +35 -0
- package/dist/agents/skills/cursor/harness-accessibility/SKILL.md +281 -0
- package/dist/agents/skills/cursor/harness-accessibility/skill.yaml +52 -0
- package/dist/agents/skills/cursor/harness-api-design/SKILL.md +356 -0
- package/dist/agents/skills/cursor/harness-api-design/skill.yaml +74 -0
- package/dist/agents/skills/cursor/harness-architecture-advisor/SKILL.md +449 -0
- package/dist/agents/skills/cursor/harness-architecture-advisor/skill.yaml +49 -0
- package/dist/agents/skills/cursor/harness-auth/SKILL.md +331 -0
- package/dist/agents/skills/cursor/harness-auth/skill.yaml +81 -0
- package/dist/agents/skills/cursor/harness-autopilot/SKILL.md +916 -0
- package/dist/agents/skills/cursor/harness-autopilot/skill.yaml +67 -0
- package/dist/agents/skills/cursor/harness-brainstorming/SKILL.md +406 -0
- package/dist/agents/skills/cursor/harness-brainstorming/skill.yaml +50 -0
- package/dist/agents/skills/cursor/harness-caching/SKILL.md +309 -0
- package/dist/agents/skills/cursor/harness-caching/skill.yaml +73 -0
- package/dist/agents/skills/cursor/harness-chaos/SKILL.md +295 -0
- package/dist/agents/skills/cursor/harness-chaos/skill.yaml +72 -0
- package/dist/agents/skills/cursor/harness-code-review/SKILL.md +857 -0
- package/dist/agents/skills/cursor/harness-code-review/skill.yaml +52 -0
- package/dist/agents/skills/cursor/harness-codebase-cleanup/SKILL.md +224 -0
- package/dist/agents/skills/cursor/harness-codebase-cleanup/skill.yaml +65 -0
- package/dist/agents/skills/cursor/harness-compliance/SKILL.md +303 -0
- package/dist/agents/skills/cursor/harness-compliance/skill.yaml +78 -0
- package/dist/agents/skills/cursor/harness-containerization/SKILL.md +284 -0
- package/dist/agents/skills/cursor/harness-containerization/skill.yaml +80 -0
- package/dist/agents/skills/cursor/harness-data-pipeline/SKILL.md +274 -0
- package/dist/agents/skills/cursor/harness-data-pipeline/skill.yaml +81 -0
- package/dist/agents/skills/cursor/harness-data-validation/SKILL.md +343 -0
- package/dist/agents/skills/cursor/harness-data-validation/skill.yaml +75 -0
- package/dist/agents/skills/cursor/harness-database/SKILL.md +310 -0
- package/dist/agents/skills/cursor/harness-database/skill.yaml +80 -0
- package/dist/agents/skills/cursor/harness-debugging/SKILL.md +366 -0
- package/dist/agents/skills/cursor/harness-debugging/skill.yaml +48 -0
- package/dist/agents/skills/cursor/harness-dependency-health/SKILL.md +179 -0
- package/dist/agents/skills/cursor/harness-dependency-health/skill.yaml +42 -0
- package/dist/agents/skills/cursor/harness-deployment/SKILL.md +307 -0
- package/dist/agents/skills/cursor/harness-deployment/skill.yaml +77 -0
- package/dist/agents/skills/cursor/harness-design/SKILL.md +265 -0
- package/dist/agents/skills/cursor/harness-design/skill.yaml +54 -0
- package/dist/agents/skills/cursor/harness-design-mobile/SKILL.md +336 -0
- package/dist/agents/skills/cursor/harness-design-mobile/skill.yaml +50 -0
- package/dist/agents/skills/cursor/harness-design-system/SKILL.md +282 -0
- package/dist/agents/skills/cursor/harness-design-system/skill.yaml +51 -0
- package/dist/agents/skills/cursor/harness-design-web/SKILL.md +360 -0
- package/dist/agents/skills/cursor/harness-design-web/skill.yaml +53 -0
- package/dist/agents/skills/cursor/harness-diagnostics/SKILL.md +318 -0
- package/dist/agents/skills/cursor/harness-diagnostics/skill.yaml +51 -0
- package/dist/agents/skills/cursor/harness-docs-pipeline/SKILL.md +460 -0
- package/dist/agents/skills/cursor/harness-docs-pipeline/skill.yaml +70 -0
- package/dist/agents/skills/cursor/harness-dx/SKILL.md +276 -0
- package/dist/agents/skills/cursor/harness-dx/skill.yaml +76 -0
- package/dist/agents/skills/cursor/harness-e2e/SKILL.md +245 -0
- package/dist/agents/skills/cursor/harness-e2e/skill.yaml +78 -0
- package/dist/agents/skills/cursor/harness-event-driven/SKILL.md +280 -0
- package/dist/agents/skills/cursor/harness-event-driven/skill.yaml +77 -0
- package/dist/agents/skills/cursor/harness-execution/SKILL.md +510 -0
- package/dist/agents/skills/cursor/harness-execution/skill.yaml +52 -0
- package/dist/agents/skills/cursor/harness-feature-flags/SKILL.md +287 -0
- package/dist/agents/skills/cursor/harness-feature-flags/skill.yaml +74 -0
- package/dist/agents/skills/cursor/harness-git-workflow/SKILL.md +268 -0
- package/dist/agents/skills/cursor/harness-git-workflow/skill.yaml +32 -0
- package/dist/agents/skills/cursor/harness-hotspot-detector/SKILL.md +161 -0
- package/dist/agents/skills/cursor/harness-hotspot-detector/skill.yaml +45 -0
- package/dist/agents/skills/cursor/harness-i18n/SKILL.md +484 -0
- package/dist/agents/skills/cursor/harness-i18n/skill.yaml +55 -0
- package/dist/agents/skills/cursor/harness-i18n-process/SKILL.md +388 -0
- package/dist/agents/skills/cursor/harness-i18n-process/skill.yaml +44 -0
- package/dist/agents/skills/cursor/harness-i18n-workflow/SKILL.md +512 -0
- package/dist/agents/skills/cursor/harness-i18n-workflow/skill.yaml +54 -0
- package/dist/agents/skills/cursor/harness-impact-analysis/SKILL.md +184 -0
- package/dist/agents/skills/cursor/harness-impact-analysis/skill.yaml +45 -0
- package/dist/agents/skills/cursor/harness-incident-response/SKILL.md +223 -0
- package/dist/agents/skills/cursor/harness-incident-response/skill.yaml +78 -0
- package/dist/agents/skills/cursor/harness-infrastructure-as-code/SKILL.md +279 -0
- package/dist/agents/skills/cursor/harness-infrastructure-as-code/skill.yaml +80 -0
- package/dist/agents/skills/cursor/harness-integration-test/SKILL.md +271 -0
- package/dist/agents/skills/cursor/harness-integration-test/skill.yaml +73 -0
- package/dist/agents/skills/cursor/harness-integrity/SKILL.md +167 -0
- package/dist/agents/skills/cursor/harness-integrity/skill.yaml +48 -0
- package/dist/agents/skills/cursor/harness-knowledge-mapper/SKILL.md +195 -0
- package/dist/agents/skills/cursor/harness-knowledge-mapper/skill.yaml +50 -0
- package/dist/agents/skills/cursor/harness-load-testing/SKILL.md +274 -0
- package/dist/agents/skills/cursor/harness-load-testing/skill.yaml +79 -0
- package/dist/agents/skills/cursor/harness-ml-ops/SKILL.md +341 -0
- package/dist/agents/skills/cursor/harness-ml-ops/skill.yaml +79 -0
- package/dist/agents/skills/cursor/harness-mobile-patterns/SKILL.md +326 -0
- package/dist/agents/skills/cursor/harness-mobile-patterns/skill.yaml +82 -0
- package/dist/agents/skills/cursor/harness-mutation-test/SKILL.md +251 -0
- package/dist/agents/skills/cursor/harness-mutation-test/skill.yaml +70 -0
- package/dist/agents/skills/cursor/harness-observability/SKILL.md +283 -0
- package/dist/agents/skills/cursor/harness-observability/skill.yaml +78 -0
- package/dist/agents/skills/cursor/harness-onboarding/SKILL.md +288 -0
- package/dist/agents/skills/cursor/harness-onboarding/skill.yaml +31 -0
- package/dist/agents/skills/cursor/harness-parallel-agents/SKILL.md +256 -0
- package/dist/agents/skills/cursor/harness-parallel-agents/skill.yaml +34 -0
- package/dist/agents/skills/cursor/harness-perf/SKILL.md +260 -0
- package/dist/agents/skills/cursor/harness-perf/skill.yaml +51 -0
- package/dist/agents/skills/cursor/harness-perf-tdd/SKILL.md +249 -0
- package/dist/agents/skills/cursor/harness-perf-tdd/skill.yaml +48 -0
- package/dist/agents/skills/cursor/harness-planning/SKILL.md +579 -0
- package/dist/agents/skills/cursor/harness-planning/skill.yaml +56 -0
- package/dist/agents/skills/cursor/harness-pre-commit-review/SKILL.md +324 -0
- package/dist/agents/skills/cursor/harness-pre-commit-review/skill.yaml +34 -0
- package/dist/agents/skills/cursor/harness-product-spec/SKILL.md +285 -0
- package/dist/agents/skills/cursor/harness-product-spec/skill.yaml +72 -0
- package/dist/agents/skills/cursor/harness-property-test/SKILL.md +281 -0
- package/dist/agents/skills/cursor/harness-property-test/skill.yaml +71 -0
- package/dist/agents/skills/cursor/harness-refactoring/SKILL.md +169 -0
- package/dist/agents/skills/cursor/harness-refactoring/skill.yaml +34 -0
- package/dist/agents/skills/cursor/harness-release-readiness/SKILL.md +689 -0
- package/dist/agents/skills/cursor/harness-release-readiness/skill.yaml +58 -0
- package/dist/agents/skills/cursor/harness-resilience/SKILL.md +255 -0
- package/dist/agents/skills/cursor/harness-resilience/skill.yaml +76 -0
- package/dist/agents/skills/cursor/harness-roadmap/SKILL.md +595 -0
- package/dist/agents/skills/cursor/harness-roadmap/skill.yaml +44 -0
- package/dist/agents/skills/cursor/harness-secrets/SKILL.md +293 -0
- package/dist/agents/skills/cursor/harness-secrets/skill.yaml +76 -0
- package/dist/agents/skills/cursor/harness-security-review/SKILL.md +260 -0
- package/dist/agents/skills/cursor/harness-security-review/skill.yaml +53 -0
- package/dist/agents/skills/cursor/harness-security-scan/SKILL.md +154 -0
- package/dist/agents/skills/cursor/harness-security-scan/skill.yaml +42 -0
- package/dist/agents/skills/cursor/harness-skill-authoring/SKILL.md +292 -0
- package/dist/agents/skills/cursor/harness-skill-authoring/skill.yaml +33 -0
- package/dist/agents/skills/cursor/harness-soundness-review/SKILL.md +1267 -0
- package/dist/agents/skills/cursor/harness-soundness-review/skill.yaml +49 -0
- package/dist/agents/skills/cursor/harness-sql-review/SKILL.md +315 -0
- package/dist/agents/skills/cursor/harness-sql-review/skill.yaml +74 -0
- package/dist/agents/skills/cursor/harness-state-management/SKILL.md +309 -0
- package/dist/agents/skills/cursor/harness-state-management/skill.yaml +33 -0
- package/dist/agents/skills/cursor/harness-supply-chain-audit/SKILL.md +281 -0
- package/dist/agents/skills/cursor/harness-supply-chain-audit/skill.yaml +51 -0
- package/dist/agents/skills/cursor/harness-tdd/SKILL.md +177 -0
- package/dist/agents/skills/cursor/harness-tdd/skill.yaml +49 -0
- package/dist/agents/skills/cursor/harness-test-advisor/SKILL.md +160 -0
- package/dist/agents/skills/cursor/harness-test-advisor/skill.yaml +45 -0
- package/dist/agents/skills/cursor/harness-test-data/SKILL.md +268 -0
- package/dist/agents/skills/cursor/harness-test-data/skill.yaml +74 -0
- package/dist/agents/skills/cursor/harness-ux-copy/SKILL.md +271 -0
- package/dist/agents/skills/cursor/harness-ux-copy/skill.yaml +77 -0
- package/dist/agents/skills/cursor/harness-verification/SKILL.md +421 -0
- package/dist/agents/skills/cursor/harness-verification/skill.yaml +43 -0
- package/dist/agents/skills/cursor/harness-verify/SKILL.md +159 -0
- package/dist/agents/skills/cursor/harness-verify/skill.yaml +41 -0
- package/dist/agents/skills/cursor/harness-visual-regression/SKILL.md +257 -0
- package/dist/agents/skills/cursor/harness-visual-regression/skill.yaml +74 -0
- package/dist/agents/skills/cursor/initialize-harness-project/SKILL.md +232 -0
- package/dist/agents/skills/cursor/initialize-harness-project/skill.yaml +32 -0
- package/dist/agents/skills/cursor/validate-context-engineering/SKILL.md +150 -0
- package/dist/agents/skills/cursor/validate-context-engineering/skill.yaml +32 -0
- package/dist/agents/skills/gemini-cli/enforce-architecture/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-api-design/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-architecture-advisor/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-auth/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-autopilot/SKILL.md +355 -45
- package/dist/agents/skills/gemini-cli/harness-autopilot/skill.yaml +12 -0
- package/dist/agents/skills/gemini-cli/harness-code-review/SKILL.md +97 -3
- package/dist/agents/skills/gemini-cli/harness-code-review/skill.yaml +6 -0
- package/dist/agents/skills/gemini-cli/harness-codebase-cleanup/SKILL.md +2 -4
- package/dist/agents/skills/gemini-cli/harness-database/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-deployment/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-planning/SKILL.md +99 -3
- package/dist/agents/skills/gemini-cli/harness-planning/skill.yaml +6 -0
- package/dist/agents/skills/gemini-cli/harness-pre-commit-review/SKILL.md +1 -1
- package/dist/agents/skills/gemini-cli/harness-product-spec/SKILL.md +5 -5
- package/dist/agents/skills/gemini-cli/harness-security-review/SKILL.md +27 -7
- package/dist/agents/skills/gemini-cli/harness-security-scan/SKILL.md +52 -0
- package/dist/agents/skills/gemini-cli/harness-supply-chain-audit/SKILL.md +281 -0
- package/dist/agents/skills/gemini-cli/harness-supply-chain-audit/skill.yaml +51 -0
- package/dist/agents/skills/package.json +1 -0
- package/dist/agents/skills/templates/discipline-template.md +49 -0
- package/dist/agents/skills/tests/schema.ts +1 -1
- package/dist/agents/skills/vitest.config.mts +5 -0
- package/dist/{agents-md-YTYQDA3P.js → agents-md-VYDFPIRW.js} +1 -1
- package/dist/{architecture-JQZYM4US.js → architecture-K5HSRBGB.js} +2 -2
- package/dist/bin/harness-mcp.js +13 -13
- package/dist/bin/harness.js +21 -19
- package/dist/{check-phase-gate-L3RADYWO.js → check-phase-gate-5AS6SXL6.js} +3 -3
- package/dist/{chunk-6KTUUFRN.js → chunk-5ZXHMCPL.js} +1 -1
- package/dist/{chunk-RCWZBSK5.js → chunk-6KWBH4EO.js} +1 -1
- package/dist/{chunk-ABQHQ6I5.js → chunk-ALFKNAZW.js} +2436 -233
- package/dist/{chunk-OXLLOSSR.js → chunk-AV6KMDO5.js} +2 -2
- package/dist/{chunk-7IP4JIFL.js → chunk-C7DTKLPW.js} +4 -4
- package/dist/{chunk-ZOAWBDWU.js → chunk-CJDVBBPB.js} +5 -1
- package/dist/{chunk-YPYGXRDR.js → chunk-DNDBFIZN.js} +18 -4
- package/dist/{chunk-XYLGHKG6.js → chunk-HKUX2X7O.js} +11 -2
- package/dist/{chunk-YZD2MRNQ.js → chunk-JOP2NDNB.js} +684 -142
- package/dist/{chunk-YBJ262QL.js → chunk-LRG3B43J.js} +1 -1
- package/dist/{chunk-AOZRDOIP.js → chunk-M6TIO6NF.js} +1 -1
- package/dist/{chunk-O5OJVPL6.js → chunk-OCDDCGDE.js} +9 -1
- package/dist/{chunk-OSXBPAMK.js → chunk-QDF7COPQ.js} +1 -1
- package/dist/{chunk-TPOTOBR7.js → chunk-RWZPHW4H.js} +3 -3
- package/dist/{chunk-3C2MLBPJ.js → chunk-SFRGPAK6.js} +1 -1
- package/dist/{chunk-XKECDXJS.js → chunk-SHYWICGA.js} +2184 -456
- package/dist/{chunk-S2FXOWOR.js → chunk-TF6ZLHJV.js} +2 -2
- package/dist/{chunk-NLVUVUGD.js → chunk-ZJMU7MEV.js} +1 -1
- package/dist/{ci-workflow-EQZFVX3P.js → ci-workflow-CRWU723U.js} +1 -1
- package/dist/{create-skill-XSWHMSM5.js → create-skill-NDXQSTIK.js} +2 -2
- package/dist/{dist-HWXF2C3R.js → dist-4LPXJYVZ.js} +105 -1
- package/dist/{docs-7ECGYMAV.js → docs-4JRHTLUZ.js} +3 -3
- package/dist/{engine-EG4EH4IX.js → engine-3G3VIM6L.js} +1 -1
- package/dist/{entropy-5USWKLVS.js → entropy-G6CZ2A6P.js} +2 -2
- package/dist/{feedback-UTBXZZHF.js → feedback-QYKQ65HB.js} +1 -1
- package/dist/{generate-agent-definitions-3PM5EU7V.js → generate-agent-definitions-SAAOAPT4.js} +3 -3
- package/dist/index.d.ts +25 -4
- package/dist/index.js +18 -18
- package/dist/{loader-ZPALXIVR.js → loader-VCOK3PF7.js} +1 -1
- package/dist/{mcp-362EZHF4.js → mcp-YENEPHBW.js} +13 -13
- package/dist/{performance-OQAFMJUD.js → performance-UBCFI2UP.js} +4 -2
- package/dist/{review-pipeline-C4GCFVGP.js → review-pipeline-IQAVCWAX.js} +1 -1
- package/dist/{runtime-7YLVK453.js → runtime-PYFFIESU.js} +1 -1
- package/dist/{security-PZOX7AQS.js → security-ZDADTPYW.js} +1 -1
- package/dist/{skill-executor-XZLYZYAK.js → skill-executor-XEVDGXUM.js} +2 -2
- package/dist/{validate-FD3Z6VJD.js → validate-VRTUHALQ.js} +2 -2
- package/dist/{validate-cross-check-WNJM6H2D.js → validate-cross-check-4Y6NHNK3.js} +1 -1
- package/package.json +8 -5
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
# Harness Impact Analysis
|
|
2
|
+
|
|
3
|
+
> Graph-based impact analysis. Answers: "if I change X, what breaks?"
|
|
4
|
+
|
|
5
|
+
## When to Use
|
|
6
|
+
|
|
7
|
+
- Before merging a PR — understand the blast radius of changes
|
|
8
|
+
- When planning a refactoring — know what will be affected
|
|
9
|
+
- When a test fails — trace backwards to find what change caused it
|
|
10
|
+
- When `on_pr` triggers fire
|
|
11
|
+
- NOT for understanding code (use harness-onboarding or harness-code-review)
|
|
12
|
+
- NOT for finding dead code (use cleanup-dead-code)
|
|
13
|
+
|
|
14
|
+
## Prerequisites
|
|
15
|
+
|
|
16
|
+
A knowledge graph at `.harness/graph/` enables full analysis. If no graph exists,
|
|
17
|
+
the skill uses static analysis fallbacks (see Graph Availability section).
|
|
18
|
+
Run `harness scan` to enable graph-enhanced analysis.
|
|
19
|
+
|
|
20
|
+
### Graph Availability
|
|
21
|
+
|
|
22
|
+
Before starting, check if `.harness/graph/graph.json` exists.
|
|
23
|
+
|
|
24
|
+
**If graph exists:** Check staleness — compare `.harness/graph/metadata.json`
|
|
25
|
+
scanTimestamp against `git log -1 --format=%ct` (latest commit timestamp).
|
|
26
|
+
If graph is more than 2 commits behind (`git log --oneline <scanTimestamp>..HEAD | wc -l`),
|
|
27
|
+
run `harness scan` to refresh before proceeding. (Staleness sensitivity: **High**)
|
|
28
|
+
|
|
29
|
+
**If graph exists and is fresh (or refreshed):** Use graph tools as primary strategy.
|
|
30
|
+
|
|
31
|
+
**If no graph exists:** Output "Running without graph (run `harness scan` to
|
|
32
|
+
enable full analysis)" and use fallback strategies for all subsequent steps.
|
|
33
|
+
|
|
34
|
+
## Process
|
|
35
|
+
|
|
36
|
+
### Phase 1: IDENTIFY — Determine Changed Files
|
|
37
|
+
|
|
38
|
+
1. **From diff**: If a git diff is available, parse it to extract changed file paths.
|
|
39
|
+
2. **From input**: If file paths are provided directly, use those.
|
|
40
|
+
3. **From git**: If neither, use `git diff --name-only HEAD~1` to get recent changes.
|
|
41
|
+
|
|
42
|
+
### Phase 2: ANALYZE — Query Graph for Impact
|
|
43
|
+
|
|
44
|
+
For each changed file:
|
|
45
|
+
|
|
46
|
+
1. **Direct dependents**: Use `get_impact` MCP tool to find all files that import or call the changed file.
|
|
47
|
+
|
|
48
|
+
```
|
|
49
|
+
get_impact(filePath="src/services/auth.ts")
|
|
50
|
+
→ tests: [auth.test.ts, integration.test.ts]
|
|
51
|
+
→ docs: [auth-guide.md]
|
|
52
|
+
→ code: [routes/login.ts, middleware/verify.ts, ...]
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
2. **Transitive dependents**: Use `query_graph` with depth 3 to find indirect consumers.
|
|
56
|
+
|
|
57
|
+
```
|
|
58
|
+
query_graph(rootNodeIds=["file:src/services/auth.ts"], maxDepth=3, includeEdges=["imports", "calls"])
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
3. **Documentation impact**: Use `get_relationships` to find `documents` edges pointing to changed nodes.
|
|
62
|
+
|
|
63
|
+
4. **Test coverage**: Identify test files connected via `imports` edges. Flag changed files with no test coverage.
|
|
64
|
+
|
|
65
|
+
5. **Design token impact**: When the graph contains `DesignToken` nodes, use `query_graph` with `USES_TOKEN` edges to find components that consume changed tokens.
|
|
66
|
+
|
|
67
|
+
```
|
|
68
|
+
query_graph(rootNodeIds=["designtoken:color.primary"], maxDepth=2, includeEdges=["uses_token"])
|
|
69
|
+
→ components: [Button.tsx, Card.tsx, Header.tsx, ...]
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
If a changed file is `design-system/tokens.json`, identify ALL tokens that changed and trace each to its consuming components. This reveals the full design blast radius of a token change.
|
|
73
|
+
|
|
74
|
+
6. **Design constraint impact**: When the graph contains `DesignConstraint` nodes, check if changed code introduces new `VIOLATES_DESIGN` edges.
|
|
75
|
+
|
|
76
|
+
#### Fallback (without graph)
|
|
77
|
+
|
|
78
|
+
When no graph is available, use static analysis to approximate impact:
|
|
79
|
+
|
|
80
|
+
1. **Parse imports**: For each changed file, grep all source files for `import.*from.*<changed-file>` and `require.*<changed-file>` patterns to find direct dependents.
|
|
81
|
+
2. **Follow imports 2 levels deep**: For each direct dependent found, repeat the import grep to find second-level dependents. Stop at 2 levels (fallback cannot reliably trace deeper).
|
|
82
|
+
3. **Find test files by naming convention**: For each changed file `foo.ts`, search for:
|
|
83
|
+
- `foo.test.ts`, `foo.spec.ts` (same directory and `__tests__/` directory)
|
|
84
|
+
- `*.test.*` and `*.spec.*` files that import the changed file (from step 1)
|
|
85
|
+
4. **Find docs by path matching**: Grep `docs/` directory for references to the changed module name (filename without extension).
|
|
86
|
+
5. **Group results** the same as the graph version: tests, docs, code, other. Note the count of files found.
|
|
87
|
+
|
|
88
|
+
> Fallback completeness: ~70% — misses transitive deps beyond 2 levels.
|
|
89
|
+
|
|
90
|
+
### Phase 3: ASSESS — Risk Assessment and Report
|
|
91
|
+
|
|
92
|
+
1. **Impact score**: Calculate based on:
|
|
93
|
+
- Number of direct dependents (weight: 3x)
|
|
94
|
+
- Number of transitive dependents (weight: 1x)
|
|
95
|
+
- Whether affected code includes entry points (weight: 5x)
|
|
96
|
+
- Whether tests exist for the changed code (no tests = higher risk)
|
|
97
|
+
- Whether design tokens are affected (weight: 2x — token changes cascade to all consumers)
|
|
98
|
+
|
|
99
|
+
2. **Risk tiers**:
|
|
100
|
+
- **Critical** (score > 50): Changes affect entry points or >20 downstream files
|
|
101
|
+
- **High** (score 20-50): Changes affect multiple modules or shared utilities
|
|
102
|
+
- **Medium** (score 5-20): Changes affect a few files within the same module
|
|
103
|
+
- **Low** (score < 5): Changes are isolated with minimal downstream impact
|
|
104
|
+
|
|
105
|
+
3. **Output report**:
|
|
106
|
+
|
|
107
|
+
```
|
|
108
|
+
## Impact Analysis Report
|
|
109
|
+
|
|
110
|
+
### Changed Files
|
|
111
|
+
- src/services/auth.ts (modified)
|
|
112
|
+
- src/types/user.ts (modified)
|
|
113
|
+
|
|
114
|
+
### Impact Summary
|
|
115
|
+
- Direct dependents: 8 files
|
|
116
|
+
- Transitive dependents: 23 files
|
|
117
|
+
- Affected tests: 5 files
|
|
118
|
+
- Affected docs: 2 files
|
|
119
|
+
- Risk tier: HIGH
|
|
120
|
+
|
|
121
|
+
### Affected Tests (must run)
|
|
122
|
+
1. tests/services/auth.test.ts (direct)
|
|
123
|
+
2. tests/routes/login.test.ts (transitive)
|
|
124
|
+
3. tests/integration/auth-flow.test.ts (transitive)
|
|
125
|
+
|
|
126
|
+
### Affected Documentation (may need update)
|
|
127
|
+
1. docs/auth-guide.md → documents src/services/auth.ts
|
|
128
|
+
2. docs/api-reference.md → documents src/types/user.ts
|
|
129
|
+
|
|
130
|
+
### Downstream Consumers
|
|
131
|
+
1. src/routes/login.ts — imports auth.ts
|
|
132
|
+
2. src/middleware/verify.ts — imports auth.ts
|
|
133
|
+
3. src/routes/signup.ts — imports user.ts (transitive via auth.ts)
|
|
134
|
+
|
|
135
|
+
### Affected Design Tokens (when tokens change)
|
|
136
|
+
1. color.primary → used by 12 components
|
|
137
|
+
2. typography.body → used by 8 components
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
## Harness Integration
|
|
141
|
+
|
|
142
|
+
- **`harness scan`** — Recommended before this skill for full graph-enhanced analysis. If graph is missing, skill uses static analysis fallbacks.
|
|
143
|
+
- **`harness validate`** — Run after acting on findings to verify project health.
|
|
144
|
+
- **Graph tools** — This skill uses `query_graph`, `get_impact`, and `get_relationships` MCP tools.
|
|
145
|
+
|
|
146
|
+
## Success Criteria
|
|
147
|
+
|
|
148
|
+
- Impact report generated with a risk tier (Critical / High / Medium / Low)
|
|
149
|
+
- All affected test files listed with direct vs transitive classification
|
|
150
|
+
- All affected documentation files listed with relationship context
|
|
151
|
+
- Report follows the structured output format
|
|
152
|
+
- All findings are backed by graph query evidence (with graph) or systematic static analysis (without graph)
|
|
153
|
+
|
|
154
|
+
## Examples
|
|
155
|
+
|
|
156
|
+
### Example: Analyzing a Change to auth.ts
|
|
157
|
+
|
|
158
|
+
```
|
|
159
|
+
Input: git diff shows src/services/auth.ts modified
|
|
160
|
+
|
|
161
|
+
1. IDENTIFY — Extract changed file: src/services/auth.ts
|
|
162
|
+
2. ANALYZE — get_impact(filePath="src/services/auth.ts")
|
|
163
|
+
query_graph(rootNodeIds=["file:src/services/auth.ts"], maxDepth=3)
|
|
164
|
+
Results: 8 direct dependents, 23 transitive, 5 tests, 2 docs
|
|
165
|
+
3. ASSESS — Impact score: 34 (High tier)
|
|
166
|
+
- Entry points affected: no
|
|
167
|
+
- Tests exist: yes (5 files)
|
|
168
|
+
|
|
169
|
+
Output:
|
|
170
|
+
Risk tier: HIGH
|
|
171
|
+
Must-run tests: auth.test.ts, login.test.ts, auth-flow.test.ts
|
|
172
|
+
Docs to update: auth-guide.md, api-reference.md
|
|
173
|
+
Downstream consumers: 8 files across 3 modules
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
## Gates
|
|
177
|
+
|
|
178
|
+
- **Graph preferred, fallback available.** If no graph exists, use fallback strategies (import parsing, naming conventions, path matching). Do not stop — produce the best analysis possible with available tools.
|
|
179
|
+
- **No risk assessment without data.** Use graph queries when available; use import parsing and naming conventions when not. If neither approach yields data, state what is missing.
|
|
180
|
+
|
|
181
|
+
## Escalation
|
|
182
|
+
|
|
183
|
+
- **When graph is stale**: If the graph's last scan timestamp is older than the most recent commit, warn that results may be incomplete and suggest re-scanning.
|
|
184
|
+
- **When impact is critical**: If risk tier is Critical, recommend a thorough code review and full test suite run before merging.
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
name: harness-impact-analysis
|
|
2
|
+
version: "1.0.0"
|
|
3
|
+
description: Graph-based impact analysis — answers "if I change X, what breaks?"
|
|
4
|
+
cognitive_mode: analytical-reporter
|
|
5
|
+
triggers:
|
|
6
|
+
- manual
|
|
7
|
+
- on_pr
|
|
8
|
+
platforms:
|
|
9
|
+
- claude-code
|
|
10
|
+
- gemini-cli
|
|
11
|
+
tools:
|
|
12
|
+
- Bash
|
|
13
|
+
- Read
|
|
14
|
+
- Glob
|
|
15
|
+
- Grep
|
|
16
|
+
cli:
|
|
17
|
+
command: harness skill run harness-impact-analysis
|
|
18
|
+
args:
|
|
19
|
+
- name: path
|
|
20
|
+
description: Project root path
|
|
21
|
+
required: false
|
|
22
|
+
- name: files
|
|
23
|
+
description: Comma-separated list of changed files
|
|
24
|
+
required: false
|
|
25
|
+
mcp:
|
|
26
|
+
tool: run_skill
|
|
27
|
+
input:
|
|
28
|
+
skill: harness-impact-analysis
|
|
29
|
+
path: string
|
|
30
|
+
type: rigid
|
|
31
|
+
tier: 2
|
|
32
|
+
phases:
|
|
33
|
+
- name: identify
|
|
34
|
+
description: Identify changed files from diff or input
|
|
35
|
+
required: true
|
|
36
|
+
- name: analyze
|
|
37
|
+
description: Query graph for impact of each changed file
|
|
38
|
+
required: true
|
|
39
|
+
- name: assess
|
|
40
|
+
description: Rank findings by risk and generate report
|
|
41
|
+
required: true
|
|
42
|
+
state:
|
|
43
|
+
persistent: false
|
|
44
|
+
files: []
|
|
45
|
+
depends_on: []
|
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
# Harness Incident Response
|
|
2
|
+
|
|
3
|
+
> Runbook generation, postmortem analysis, and SLO/SLA tracking. Diagnoses incidents by tracing symptoms through services, produces structured postmortems, and maintains error budget accounting.
|
|
4
|
+
|
|
5
|
+
## When to Use
|
|
6
|
+
|
|
7
|
+
- After a production incident to generate a structured postmortem with timeline and action items
|
|
8
|
+
- To create or audit runbooks for critical services and failure scenarios
|
|
9
|
+
- To define, track, or adjust SLOs/SLAs and monitor error budget consumption
|
|
10
|
+
- NOT for real-time incident coordination (use PagerDuty, OpsGenie, or incident.io for live response)
|
|
11
|
+
- NOT for infrastructure provisioning or remediation (use harness-infrastructure-as-code)
|
|
12
|
+
- NOT for performance benchmarking (use harness-load-testing for capacity planning)
|
|
13
|
+
|
|
14
|
+
## Process
|
|
15
|
+
|
|
16
|
+
### Phase 1: ASSESS -- Determine Scope and Severity
|
|
17
|
+
|
|
18
|
+
1. **Identify the incident signal.** Scan available evidence to determine what triggered the investigation:
|
|
19
|
+
- Check for existing incident reports in `docs/incidents/` or `docs/postmortems/`
|
|
20
|
+
- Look for recent error spikes in log files, monitoring configs, or alerting rules
|
|
21
|
+
- Review recent deployments via `git log --oneline --since="48 hours ago"` for correlated changes
|
|
22
|
+
|
|
23
|
+
2. **Map affected services.** Trace the blast radius from the incident signal:
|
|
24
|
+
- Identify the originating service from error messages or alert metadata
|
|
25
|
+
- Walk dependency chains using import graphs or service manifests (`docker-compose.yml`, `kubernetes/`, service mesh configs)
|
|
26
|
+
- List all downstream services that depend on the affected component
|
|
27
|
+
|
|
28
|
+
3. **Classify severity.** Apply the project's severity matrix if one exists in `docs/runbooks/severity-matrix.md`. Otherwise, use standard classification:
|
|
29
|
+
- **SEV1:** Complete service outage, data loss, or security breach affecting all users
|
|
30
|
+
- **SEV2:** Major feature degradation affecting a significant subset of users
|
|
31
|
+
- **SEV3:** Minor feature degradation with workaround available
|
|
32
|
+
- **SEV4:** Cosmetic issue or internal tooling degradation
|
|
33
|
+
|
|
34
|
+
4. **Establish timeline boundaries.** Determine:
|
|
35
|
+
- When the incident started (first error, first alert, or first user report)
|
|
36
|
+
- When it was detected (MTTD -- Mean Time to Detect)
|
|
37
|
+
- When mitigation began
|
|
38
|
+
- When the incident was resolved (MTTR -- Mean Time to Recover)
|
|
39
|
+
|
|
40
|
+
5. **Check for existing runbooks.** Search `docs/runbooks/` and `runbooks/` for procedures matching the affected service or failure mode. If a runbook exists, evaluate whether it was followed and whether it was effective.
|
|
41
|
+
|
|
42
|
+
---
|
|
43
|
+
|
|
44
|
+
### Phase 2: INVESTIGATE -- Trace Root Cause
|
|
45
|
+
|
|
46
|
+
1. **Correlate with recent changes.** Run `git log --oneline --since="7 days ago"` and cross-reference commits with the incident timeline. Flag commits that touched affected services or their dependencies.
|
|
47
|
+
|
|
48
|
+
2. **Analyze error patterns.** Search the codebase for error handling related to the failure:
|
|
49
|
+
- Grep for error messages, exception types, or error codes mentioned in the incident
|
|
50
|
+
- Check retry logic, timeout configurations, and circuit breaker states
|
|
51
|
+
- Identify whether the failure was transient (timeout, network) or persistent (logic error, data corruption)
|
|
52
|
+
|
|
53
|
+
3. **Trace data flow.** Map the request path from entry point to failure point:
|
|
54
|
+
- Identify API endpoints, message queues, or cron jobs involved
|
|
55
|
+
- Check database queries and external API calls along the path
|
|
56
|
+
- Look for missing validation, unhandled edge cases, or race conditions
|
|
57
|
+
|
|
58
|
+
4. **Identify contributing factors.** Distinguish between root cause and contributing factors:
|
|
59
|
+
- Root cause: the single change or condition that directly caused the failure
|
|
60
|
+
- Contributing factors: conditions that allowed the failure to reach production (missing tests, inadequate monitoring, deployment without canary)
|
|
61
|
+
|
|
62
|
+
5. **Validate the hypothesis.** Confirm the root cause by checking:
|
|
63
|
+
- Does reverting the identified change (or simulating the revert) resolve the issue?
|
|
64
|
+
- Does the failure reproduce under the identified conditions?
|
|
65
|
+
- Are there other incidents with the same root cause pattern?
|
|
66
|
+
|
|
67
|
+
---
|
|
68
|
+
|
|
69
|
+
### Phase 3: DOCUMENT -- Generate Artifacts
|
|
70
|
+
|
|
71
|
+
1. **Generate the postmortem report.** Create a structured document in `docs/postmortems/YYYY-MM-DD-<slug>.md` with these sections:
|
|
72
|
+
- **Summary:** One-paragraph description of what happened, impact, and duration
|
|
73
|
+
- **Timeline:** Chronological list of events from first signal to resolution
|
|
74
|
+
- **Root Cause:** Clear statement of what went wrong and why
|
|
75
|
+
- **Contributing Factors:** Conditions that enabled the failure
|
|
76
|
+
- **Impact:** User-facing impact, data impact, SLO impact, revenue impact if applicable
|
|
77
|
+
- **Detection:** How the incident was detected and time to detection
|
|
78
|
+
- **Mitigation:** Steps taken to resolve the incident
|
|
79
|
+
- **Action Items:** Numbered list with owner, priority, and due date
|
|
80
|
+
|
|
81
|
+
2. **Create or update runbooks.** For each failure mode identified:
|
|
82
|
+
- If no runbook exists, create one in `docs/runbooks/<service>-<failure-mode>.md`
|
|
83
|
+
- Structure: Symptoms, Diagnosis Steps, Mitigation Steps, Escalation Path, Recovery Verification
|
|
84
|
+
- Include concrete commands (kubectl, database queries, API calls) not just prose descriptions
|
|
85
|
+
- Reference monitoring dashboards and alert names
|
|
86
|
+
|
|
87
|
+
3. **Update the incident log.** If `docs/incidents/index.md` exists, append the new incident with date, severity, MTTR, and link to the postmortem.
|
|
88
|
+
|
|
89
|
+
4. **Tag related code.** Add or update `// INCIDENT-YYYY-MM-DD: <description>` comments at the code locations involved in the root cause. This creates a searchable history of incident-prone code.
|
|
90
|
+
|
|
91
|
+
---
|
|
92
|
+
|
|
93
|
+
### Phase 4: IMPROVE -- SLO Adjustments and Prevention
|
|
94
|
+
|
|
95
|
+
1. **Calculate SLO impact.** If `slo.yaml` or equivalent SLO definitions exist:
|
|
96
|
+
- Determine how much error budget the incident consumed
|
|
97
|
+
- Calculate remaining error budget for the current window
|
|
98
|
+
- If error budget is exhausted, flag that feature development should pause for reliability work
|
|
99
|
+
|
|
100
|
+
2. **Evaluate alerting effectiveness.** For each alert that fired (or should have fired):
|
|
101
|
+
- Was the alert timely? Compare alert time to incident start time
|
|
102
|
+
- Was the alert actionable? Did it point to the right service and include enough context?
|
|
103
|
+
- Were there false negatives? Identify monitoring gaps that should have caught the issue earlier
|
|
104
|
+
|
|
105
|
+
3. **Propose SLO adjustments.** Based on the incident analysis:
|
|
106
|
+
- If the SLO was violated but the impact was acceptable, the SLO may be too tight
|
|
107
|
+
- If the SLO was not violated but users were impacted, the SLO may be too loose
|
|
108
|
+
- Recommend specific SLI (Service Level Indicator) thresholds with justification
|
|
109
|
+
|
|
110
|
+
4. **Generate preventive action items.** Categorize actions by type:
|
|
111
|
+
- **Code fixes:** Specific bugs or missing validations to address
|
|
112
|
+
- **Testing gaps:** Missing integration tests, chaos tests, or load tests to add
|
|
113
|
+
- **Monitoring improvements:** New alerts, dashboards, or SLIs to implement
|
|
114
|
+
- **Process improvements:** Deployment safeguards, runbook updates, or on-call training
|
|
115
|
+
- **Architecture changes:** Circuit breakers, bulkheads, or redundancy to add
|
|
116
|
+
|
|
117
|
+
5. **Produce the improvement summary.** Output a prioritized action list with effort estimates and expected impact on MTTD and MTTR.
|
|
118
|
+
|
|
119
|
+
---
|
|
120
|
+
|
|
121
|
+
## Harness Integration
|
|
122
|
+
|
|
123
|
+
- **`harness skill run harness-incident-response`** -- Primary CLI entry point. Runs all four phases.
|
|
124
|
+
- **`harness validate`** -- Run after generating documents to ensure project structure is intact.
|
|
125
|
+
- **`harness check-deps`** -- Verify service dependency declarations match the incident trace.
|
|
126
|
+
- **`emit_interaction`** -- Used at severity classification (checkpoint:decision) to confirm severity with the operator before proceeding.
|
|
127
|
+
- **`Glob`** -- Discover existing runbooks, postmortems, and SLO definitions.
|
|
128
|
+
- **`Grep`** -- Search for error patterns, alert configurations, and incident-related code comments.
|
|
129
|
+
- **`Write`** -- Generate postmortem reports and runbook documents.
|
|
130
|
+
- **`Edit`** -- Update existing runbooks and incident indexes.
|
|
131
|
+
|
|
132
|
+
## Success Criteria
|
|
133
|
+
|
|
134
|
+
- Postmortem document is complete with all required sections (summary, timeline, root cause, action items)
|
|
135
|
+
- Timeline includes MTTD and MTTR calculations with specific timestamps
|
|
136
|
+
- Root cause is a specific, falsifiable statement (not "the system failed")
|
|
137
|
+
- Action items have owners, priorities, and due dates
|
|
138
|
+
- Runbooks contain concrete commands, not just descriptive prose
|
|
139
|
+
- SLO impact is quantified against the error budget when SLO definitions exist
|
|
140
|
+
|
|
141
|
+
## Examples
|
|
142
|
+
|
|
143
|
+
### Example: Node.js API Timeout Incident with Datadog Alerts
|
|
144
|
+
|
|
145
|
+
```
|
|
146
|
+
Phase 1: ASSESS
|
|
147
|
+
Signal: Datadog alert "api-gateway p99 latency > 2000ms" fired at 14:32 UTC
|
|
148
|
+
Affected: api-gateway -> user-service -> PostgreSQL
|
|
149
|
+
Severity: SEV2 (major degradation, 40% of requests timing out)
|
|
150
|
+
MTTD: 4 minutes (alert fired 4 min after first error)
|
|
151
|
+
MTTR: 47 minutes (resolved at 15:19 UTC)
|
|
152
|
+
|
|
153
|
+
Phase 2: INVESTIGATE
|
|
154
|
+
Correlated change: commit abc123 "add user preferences join" deployed at 14:25 UTC
|
|
155
|
+
Root cause: N+1 query in GET /api/users/:id/preferences — new LEFT JOIN
|
|
156
|
+
on unindexed column `preferences.user_id` caused full table scan
|
|
157
|
+
Contributing factors:
|
|
158
|
+
- No query performance test for the preferences endpoint
|
|
159
|
+
- Missing database index on preferences.user_id
|
|
160
|
+
- No circuit breaker between api-gateway and user-service
|
|
161
|
+
|
|
162
|
+
Phase 3: DOCUMENT
|
|
163
|
+
Created: docs/postmortems/2026-03-15-user-service-timeout.md
|
|
164
|
+
Created: docs/runbooks/user-service-database-slow-query.md
|
|
165
|
+
Updated: docs/incidents/index.md
|
|
166
|
+
|
|
167
|
+
Phase 4: IMPROVE
|
|
168
|
+
SLO impact: Consumed 12% of monthly error budget (88% remaining)
|
|
169
|
+
Action items:
|
|
170
|
+
1. [P0] Add index on preferences.user_id (owner: @backend, due: 2026-03-16)
|
|
171
|
+
2. [P1] Add query execution time assertions to integration tests (owner: @backend, due: 2026-03-22)
|
|
172
|
+
3. [P1] Add circuit breaker on api-gateway -> user-service (owner: @platform, due: 2026-03-22)
|
|
173
|
+
4. [P2] Add Datadog query performance monitor for user-service (owner: @sre, due: 2026-03-29)
|
|
174
|
+
```
|
|
175
|
+
|
|
176
|
+
### Example: Kubernetes Pod CrashLoopBackOff with PagerDuty Escalation
|
|
177
|
+
|
|
178
|
+
```
|
|
179
|
+
Phase 1: ASSESS
|
|
180
|
+
Signal: PagerDuty incident #4521 — payment-service pods in CrashLoopBackOff
|
|
181
|
+
Affected: payment-service -> Stripe API -> order-service (downstream)
|
|
182
|
+
Severity: SEV1 (payment processing completely down)
|
|
183
|
+
MTTD: 2 minutes (PagerDuty auto-detected from Kubernetes health checks)
|
|
184
|
+
MTTR: 23 minutes
|
|
185
|
+
|
|
186
|
+
Phase 2: INVESTIGATE
|
|
187
|
+
Root cause: Environment variable STRIPE_WEBHOOK_SECRET rotated in Vault
|
|
188
|
+
but payment-service pods were not restarted to pick up new value.
|
|
189
|
+
Stripe signature verification failed on all incoming webhooks, causing
|
|
190
|
+
panic in the webhook handler (no error recovery).
|
|
191
|
+
Contributing factors:
|
|
192
|
+
- Vault secret rotation did not trigger pod restart
|
|
193
|
+
- Webhook handler used panic instead of returning error
|
|
194
|
+
- No runbook for secret rotation procedures
|
|
195
|
+
|
|
196
|
+
Phase 3: DOCUMENT
|
|
197
|
+
Created: docs/postmortems/2026-03-20-payment-service-crashloop.md
|
|
198
|
+
Created: docs/runbooks/payment-service-secret-rotation.md
|
|
199
|
+
Created: docs/runbooks/payment-service-stripe-webhook-failure.md
|
|
200
|
+
Updated: docs/incidents/index.md
|
|
201
|
+
|
|
202
|
+
Phase 4: IMPROVE
|
|
203
|
+
SLO impact: Consumed 100% of weekly error budget. Feature freeze recommended.
|
|
204
|
+
Action items:
|
|
205
|
+
1. [P0] Add Vault agent sidecar with auto-restart on secret change (owner: @platform)
|
|
206
|
+
2. [P0] Replace panic with error return in webhook handler (owner: @payments)
|
|
207
|
+
3. [P1] Add synthetic Stripe webhook test to canary suite (owner: @payments)
|
|
208
|
+
4. [P2] Create secret rotation runbook for all services (owner: @sre)
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
## Gates
|
|
212
|
+
|
|
213
|
+
- **No postmortem without a root cause statement.** A postmortem that says "cause unknown" is incomplete. If the root cause cannot be determined, the postmortem must document what was investigated, what was ruled out, and what additional data is needed. Do not close the investigation.
|
|
214
|
+
- **No action items without owners.** Every action item must have an assigned owner and a due date. Unowned action items are never completed. If no owner can be identified, escalate to the team lead.
|
|
215
|
+
- **No severity downgrade without justification.** If a severity is reclassified during investigation, the reason must be documented in the postmortem timeline. Severity downgrades without evidence indicate pressure to minimize, not genuine reassessment.
|
|
216
|
+
- **No skipping the improvement phase.** Documentation without follow-through produces shelf-ware. The improvement phase must produce at least one concrete, actionable item per contributing factor identified.
|
|
217
|
+
|
|
218
|
+
## Escalation
|
|
219
|
+
|
|
220
|
+
- **When root cause cannot be determined from code alone:** The incident may require production logs, metrics, or traces that are not available in the codebase. Report: "Root cause analysis requires access to [specific observability data]. Recommend reviewing [Datadog/Grafana/CloudWatch] dashboards for the incident window."
|
|
221
|
+
- **When the incident reveals a systemic architecture issue:** A single postmortem action item is insufficient. Report: "This incident pattern indicates a systemic issue with [description]. Recommend a dedicated architecture review using harness-architecture-advisor."
|
|
222
|
+
- **When SLO definitions do not exist:** Error budget calculation is impossible without SLOs. Report: "No SLO definitions found. Recommend establishing baseline SLOs before the next incident review. See the SLO starter template in docs/runbooks/slo-template.yaml."
|
|
223
|
+
- **When multiple teams are involved in the blast radius:** A single postmortem owner may not have visibility into all contributing factors. Report: "This incident spans [N] services owned by [teams]. Recommend a joint postmortem review with representatives from each team."
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
name: harness-incident-response
|
|
2
|
+
version: "1.0.0"
|
|
3
|
+
description: Runbook generation, postmortem analysis, and SLO/SLA tracking
|
|
4
|
+
cognitive_mode: diagnostic-investigator
|
|
5
|
+
triggers:
|
|
6
|
+
- manual
|
|
7
|
+
- on_bug_fix
|
|
8
|
+
platforms:
|
|
9
|
+
- claude-code
|
|
10
|
+
- gemini-cli
|
|
11
|
+
tools:
|
|
12
|
+
- Bash
|
|
13
|
+
- Read
|
|
14
|
+
- Write
|
|
15
|
+
- Edit
|
|
16
|
+
- Glob
|
|
17
|
+
- Grep
|
|
18
|
+
- emit_interaction
|
|
19
|
+
cli:
|
|
20
|
+
command: harness skill run harness-incident-response
|
|
21
|
+
args:
|
|
22
|
+
- name: path
|
|
23
|
+
description: Project root path
|
|
24
|
+
required: false
|
|
25
|
+
- name: mode
|
|
26
|
+
description: "Operating mode: runbook, postmortem, or slo. Auto-detected when omitted."
|
|
27
|
+
required: false
|
|
28
|
+
- name: severity
|
|
29
|
+
description: "Incident severity: sev1, sev2, sev3, sev4. Defaults to sev3."
|
|
30
|
+
required: false
|
|
31
|
+
mcp:
|
|
32
|
+
tool: run_skill
|
|
33
|
+
input:
|
|
34
|
+
skill: harness-incident-response
|
|
35
|
+
path: string
|
|
36
|
+
type: rigid
|
|
37
|
+
tier: 3
|
|
38
|
+
internal: false
|
|
39
|
+
keywords:
|
|
40
|
+
- incident
|
|
41
|
+
- runbook
|
|
42
|
+
- postmortem
|
|
43
|
+
- SLO
|
|
44
|
+
- SLA
|
|
45
|
+
- SLI
|
|
46
|
+
- on-call
|
|
47
|
+
- alert
|
|
48
|
+
- severity
|
|
49
|
+
- MTTR
|
|
50
|
+
- MTTD
|
|
51
|
+
- error budget
|
|
52
|
+
- incident management
|
|
53
|
+
- PagerDuty
|
|
54
|
+
- OpsGenie
|
|
55
|
+
stack_signals:
|
|
56
|
+
- "runbooks/"
|
|
57
|
+
- "docs/runbooks/"
|
|
58
|
+
- "docs/incidents/"
|
|
59
|
+
- "docs/postmortems/"
|
|
60
|
+
- "slo.yaml"
|
|
61
|
+
- ".pagerduty*"
|
|
62
|
+
phases:
|
|
63
|
+
- name: assess
|
|
64
|
+
description: Determine incident scope, severity, and affected services from available evidence
|
|
65
|
+
required: true
|
|
66
|
+
- name: investigate
|
|
67
|
+
description: Trace root cause through logs, metrics, dependencies, and recent changes
|
|
68
|
+
required: true
|
|
69
|
+
- name: document
|
|
70
|
+
description: Generate runbooks, postmortem reports, and timeline reconstructions
|
|
71
|
+
required: true
|
|
72
|
+
- name: improve
|
|
73
|
+
description: Propose SLO adjustments, alerting improvements, and preventive action items
|
|
74
|
+
required: true
|
|
75
|
+
state:
|
|
76
|
+
persistent: false
|
|
77
|
+
files: []
|
|
78
|
+
depends_on: []
|