@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.
Files changed (499) hide show
  1. package/dist/agents/commands/codex/AGENTS.md +39 -0
  2. package/dist/agents/commands/codex/harness/add-harness-component/SKILL.md +195 -0
  3. package/dist/agents/commands/codex/harness/add-harness-component/agents/openai.yaml +3 -0
  4. package/dist/agents/commands/codex/harness/cleanup-dead-code/SKILL.md +248 -0
  5. package/dist/agents/commands/codex/harness/cleanup-dead-code/agents/openai.yaml +3 -0
  6. package/dist/agents/commands/codex/harness/detect-doc-drift/SKILL.md +182 -0
  7. package/dist/agents/commands/codex/harness/detect-doc-drift/agents/openai.yaml +3 -0
  8. package/dist/agents/commands/codex/harness/enforce-architecture/SKILL.md +299 -0
  9. package/dist/agents/commands/codex/harness/enforce-architecture/agents/openai.yaml +3 -0
  10. package/dist/agents/commands/codex/harness/harness-architecture-advisor/SKILL.md +452 -0
  11. package/dist/agents/commands/codex/harness/harness-architecture-advisor/agents/openai.yaml +3 -0
  12. package/dist/agents/commands/codex/harness/harness-autopilot/SKILL.md +919 -0
  13. package/dist/agents/commands/codex/harness/harness-autopilot/agents/openai.yaml +3 -0
  14. package/dist/agents/commands/codex/harness/harness-brainstorming/SKILL.md +409 -0
  15. package/dist/agents/commands/codex/harness/harness-brainstorming/agents/openai.yaml +3 -0
  16. package/dist/agents/commands/codex/harness/harness-code-review/SKILL.md +860 -0
  17. package/dist/agents/commands/codex/harness/harness-code-review/agents/openai.yaml +3 -0
  18. package/dist/agents/commands/codex/harness/harness-codebase-cleanup/SKILL.md +227 -0
  19. package/dist/agents/commands/codex/harness/harness-codebase-cleanup/agents/openai.yaml +3 -0
  20. package/dist/agents/commands/codex/harness/harness-debugging/SKILL.md +369 -0
  21. package/dist/agents/commands/codex/harness/harness-debugging/agents/openai.yaml +3 -0
  22. package/dist/agents/commands/codex/harness/harness-dependency-health/SKILL.md +182 -0
  23. package/dist/agents/commands/codex/harness/harness-dependency-health/agents/openai.yaml +3 -0
  24. package/dist/agents/commands/codex/harness/harness-docs-pipeline/SKILL.md +463 -0
  25. package/dist/agents/commands/codex/harness/harness-docs-pipeline/agents/openai.yaml +3 -0
  26. package/dist/agents/commands/codex/harness/harness-execution/SKILL.md +513 -0
  27. package/dist/agents/commands/codex/harness/harness-execution/agents/openai.yaml +3 -0
  28. package/dist/agents/commands/codex/harness/harness-hotspot-detector/SKILL.md +164 -0
  29. package/dist/agents/commands/codex/harness/harness-hotspot-detector/agents/openai.yaml +3 -0
  30. package/dist/agents/commands/codex/harness/harness-impact-analysis/SKILL.md +187 -0
  31. package/dist/agents/commands/codex/harness/harness-impact-analysis/agents/openai.yaml +3 -0
  32. package/dist/agents/commands/codex/harness/harness-integrity/SKILL.md +170 -0
  33. package/dist/agents/commands/codex/harness/harness-integrity/agents/openai.yaml +3 -0
  34. package/dist/agents/commands/codex/harness/harness-onboarding/SKILL.md +291 -0
  35. package/dist/agents/commands/codex/harness/harness-onboarding/agents/openai.yaml +3 -0
  36. package/dist/agents/commands/codex/harness/harness-perf/SKILL.md +263 -0
  37. package/dist/agents/commands/codex/harness/harness-perf/agents/openai.yaml +3 -0
  38. package/dist/agents/commands/codex/harness/harness-planning/SKILL.md +582 -0
  39. package/dist/agents/commands/codex/harness/harness-planning/agents/openai.yaml +3 -0
  40. package/dist/agents/commands/codex/harness/harness-refactoring/SKILL.md +172 -0
  41. package/dist/agents/commands/codex/harness/harness-refactoring/agents/openai.yaml +3 -0
  42. package/dist/agents/commands/codex/harness/harness-release-readiness/SKILL.md +692 -0
  43. package/dist/agents/commands/codex/harness/harness-release-readiness/agents/openai.yaml +3 -0
  44. package/dist/agents/commands/codex/harness/harness-roadmap/SKILL.md +598 -0
  45. package/dist/agents/commands/codex/harness/harness-roadmap/agents/openai.yaml +3 -0
  46. package/dist/agents/commands/codex/harness/harness-security-scan/SKILL.md +157 -0
  47. package/dist/agents/commands/codex/harness/harness-security-scan/agents/openai.yaml +3 -0
  48. package/dist/agents/commands/codex/harness/harness-skill-authoring/SKILL.md +295 -0
  49. package/dist/agents/commands/codex/harness/harness-skill-authoring/agents/openai.yaml +3 -0
  50. package/dist/agents/commands/codex/harness/harness-soundness-review/SKILL.md +1270 -0
  51. package/dist/agents/commands/codex/harness/harness-soundness-review/agents/openai.yaml +3 -0
  52. package/dist/agents/commands/codex/harness/harness-supply-chain-audit/SKILL.md +247 -0
  53. package/dist/agents/commands/codex/harness/harness-supply-chain-audit/agents/openai.yaml +3 -0
  54. package/dist/agents/commands/codex/harness/harness-tdd/SKILL.md +180 -0
  55. package/dist/agents/commands/codex/harness/harness-tdd/agents/openai.yaml +3 -0
  56. package/dist/agents/commands/codex/harness/harness-test-advisor/SKILL.md +163 -0
  57. package/dist/agents/commands/codex/harness/harness-test-advisor/agents/openai.yaml +3 -0
  58. package/dist/agents/commands/codex/harness/harness-verification/SKILL.md +424 -0
  59. package/dist/agents/commands/codex/harness/harness-verification/agents/openai.yaml +3 -0
  60. package/dist/agents/commands/codex/harness/harness-verify/SKILL.md +162 -0
  61. package/dist/agents/commands/codex/harness/harness-verify/agents/openai.yaml +3 -0
  62. package/dist/agents/commands/codex/harness/initialize-harness-project/SKILL.md +235 -0
  63. package/dist/agents/commands/codex/harness/initialize-harness-project/agents/openai.yaml +3 -0
  64. package/dist/agents/commands/cursor/harness/add-harness-component.mdc +200 -0
  65. package/dist/agents/commands/cursor/harness/cleanup-dead-code.mdc +253 -0
  66. package/dist/agents/commands/cursor/harness/detect-doc-drift.mdc +187 -0
  67. package/dist/agents/commands/cursor/harness/enforce-architecture.mdc +304 -0
  68. package/dist/agents/commands/cursor/harness/harness-architecture-advisor.mdc +457 -0
  69. package/dist/agents/commands/cursor/harness/harness-autopilot.mdc +924 -0
  70. package/dist/agents/commands/cursor/harness/harness-brainstorming.mdc +414 -0
  71. package/dist/agents/commands/cursor/harness/harness-code-review.mdc +865 -0
  72. package/dist/agents/commands/cursor/harness/harness-codebase-cleanup.mdc +232 -0
  73. package/dist/agents/commands/cursor/harness/harness-debugging.mdc +374 -0
  74. package/dist/agents/commands/cursor/harness/harness-dependency-health.mdc +187 -0
  75. package/dist/agents/commands/cursor/harness/harness-docs-pipeline.mdc +468 -0
  76. package/dist/agents/commands/cursor/harness/harness-execution.mdc +518 -0
  77. package/dist/agents/commands/cursor/harness/harness-hotspot-detector.mdc +169 -0
  78. package/dist/agents/commands/cursor/harness/harness-impact-analysis.mdc +192 -0
  79. package/dist/agents/commands/cursor/harness/harness-integrity.mdc +175 -0
  80. package/dist/agents/commands/cursor/harness/harness-onboarding.mdc +296 -0
  81. package/dist/agents/commands/cursor/harness/harness-perf.mdc +268 -0
  82. package/dist/agents/commands/cursor/harness/harness-planning.mdc +587 -0
  83. package/dist/agents/commands/cursor/harness/harness-refactoring.mdc +177 -0
  84. package/dist/agents/commands/cursor/harness/harness-release-readiness.mdc +697 -0
  85. package/dist/agents/commands/cursor/harness/harness-roadmap.mdc +603 -0
  86. package/dist/agents/commands/cursor/harness/harness-security-scan.mdc +162 -0
  87. package/dist/agents/commands/cursor/harness/harness-skill-authoring.mdc +300 -0
  88. package/dist/agents/commands/cursor/harness/harness-soundness-review.mdc +1275 -0
  89. package/dist/agents/commands/cursor/harness/harness-supply-chain-audit.mdc +252 -0
  90. package/dist/agents/commands/cursor/harness/harness-tdd.mdc +185 -0
  91. package/dist/agents/commands/cursor/harness/harness-test-advisor.mdc +168 -0
  92. package/dist/agents/commands/cursor/harness/harness-verification.mdc +429 -0
  93. package/dist/agents/commands/cursor/harness/harness-verify.mdc +167 -0
  94. package/dist/agents/commands/cursor/harness/initialize-harness-project.mdc +240 -0
  95. package/dist/agents/skills/claude-code/enforce-architecture/SKILL.md +52 -0
  96. package/dist/agents/skills/claude-code/harness-api-design/SKILL.md +52 -0
  97. package/dist/agents/skills/claude-code/harness-architecture-advisor/SKILL.md +52 -0
  98. package/dist/agents/skills/claude-code/harness-auth/SKILL.md +52 -0
  99. package/dist/agents/skills/claude-code/harness-autopilot/SKILL.md +355 -45
  100. package/dist/agents/skills/claude-code/harness-autopilot/skill.yaml +12 -0
  101. package/dist/agents/skills/claude-code/harness-code-review/SKILL.md +97 -3
  102. package/dist/agents/skills/claude-code/harness-code-review/skill.yaml +6 -0
  103. package/dist/agents/skills/claude-code/harness-codebase-cleanup/SKILL.md +2 -4
  104. package/dist/agents/skills/claude-code/harness-database/SKILL.md +52 -0
  105. package/dist/agents/skills/claude-code/harness-deployment/SKILL.md +52 -0
  106. package/dist/agents/skills/claude-code/harness-planning/SKILL.md +99 -3
  107. package/dist/agents/skills/claude-code/harness-planning/skill.yaml +6 -0
  108. package/dist/agents/skills/claude-code/harness-pre-commit-review/SKILL.md +1 -1
  109. package/dist/agents/skills/claude-code/harness-product-spec/SKILL.md +5 -5
  110. package/dist/agents/skills/claude-code/harness-security-review/SKILL.md +27 -7
  111. package/dist/agents/skills/claude-code/harness-security-scan/SKILL.md +52 -0
  112. package/dist/agents/skills/claude-code/harness-supply-chain-audit/SKILL.md +281 -0
  113. package/dist/agents/skills/claude-code/harness-supply-chain-audit/skill.yaml +51 -0
  114. package/dist/agents/skills/codex/add-harness-component/SKILL.md +192 -0
  115. package/dist/agents/skills/codex/add-harness-component/skill.yaml +33 -0
  116. package/dist/agents/skills/codex/align-documentation/SKILL.md +213 -0
  117. package/dist/agents/skills/codex/align-documentation/skill.yaml +32 -0
  118. package/dist/agents/skills/codex/check-mechanical-constraints/SKILL.md +191 -0
  119. package/dist/agents/skills/codex/check-mechanical-constraints/skill.yaml +33 -0
  120. package/dist/agents/skills/codex/cleanup-dead-code/SKILL.md +245 -0
  121. package/dist/agents/skills/codex/cleanup-dead-code/skill.yaml +34 -0
  122. package/dist/agents/skills/codex/detect-doc-drift/SKILL.md +179 -0
  123. package/dist/agents/skills/codex/detect-doc-drift/skill.yaml +31 -0
  124. package/dist/agents/skills/codex/enforce-architecture/SKILL.md +296 -0
  125. package/dist/agents/skills/codex/enforce-architecture/skill.yaml +35 -0
  126. package/dist/agents/skills/codex/harness-accessibility/SKILL.md +281 -0
  127. package/dist/agents/skills/codex/harness-accessibility/skill.yaml +52 -0
  128. package/dist/agents/skills/codex/harness-api-design/SKILL.md +356 -0
  129. package/dist/agents/skills/codex/harness-api-design/skill.yaml +74 -0
  130. package/dist/agents/skills/codex/harness-architecture-advisor/SKILL.md +449 -0
  131. package/dist/agents/skills/codex/harness-architecture-advisor/skill.yaml +49 -0
  132. package/dist/agents/skills/codex/harness-auth/SKILL.md +331 -0
  133. package/dist/agents/skills/codex/harness-auth/skill.yaml +81 -0
  134. package/dist/agents/skills/codex/harness-autopilot/SKILL.md +916 -0
  135. package/dist/agents/skills/codex/harness-autopilot/skill.yaml +67 -0
  136. package/dist/agents/skills/codex/harness-brainstorming/SKILL.md +406 -0
  137. package/dist/agents/skills/codex/harness-brainstorming/skill.yaml +50 -0
  138. package/dist/agents/skills/codex/harness-caching/SKILL.md +309 -0
  139. package/dist/agents/skills/codex/harness-caching/skill.yaml +73 -0
  140. package/dist/agents/skills/codex/harness-chaos/SKILL.md +295 -0
  141. package/dist/agents/skills/codex/harness-chaos/skill.yaml +72 -0
  142. package/dist/agents/skills/codex/harness-code-review/SKILL.md +857 -0
  143. package/dist/agents/skills/codex/harness-code-review/skill.yaml +52 -0
  144. package/dist/agents/skills/codex/harness-codebase-cleanup/SKILL.md +224 -0
  145. package/dist/agents/skills/codex/harness-codebase-cleanup/skill.yaml +65 -0
  146. package/dist/agents/skills/codex/harness-compliance/SKILL.md +303 -0
  147. package/dist/agents/skills/codex/harness-compliance/skill.yaml +78 -0
  148. package/dist/agents/skills/codex/harness-containerization/SKILL.md +284 -0
  149. package/dist/agents/skills/codex/harness-containerization/skill.yaml +80 -0
  150. package/dist/agents/skills/codex/harness-data-pipeline/SKILL.md +274 -0
  151. package/dist/agents/skills/codex/harness-data-pipeline/skill.yaml +81 -0
  152. package/dist/agents/skills/codex/harness-data-validation/SKILL.md +343 -0
  153. package/dist/agents/skills/codex/harness-data-validation/skill.yaml +75 -0
  154. package/dist/agents/skills/codex/harness-database/SKILL.md +310 -0
  155. package/dist/agents/skills/codex/harness-database/skill.yaml +80 -0
  156. package/dist/agents/skills/codex/harness-debugging/SKILL.md +366 -0
  157. package/dist/agents/skills/codex/harness-debugging/skill.yaml +48 -0
  158. package/dist/agents/skills/codex/harness-dependency-health/SKILL.md +179 -0
  159. package/dist/agents/skills/codex/harness-dependency-health/skill.yaml +42 -0
  160. package/dist/agents/skills/codex/harness-deployment/SKILL.md +307 -0
  161. package/dist/agents/skills/codex/harness-deployment/skill.yaml +77 -0
  162. package/dist/agents/skills/codex/harness-design/SKILL.md +265 -0
  163. package/dist/agents/skills/codex/harness-design/skill.yaml +54 -0
  164. package/dist/agents/skills/codex/harness-design-mobile/SKILL.md +336 -0
  165. package/dist/agents/skills/codex/harness-design-mobile/skill.yaml +50 -0
  166. package/dist/agents/skills/codex/harness-design-system/SKILL.md +282 -0
  167. package/dist/agents/skills/codex/harness-design-system/skill.yaml +51 -0
  168. package/dist/agents/skills/codex/harness-design-web/SKILL.md +360 -0
  169. package/dist/agents/skills/codex/harness-design-web/skill.yaml +53 -0
  170. package/dist/agents/skills/codex/harness-diagnostics/SKILL.md +318 -0
  171. package/dist/agents/skills/codex/harness-diagnostics/skill.yaml +51 -0
  172. package/dist/agents/skills/codex/harness-docs-pipeline/SKILL.md +460 -0
  173. package/dist/agents/skills/codex/harness-docs-pipeline/skill.yaml +70 -0
  174. package/dist/agents/skills/codex/harness-dx/SKILL.md +276 -0
  175. package/dist/agents/skills/codex/harness-dx/skill.yaml +76 -0
  176. package/dist/agents/skills/codex/harness-e2e/SKILL.md +245 -0
  177. package/dist/agents/skills/codex/harness-e2e/skill.yaml +78 -0
  178. package/dist/agents/skills/codex/harness-event-driven/SKILL.md +280 -0
  179. package/dist/agents/skills/codex/harness-event-driven/skill.yaml +77 -0
  180. package/dist/agents/skills/codex/harness-execution/SKILL.md +510 -0
  181. package/dist/agents/skills/codex/harness-execution/skill.yaml +52 -0
  182. package/dist/agents/skills/codex/harness-feature-flags/SKILL.md +287 -0
  183. package/dist/agents/skills/codex/harness-feature-flags/skill.yaml +74 -0
  184. package/dist/agents/skills/codex/harness-git-workflow/SKILL.md +268 -0
  185. package/dist/agents/skills/codex/harness-git-workflow/skill.yaml +32 -0
  186. package/dist/agents/skills/codex/harness-hotspot-detector/SKILL.md +161 -0
  187. package/dist/agents/skills/codex/harness-hotspot-detector/skill.yaml +45 -0
  188. package/dist/agents/skills/codex/harness-i18n/SKILL.md +484 -0
  189. package/dist/agents/skills/codex/harness-i18n/skill.yaml +55 -0
  190. package/dist/agents/skills/codex/harness-i18n-process/SKILL.md +388 -0
  191. package/dist/agents/skills/codex/harness-i18n-process/skill.yaml +44 -0
  192. package/dist/agents/skills/codex/harness-i18n-workflow/SKILL.md +512 -0
  193. package/dist/agents/skills/codex/harness-i18n-workflow/skill.yaml +54 -0
  194. package/dist/agents/skills/codex/harness-impact-analysis/SKILL.md +184 -0
  195. package/dist/agents/skills/codex/harness-impact-analysis/skill.yaml +45 -0
  196. package/dist/agents/skills/codex/harness-incident-response/SKILL.md +223 -0
  197. package/dist/agents/skills/codex/harness-incident-response/skill.yaml +78 -0
  198. package/dist/agents/skills/codex/harness-infrastructure-as-code/SKILL.md +279 -0
  199. package/dist/agents/skills/codex/harness-infrastructure-as-code/skill.yaml +80 -0
  200. package/dist/agents/skills/codex/harness-integration-test/SKILL.md +271 -0
  201. package/dist/agents/skills/codex/harness-integration-test/skill.yaml +73 -0
  202. package/dist/agents/skills/codex/harness-integrity/SKILL.md +167 -0
  203. package/dist/agents/skills/codex/harness-integrity/skill.yaml +48 -0
  204. package/dist/agents/skills/codex/harness-knowledge-mapper/SKILL.md +195 -0
  205. package/dist/agents/skills/codex/harness-knowledge-mapper/skill.yaml +50 -0
  206. package/dist/agents/skills/codex/harness-load-testing/SKILL.md +274 -0
  207. package/dist/agents/skills/codex/harness-load-testing/skill.yaml +79 -0
  208. package/dist/agents/skills/codex/harness-ml-ops/SKILL.md +341 -0
  209. package/dist/agents/skills/codex/harness-ml-ops/skill.yaml +79 -0
  210. package/dist/agents/skills/codex/harness-mobile-patterns/SKILL.md +326 -0
  211. package/dist/agents/skills/codex/harness-mobile-patterns/skill.yaml +82 -0
  212. package/dist/agents/skills/codex/harness-mutation-test/SKILL.md +251 -0
  213. package/dist/agents/skills/codex/harness-mutation-test/skill.yaml +70 -0
  214. package/dist/agents/skills/codex/harness-observability/SKILL.md +283 -0
  215. package/dist/agents/skills/codex/harness-observability/skill.yaml +78 -0
  216. package/dist/agents/skills/codex/harness-onboarding/SKILL.md +288 -0
  217. package/dist/agents/skills/codex/harness-onboarding/skill.yaml +31 -0
  218. package/dist/agents/skills/codex/harness-parallel-agents/SKILL.md +256 -0
  219. package/dist/agents/skills/codex/harness-parallel-agents/skill.yaml +34 -0
  220. package/dist/agents/skills/codex/harness-perf/SKILL.md +260 -0
  221. package/dist/agents/skills/codex/harness-perf/skill.yaml +51 -0
  222. package/dist/agents/skills/codex/harness-perf-tdd/SKILL.md +249 -0
  223. package/dist/agents/skills/codex/harness-perf-tdd/skill.yaml +48 -0
  224. package/dist/agents/skills/codex/harness-planning/SKILL.md +579 -0
  225. package/dist/agents/skills/codex/harness-planning/skill.yaml +56 -0
  226. package/dist/agents/skills/codex/harness-pre-commit-review/SKILL.md +324 -0
  227. package/dist/agents/skills/codex/harness-pre-commit-review/skill.yaml +34 -0
  228. package/dist/agents/skills/codex/harness-product-spec/SKILL.md +285 -0
  229. package/dist/agents/skills/codex/harness-product-spec/skill.yaml +72 -0
  230. package/dist/agents/skills/codex/harness-property-test/SKILL.md +281 -0
  231. package/dist/agents/skills/codex/harness-property-test/skill.yaml +71 -0
  232. package/dist/agents/skills/codex/harness-refactoring/SKILL.md +169 -0
  233. package/dist/agents/skills/codex/harness-refactoring/skill.yaml +34 -0
  234. package/dist/agents/skills/codex/harness-release-readiness/SKILL.md +689 -0
  235. package/dist/agents/skills/codex/harness-release-readiness/skill.yaml +58 -0
  236. package/dist/agents/skills/codex/harness-resilience/SKILL.md +255 -0
  237. package/dist/agents/skills/codex/harness-resilience/skill.yaml +76 -0
  238. package/dist/agents/skills/codex/harness-roadmap/SKILL.md +595 -0
  239. package/dist/agents/skills/codex/harness-roadmap/skill.yaml +44 -0
  240. package/dist/agents/skills/codex/harness-secrets/SKILL.md +293 -0
  241. package/dist/agents/skills/codex/harness-secrets/skill.yaml +76 -0
  242. package/dist/agents/skills/codex/harness-security-review/SKILL.md +260 -0
  243. package/dist/agents/skills/codex/harness-security-review/skill.yaml +53 -0
  244. package/dist/agents/skills/codex/harness-security-scan/SKILL.md +154 -0
  245. package/dist/agents/skills/codex/harness-security-scan/skill.yaml +42 -0
  246. package/dist/agents/skills/codex/harness-skill-authoring/SKILL.md +292 -0
  247. package/dist/agents/skills/codex/harness-skill-authoring/skill.yaml +33 -0
  248. package/dist/agents/skills/codex/harness-soundness-review/SKILL.md +1267 -0
  249. package/dist/agents/skills/codex/harness-soundness-review/skill.yaml +49 -0
  250. package/dist/agents/skills/codex/harness-sql-review/SKILL.md +315 -0
  251. package/dist/agents/skills/codex/harness-sql-review/skill.yaml +74 -0
  252. package/dist/agents/skills/codex/harness-state-management/SKILL.md +309 -0
  253. package/dist/agents/skills/codex/harness-state-management/skill.yaml +33 -0
  254. package/dist/agents/skills/codex/harness-supply-chain-audit/SKILL.md +281 -0
  255. package/dist/agents/skills/codex/harness-supply-chain-audit/skill.yaml +51 -0
  256. package/dist/agents/skills/codex/harness-tdd/SKILL.md +177 -0
  257. package/dist/agents/skills/codex/harness-tdd/skill.yaml +49 -0
  258. package/dist/agents/skills/codex/harness-test-advisor/SKILL.md +160 -0
  259. package/dist/agents/skills/codex/harness-test-advisor/skill.yaml +45 -0
  260. package/dist/agents/skills/codex/harness-test-data/SKILL.md +268 -0
  261. package/dist/agents/skills/codex/harness-test-data/skill.yaml +74 -0
  262. package/dist/agents/skills/codex/harness-ux-copy/SKILL.md +271 -0
  263. package/dist/agents/skills/codex/harness-ux-copy/skill.yaml +77 -0
  264. package/dist/agents/skills/codex/harness-verification/SKILL.md +421 -0
  265. package/dist/agents/skills/codex/harness-verification/skill.yaml +43 -0
  266. package/dist/agents/skills/codex/harness-verify/SKILL.md +159 -0
  267. package/dist/agents/skills/codex/harness-verify/skill.yaml +41 -0
  268. package/dist/agents/skills/codex/harness-visual-regression/SKILL.md +257 -0
  269. package/dist/agents/skills/codex/harness-visual-regression/skill.yaml +74 -0
  270. package/dist/agents/skills/codex/initialize-harness-project/SKILL.md +232 -0
  271. package/dist/agents/skills/codex/initialize-harness-project/skill.yaml +32 -0
  272. package/dist/agents/skills/codex/validate-context-engineering/SKILL.md +150 -0
  273. package/dist/agents/skills/codex/validate-context-engineering/skill.yaml +32 -0
  274. package/dist/agents/skills/cursor/add-harness-component/SKILL.md +192 -0
  275. package/dist/agents/skills/cursor/add-harness-component/skill.yaml +33 -0
  276. package/dist/agents/skills/cursor/align-documentation/SKILL.md +213 -0
  277. package/dist/agents/skills/cursor/align-documentation/skill.yaml +32 -0
  278. package/dist/agents/skills/cursor/check-mechanical-constraints/SKILL.md +191 -0
  279. package/dist/agents/skills/cursor/check-mechanical-constraints/skill.yaml +33 -0
  280. package/dist/agents/skills/cursor/cleanup-dead-code/SKILL.md +245 -0
  281. package/dist/agents/skills/cursor/cleanup-dead-code/skill.yaml +34 -0
  282. package/dist/agents/skills/cursor/detect-doc-drift/SKILL.md +179 -0
  283. package/dist/agents/skills/cursor/detect-doc-drift/skill.yaml +31 -0
  284. package/dist/agents/skills/cursor/enforce-architecture/SKILL.md +296 -0
  285. package/dist/agents/skills/cursor/enforce-architecture/skill.yaml +35 -0
  286. package/dist/agents/skills/cursor/harness-accessibility/SKILL.md +281 -0
  287. package/dist/agents/skills/cursor/harness-accessibility/skill.yaml +52 -0
  288. package/dist/agents/skills/cursor/harness-api-design/SKILL.md +356 -0
  289. package/dist/agents/skills/cursor/harness-api-design/skill.yaml +74 -0
  290. package/dist/agents/skills/cursor/harness-architecture-advisor/SKILL.md +449 -0
  291. package/dist/agents/skills/cursor/harness-architecture-advisor/skill.yaml +49 -0
  292. package/dist/agents/skills/cursor/harness-auth/SKILL.md +331 -0
  293. package/dist/agents/skills/cursor/harness-auth/skill.yaml +81 -0
  294. package/dist/agents/skills/cursor/harness-autopilot/SKILL.md +916 -0
  295. package/dist/agents/skills/cursor/harness-autopilot/skill.yaml +67 -0
  296. package/dist/agents/skills/cursor/harness-brainstorming/SKILL.md +406 -0
  297. package/dist/agents/skills/cursor/harness-brainstorming/skill.yaml +50 -0
  298. package/dist/agents/skills/cursor/harness-caching/SKILL.md +309 -0
  299. package/dist/agents/skills/cursor/harness-caching/skill.yaml +73 -0
  300. package/dist/agents/skills/cursor/harness-chaos/SKILL.md +295 -0
  301. package/dist/agents/skills/cursor/harness-chaos/skill.yaml +72 -0
  302. package/dist/agents/skills/cursor/harness-code-review/SKILL.md +857 -0
  303. package/dist/agents/skills/cursor/harness-code-review/skill.yaml +52 -0
  304. package/dist/agents/skills/cursor/harness-codebase-cleanup/SKILL.md +224 -0
  305. package/dist/agents/skills/cursor/harness-codebase-cleanup/skill.yaml +65 -0
  306. package/dist/agents/skills/cursor/harness-compliance/SKILL.md +303 -0
  307. package/dist/agents/skills/cursor/harness-compliance/skill.yaml +78 -0
  308. package/dist/agents/skills/cursor/harness-containerization/SKILL.md +284 -0
  309. package/dist/agents/skills/cursor/harness-containerization/skill.yaml +80 -0
  310. package/dist/agents/skills/cursor/harness-data-pipeline/SKILL.md +274 -0
  311. package/dist/agents/skills/cursor/harness-data-pipeline/skill.yaml +81 -0
  312. package/dist/agents/skills/cursor/harness-data-validation/SKILL.md +343 -0
  313. package/dist/agents/skills/cursor/harness-data-validation/skill.yaml +75 -0
  314. package/dist/agents/skills/cursor/harness-database/SKILL.md +310 -0
  315. package/dist/agents/skills/cursor/harness-database/skill.yaml +80 -0
  316. package/dist/agents/skills/cursor/harness-debugging/SKILL.md +366 -0
  317. package/dist/agents/skills/cursor/harness-debugging/skill.yaml +48 -0
  318. package/dist/agents/skills/cursor/harness-dependency-health/SKILL.md +179 -0
  319. package/dist/agents/skills/cursor/harness-dependency-health/skill.yaml +42 -0
  320. package/dist/agents/skills/cursor/harness-deployment/SKILL.md +307 -0
  321. package/dist/agents/skills/cursor/harness-deployment/skill.yaml +77 -0
  322. package/dist/agents/skills/cursor/harness-design/SKILL.md +265 -0
  323. package/dist/agents/skills/cursor/harness-design/skill.yaml +54 -0
  324. package/dist/agents/skills/cursor/harness-design-mobile/SKILL.md +336 -0
  325. package/dist/agents/skills/cursor/harness-design-mobile/skill.yaml +50 -0
  326. package/dist/agents/skills/cursor/harness-design-system/SKILL.md +282 -0
  327. package/dist/agents/skills/cursor/harness-design-system/skill.yaml +51 -0
  328. package/dist/agents/skills/cursor/harness-design-web/SKILL.md +360 -0
  329. package/dist/agents/skills/cursor/harness-design-web/skill.yaml +53 -0
  330. package/dist/agents/skills/cursor/harness-diagnostics/SKILL.md +318 -0
  331. package/dist/agents/skills/cursor/harness-diagnostics/skill.yaml +51 -0
  332. package/dist/agents/skills/cursor/harness-docs-pipeline/SKILL.md +460 -0
  333. package/dist/agents/skills/cursor/harness-docs-pipeline/skill.yaml +70 -0
  334. package/dist/agents/skills/cursor/harness-dx/SKILL.md +276 -0
  335. package/dist/agents/skills/cursor/harness-dx/skill.yaml +76 -0
  336. package/dist/agents/skills/cursor/harness-e2e/SKILL.md +245 -0
  337. package/dist/agents/skills/cursor/harness-e2e/skill.yaml +78 -0
  338. package/dist/agents/skills/cursor/harness-event-driven/SKILL.md +280 -0
  339. package/dist/agents/skills/cursor/harness-event-driven/skill.yaml +77 -0
  340. package/dist/agents/skills/cursor/harness-execution/SKILL.md +510 -0
  341. package/dist/agents/skills/cursor/harness-execution/skill.yaml +52 -0
  342. package/dist/agents/skills/cursor/harness-feature-flags/SKILL.md +287 -0
  343. package/dist/agents/skills/cursor/harness-feature-flags/skill.yaml +74 -0
  344. package/dist/agents/skills/cursor/harness-git-workflow/SKILL.md +268 -0
  345. package/dist/agents/skills/cursor/harness-git-workflow/skill.yaml +32 -0
  346. package/dist/agents/skills/cursor/harness-hotspot-detector/SKILL.md +161 -0
  347. package/dist/agents/skills/cursor/harness-hotspot-detector/skill.yaml +45 -0
  348. package/dist/agents/skills/cursor/harness-i18n/SKILL.md +484 -0
  349. package/dist/agents/skills/cursor/harness-i18n/skill.yaml +55 -0
  350. package/dist/agents/skills/cursor/harness-i18n-process/SKILL.md +388 -0
  351. package/dist/agents/skills/cursor/harness-i18n-process/skill.yaml +44 -0
  352. package/dist/agents/skills/cursor/harness-i18n-workflow/SKILL.md +512 -0
  353. package/dist/agents/skills/cursor/harness-i18n-workflow/skill.yaml +54 -0
  354. package/dist/agents/skills/cursor/harness-impact-analysis/SKILL.md +184 -0
  355. package/dist/agents/skills/cursor/harness-impact-analysis/skill.yaml +45 -0
  356. package/dist/agents/skills/cursor/harness-incident-response/SKILL.md +223 -0
  357. package/dist/agents/skills/cursor/harness-incident-response/skill.yaml +78 -0
  358. package/dist/agents/skills/cursor/harness-infrastructure-as-code/SKILL.md +279 -0
  359. package/dist/agents/skills/cursor/harness-infrastructure-as-code/skill.yaml +80 -0
  360. package/dist/agents/skills/cursor/harness-integration-test/SKILL.md +271 -0
  361. package/dist/agents/skills/cursor/harness-integration-test/skill.yaml +73 -0
  362. package/dist/agents/skills/cursor/harness-integrity/SKILL.md +167 -0
  363. package/dist/agents/skills/cursor/harness-integrity/skill.yaml +48 -0
  364. package/dist/agents/skills/cursor/harness-knowledge-mapper/SKILL.md +195 -0
  365. package/dist/agents/skills/cursor/harness-knowledge-mapper/skill.yaml +50 -0
  366. package/dist/agents/skills/cursor/harness-load-testing/SKILL.md +274 -0
  367. package/dist/agents/skills/cursor/harness-load-testing/skill.yaml +79 -0
  368. package/dist/agents/skills/cursor/harness-ml-ops/SKILL.md +341 -0
  369. package/dist/agents/skills/cursor/harness-ml-ops/skill.yaml +79 -0
  370. package/dist/agents/skills/cursor/harness-mobile-patterns/SKILL.md +326 -0
  371. package/dist/agents/skills/cursor/harness-mobile-patterns/skill.yaml +82 -0
  372. package/dist/agents/skills/cursor/harness-mutation-test/SKILL.md +251 -0
  373. package/dist/agents/skills/cursor/harness-mutation-test/skill.yaml +70 -0
  374. package/dist/agents/skills/cursor/harness-observability/SKILL.md +283 -0
  375. package/dist/agents/skills/cursor/harness-observability/skill.yaml +78 -0
  376. package/dist/agents/skills/cursor/harness-onboarding/SKILL.md +288 -0
  377. package/dist/agents/skills/cursor/harness-onboarding/skill.yaml +31 -0
  378. package/dist/agents/skills/cursor/harness-parallel-agents/SKILL.md +256 -0
  379. package/dist/agents/skills/cursor/harness-parallel-agents/skill.yaml +34 -0
  380. package/dist/agents/skills/cursor/harness-perf/SKILL.md +260 -0
  381. package/dist/agents/skills/cursor/harness-perf/skill.yaml +51 -0
  382. package/dist/agents/skills/cursor/harness-perf-tdd/SKILL.md +249 -0
  383. package/dist/agents/skills/cursor/harness-perf-tdd/skill.yaml +48 -0
  384. package/dist/agents/skills/cursor/harness-planning/SKILL.md +579 -0
  385. package/dist/agents/skills/cursor/harness-planning/skill.yaml +56 -0
  386. package/dist/agents/skills/cursor/harness-pre-commit-review/SKILL.md +324 -0
  387. package/dist/agents/skills/cursor/harness-pre-commit-review/skill.yaml +34 -0
  388. package/dist/agents/skills/cursor/harness-product-spec/SKILL.md +285 -0
  389. package/dist/agents/skills/cursor/harness-product-spec/skill.yaml +72 -0
  390. package/dist/agents/skills/cursor/harness-property-test/SKILL.md +281 -0
  391. package/dist/agents/skills/cursor/harness-property-test/skill.yaml +71 -0
  392. package/dist/agents/skills/cursor/harness-refactoring/SKILL.md +169 -0
  393. package/dist/agents/skills/cursor/harness-refactoring/skill.yaml +34 -0
  394. package/dist/agents/skills/cursor/harness-release-readiness/SKILL.md +689 -0
  395. package/dist/agents/skills/cursor/harness-release-readiness/skill.yaml +58 -0
  396. package/dist/agents/skills/cursor/harness-resilience/SKILL.md +255 -0
  397. package/dist/agents/skills/cursor/harness-resilience/skill.yaml +76 -0
  398. package/dist/agents/skills/cursor/harness-roadmap/SKILL.md +595 -0
  399. package/dist/agents/skills/cursor/harness-roadmap/skill.yaml +44 -0
  400. package/dist/agents/skills/cursor/harness-secrets/SKILL.md +293 -0
  401. package/dist/agents/skills/cursor/harness-secrets/skill.yaml +76 -0
  402. package/dist/agents/skills/cursor/harness-security-review/SKILL.md +260 -0
  403. package/dist/agents/skills/cursor/harness-security-review/skill.yaml +53 -0
  404. package/dist/agents/skills/cursor/harness-security-scan/SKILL.md +154 -0
  405. package/dist/agents/skills/cursor/harness-security-scan/skill.yaml +42 -0
  406. package/dist/agents/skills/cursor/harness-skill-authoring/SKILL.md +292 -0
  407. package/dist/agents/skills/cursor/harness-skill-authoring/skill.yaml +33 -0
  408. package/dist/agents/skills/cursor/harness-soundness-review/SKILL.md +1267 -0
  409. package/dist/agents/skills/cursor/harness-soundness-review/skill.yaml +49 -0
  410. package/dist/agents/skills/cursor/harness-sql-review/SKILL.md +315 -0
  411. package/dist/agents/skills/cursor/harness-sql-review/skill.yaml +74 -0
  412. package/dist/agents/skills/cursor/harness-state-management/SKILL.md +309 -0
  413. package/dist/agents/skills/cursor/harness-state-management/skill.yaml +33 -0
  414. package/dist/agents/skills/cursor/harness-supply-chain-audit/SKILL.md +281 -0
  415. package/dist/agents/skills/cursor/harness-supply-chain-audit/skill.yaml +51 -0
  416. package/dist/agents/skills/cursor/harness-tdd/SKILL.md +177 -0
  417. package/dist/agents/skills/cursor/harness-tdd/skill.yaml +49 -0
  418. package/dist/agents/skills/cursor/harness-test-advisor/SKILL.md +160 -0
  419. package/dist/agents/skills/cursor/harness-test-advisor/skill.yaml +45 -0
  420. package/dist/agents/skills/cursor/harness-test-data/SKILL.md +268 -0
  421. package/dist/agents/skills/cursor/harness-test-data/skill.yaml +74 -0
  422. package/dist/agents/skills/cursor/harness-ux-copy/SKILL.md +271 -0
  423. package/dist/agents/skills/cursor/harness-ux-copy/skill.yaml +77 -0
  424. package/dist/agents/skills/cursor/harness-verification/SKILL.md +421 -0
  425. package/dist/agents/skills/cursor/harness-verification/skill.yaml +43 -0
  426. package/dist/agents/skills/cursor/harness-verify/SKILL.md +159 -0
  427. package/dist/agents/skills/cursor/harness-verify/skill.yaml +41 -0
  428. package/dist/agents/skills/cursor/harness-visual-regression/SKILL.md +257 -0
  429. package/dist/agents/skills/cursor/harness-visual-regression/skill.yaml +74 -0
  430. package/dist/agents/skills/cursor/initialize-harness-project/SKILL.md +232 -0
  431. package/dist/agents/skills/cursor/initialize-harness-project/skill.yaml +32 -0
  432. package/dist/agents/skills/cursor/validate-context-engineering/SKILL.md +150 -0
  433. package/dist/agents/skills/cursor/validate-context-engineering/skill.yaml +32 -0
  434. package/dist/agents/skills/gemini-cli/enforce-architecture/SKILL.md +52 -0
  435. package/dist/agents/skills/gemini-cli/harness-api-design/SKILL.md +52 -0
  436. package/dist/agents/skills/gemini-cli/harness-architecture-advisor/SKILL.md +52 -0
  437. package/dist/agents/skills/gemini-cli/harness-auth/SKILL.md +52 -0
  438. package/dist/agents/skills/gemini-cli/harness-autopilot/SKILL.md +355 -45
  439. package/dist/agents/skills/gemini-cli/harness-autopilot/skill.yaml +12 -0
  440. package/dist/agents/skills/gemini-cli/harness-code-review/SKILL.md +97 -3
  441. package/dist/agents/skills/gemini-cli/harness-code-review/skill.yaml +6 -0
  442. package/dist/agents/skills/gemini-cli/harness-codebase-cleanup/SKILL.md +2 -4
  443. package/dist/agents/skills/gemini-cli/harness-database/SKILL.md +52 -0
  444. package/dist/agents/skills/gemini-cli/harness-deployment/SKILL.md +52 -0
  445. package/dist/agents/skills/gemini-cli/harness-planning/SKILL.md +99 -3
  446. package/dist/agents/skills/gemini-cli/harness-planning/skill.yaml +6 -0
  447. package/dist/agents/skills/gemini-cli/harness-pre-commit-review/SKILL.md +1 -1
  448. package/dist/agents/skills/gemini-cli/harness-product-spec/SKILL.md +5 -5
  449. package/dist/agents/skills/gemini-cli/harness-security-review/SKILL.md +27 -7
  450. package/dist/agents/skills/gemini-cli/harness-security-scan/SKILL.md +52 -0
  451. package/dist/agents/skills/gemini-cli/harness-supply-chain-audit/SKILL.md +281 -0
  452. package/dist/agents/skills/gemini-cli/harness-supply-chain-audit/skill.yaml +51 -0
  453. package/dist/agents/skills/package.json +1 -0
  454. package/dist/agents/skills/templates/discipline-template.md +49 -0
  455. package/dist/agents/skills/tests/schema.ts +1 -1
  456. package/dist/agents/skills/vitest.config.mts +5 -0
  457. package/dist/{agents-md-YTYQDA3P.js → agents-md-VYDFPIRW.js} +1 -1
  458. package/dist/{architecture-JQZYM4US.js → architecture-K5HSRBGB.js} +2 -2
  459. package/dist/bin/harness-mcp.js +13 -13
  460. package/dist/bin/harness.js +21 -19
  461. package/dist/{check-phase-gate-L3RADYWO.js → check-phase-gate-5AS6SXL6.js} +3 -3
  462. package/dist/{chunk-6KTUUFRN.js → chunk-5ZXHMCPL.js} +1 -1
  463. package/dist/{chunk-RCWZBSK5.js → chunk-6KWBH4EO.js} +1 -1
  464. package/dist/{chunk-ABQHQ6I5.js → chunk-ALFKNAZW.js} +2436 -233
  465. package/dist/{chunk-OXLLOSSR.js → chunk-AV6KMDO5.js} +2 -2
  466. package/dist/{chunk-7IP4JIFL.js → chunk-C7DTKLPW.js} +4 -4
  467. package/dist/{chunk-ZOAWBDWU.js → chunk-CJDVBBPB.js} +5 -1
  468. package/dist/{chunk-YPYGXRDR.js → chunk-DNDBFIZN.js} +18 -4
  469. package/dist/{chunk-XYLGHKG6.js → chunk-HKUX2X7O.js} +11 -2
  470. package/dist/{chunk-YZD2MRNQ.js → chunk-JOP2NDNB.js} +684 -142
  471. package/dist/{chunk-YBJ262QL.js → chunk-LRG3B43J.js} +1 -1
  472. package/dist/{chunk-AOZRDOIP.js → chunk-M6TIO6NF.js} +1 -1
  473. package/dist/{chunk-O5OJVPL6.js → chunk-OCDDCGDE.js} +9 -1
  474. package/dist/{chunk-OSXBPAMK.js → chunk-QDF7COPQ.js} +1 -1
  475. package/dist/{chunk-TPOTOBR7.js → chunk-RWZPHW4H.js} +3 -3
  476. package/dist/{chunk-3C2MLBPJ.js → chunk-SFRGPAK6.js} +1 -1
  477. package/dist/{chunk-XKECDXJS.js → chunk-SHYWICGA.js} +2184 -456
  478. package/dist/{chunk-S2FXOWOR.js → chunk-TF6ZLHJV.js} +2 -2
  479. package/dist/{chunk-NLVUVUGD.js → chunk-ZJMU7MEV.js} +1 -1
  480. package/dist/{ci-workflow-EQZFVX3P.js → ci-workflow-CRWU723U.js} +1 -1
  481. package/dist/{create-skill-XSWHMSM5.js → create-skill-NDXQSTIK.js} +2 -2
  482. package/dist/{dist-HWXF2C3R.js → dist-4LPXJYVZ.js} +105 -1
  483. package/dist/{docs-7ECGYMAV.js → docs-4JRHTLUZ.js} +3 -3
  484. package/dist/{engine-EG4EH4IX.js → engine-3G3VIM6L.js} +1 -1
  485. package/dist/{entropy-5USWKLVS.js → entropy-G6CZ2A6P.js} +2 -2
  486. package/dist/{feedback-UTBXZZHF.js → feedback-QYKQ65HB.js} +1 -1
  487. package/dist/{generate-agent-definitions-3PM5EU7V.js → generate-agent-definitions-SAAOAPT4.js} +3 -3
  488. package/dist/index.d.ts +25 -4
  489. package/dist/index.js +18 -18
  490. package/dist/{loader-ZPALXIVR.js → loader-VCOK3PF7.js} +1 -1
  491. package/dist/{mcp-362EZHF4.js → mcp-YENEPHBW.js} +13 -13
  492. package/dist/{performance-OQAFMJUD.js → performance-UBCFI2UP.js} +4 -2
  493. package/dist/{review-pipeline-C4GCFVGP.js → review-pipeline-IQAVCWAX.js} +1 -1
  494. package/dist/{runtime-7YLVK453.js → runtime-PYFFIESU.js} +1 -1
  495. package/dist/{security-PZOX7AQS.js → security-ZDADTPYW.js} +1 -1
  496. package/dist/{skill-executor-XZLYZYAK.js → skill-executor-XEVDGXUM.js} +2 -2
  497. package/dist/{validate-FD3Z6VJD.js → validate-VRTUHALQ.js} +2 -2
  498. package/dist/{validate-cross-check-WNJM6H2D.js → validate-cross-check-4Y6NHNK3.js} +1 -1
  499. package/package.json +8 -5
@@ -0,0 +1,513 @@
1
+ <!-- Generated by harness generate-slash-commands. Do not edit. -->
2
+
3
+ # Harness Execution
4
+
5
+ > Execute a plan task by task with atomic commits, checkpoint protocol, and persistent knowledge capture. Stop on blockers. Do not guess.
6
+
7
+ ## When to Use
8
+
9
+ - When an approved plan exists (output of harness-planning) and implementation should begin
10
+ - When resuming execution of a previously started plan after a context reset
11
+ - When `on_new_feature` or `on_bug_fix` triggers fire and a plan is already in place
12
+ - NOT when no plan exists (use harness-planning first)
13
+ - NOT when the plan needs revision (update the plan first, then resume execution)
14
+ - NOT when exploring or brainstorming (use harness-brainstorming)
15
+ - NOT for ad-hoc single-task work that does not follow a plan
16
+
17
+ ## Process
18
+
19
+ ### Iron Law
20
+
21
+ **Execute the plan as written. If the plan is wrong, stop and fix the plan — do not improvise.**
22
+
23
+ Deviating from the plan mid-execution introduces untested assumptions, breaks task atomicity, and makes progress untraceable. If a task cannot be completed as written, that is a blocker. Record it and stop.
24
+
25
+ ---
26
+
27
+ ### Phase 1: PREPARE — Load State and Verify Prerequisites
28
+
29
+ 1. **Load the plan.** Read the plan document from `docs/plans/`. Identify the total task count and any checkpoints.
30
+
31
+ 2. **Gather context in one call.** Use the `gather_context` MCP tool to load all working context at once:
32
+
33
+ ```json
34
+ gather_context({
35
+ path: "<project-root>",
36
+ intent: "Execute plan tasks starting from current position",
37
+ skill: "harness-execution",
38
+ session: "<session-slug-if-known>",
39
+ include: ["state", "learnings", "handoff", "validation"]
40
+ })
41
+ ```
42
+
43
+ **Session resolution:** If a session directory is known (passed via autopilot dispatch or available from a previous handoff), include the `session` parameter. This scopes all state reads/writes to `.harness/sessions/<slug>/`. If no session is known, omit it — `gather_context` falls back to global files at `.harness/`.
44
+
45
+ This returns `state` (current position — if null, this is a fresh start at Task 1), `learnings` (hard-won insights from previous sessions — do not ignore them), `handoff` (structured context from the previous skill), and `validation` (current project health). If any constituent fails, its field is null and the error is reported in `meta.errors`.
46
+
47
+ 3. **Load session summary for cold start.** If resuming a session (session slug is known), read the session summary for quick orientation:
48
+ - Call `listActiveSessions()` to read the session index (~100 tokens).
49
+ - If the target session is known, call `loadSessionSummary()` for that session (~200 tokens).
50
+ - If ambiguous (multiple active sessions, no clear target), present the index to the user and ask which session to resume.
51
+ - The summary provides skill, phase, status, key context, and next step — enough to orient without re-reading full state + learnings + plan.
52
+
53
+ 4. **Check for known dead ends.** Review `learnings` entries tagged `[outcome:failure]`. If any match approaches in the current plan, surface warnings before proceeding.
54
+
55
+ 5. **Verify prerequisites.** For the current task:
56
+ - Are dependency tasks marked complete in state?
57
+ - Do the files referenced in the task exist as expected?
58
+ - Does the test suite pass? Run `harness validate` to confirm a clean baseline.
59
+
60
+ 6. **If prerequisites fail,** do not proceed. Report what is missing and which task is blocked.
61
+
62
+ ### Graph-Enhanced Context (when available)
63
+
64
+ When a knowledge graph exists at `.harness/graph/`, use graph queries for faster, more accurate context:
65
+
66
+ - `query_graph` — check file overlap between current and next task for conflict detection
67
+ - `get_impact` — understand blast radius before executing a task
68
+
69
+ Enables smarter execution ordering and blockage detection. Fall back to file-based commands if no graph is available.
70
+
71
+ ---
72
+
73
+ ### Phase 2: EXECUTE — Implement Tasks Atomically
74
+
75
+ When reporting task progress, use progress markers:
76
+
77
+ ```
78
+ **[Phase N/M]** Task N — <task description>
79
+ ```
80
+
81
+ For each task, starting from the current position:
82
+
83
+ 1. **Read the task instructions completely** before writing any code. Understand what files to touch, what tests to write, what the expected outcome is.
84
+
85
+ 2. **Follow the task instructions exactly.** The plan contains exact file paths, exact code, and exact commands. Execute them as written.
86
+
87
+ 3. **TDD rhythm within each task:**
88
+ - Write the test as specified in the task
89
+ - Run the test — observe it fail (for the right reason)
90
+ - Write the implementation as specified in the task
91
+ - Run the test — observe it pass
92
+ - Run `harness validate`
93
+
94
+ 4. **Commit atomically.** Each task produces exactly one commit. Use the commit message specified in the plan. If no message is specified, write a descriptive message in the project's convention.
95
+
96
+ 5. **Run mechanical gate.** After each task commit, run the full gate check. Use `assess_project` to run harness checks (including lint) in parallel, then run the test suite:
97
+
98
+ ```json
99
+ assess_project({
100
+ path: "<project-root>",
101
+ checks: ["validate", "deps", "lint"],
102
+ mode: "summary"
103
+ })
104
+ ```
105
+
106
+ Then run the project's test suite (`npx turbo run test` or equivalent). This is binary pass/fail.
107
+ - **All pass →** proceed to the next task.
108
+ - **Any fail →** retry with error context (max 2 attempts).
109
+ - **Still failing after retries →** record the failure in `.harness/failures.md`, escalate, and stop.
110
+
111
+ 6. **Update state after each task.** Write to `.harness/state.json`:
112
+
113
+ ```json
114
+ {
115
+ "schemaVersion": 1,
116
+ "position": { "phase": "execute", "task": "Task N" },
117
+ "progress": { "Task 1": "complete", "Task 2": "complete", "Task 3": "in_progress" },
118
+ "lastSession": { "date": "YYYY-MM-DD", "summary": "Completed Tasks 1-2, starting Task 3" }
119
+ }
120
+ ```
121
+
122
+ 7. **Handle checkpoints** according to the checkpoint protocol (see below).
123
+
124
+ ---
125
+
126
+ ### Checkpoint Protocol
127
+
128
+ Plans contain three types of checkpoints. Each requires pausing execution.
129
+
130
+ **`[checkpoint:human-verify]` — Show and Confirm**
131
+
132
+ 1. Stop execution.
133
+ 2. Use `emit_interaction` to present the checkpoint:
134
+ ```json
135
+ emit_interaction({
136
+ path: "<project-root>",
137
+ type: "confirmation",
138
+ confirmation: {
139
+ text: "Task N complete. Output: <summary>. Continue to Task N+1?",
140
+ context: "<test output or file diff summary>",
141
+ impact: "Continuing proceeds to the next task. Declining pauses execution for review.",
142
+ risk: "low"
143
+ }
144
+ })
145
+ ```
146
+ 3. Wait for the human to confirm before proceeding.
147
+
148
+ **`[checkpoint:decision]` — Present Options and Wait**
149
+
150
+ 1. Stop execution.
151
+ 2. Use `emit_interaction` to present the decision:
152
+ ```json
153
+ emit_interaction({
154
+ path: "<project-root>",
155
+ type: "question",
156
+ question: {
157
+ text: "Task N requires a decision: <description>",
158
+ options: [
159
+ {
160
+ label: "<option A>",
161
+ pros: ["<pro 1>", "<pro 2>"],
162
+ cons: ["<con 1>"],
163
+ risk: "low",
164
+ effort: "low"
165
+ },
166
+ {
167
+ label: "<option B>",
168
+ pros: ["<pro 1>"],
169
+ cons: ["<con 1>", "<con 2>"],
170
+ risk: "medium",
171
+ effort: "medium"
172
+ }
173
+ ],
174
+ recommendation: {
175
+ optionIndex: 0,
176
+ reason: "<why this option is recommended>",
177
+ confidence: "medium"
178
+ }
179
+ }
180
+ })
181
+ ```
182
+ 3. Wait for the human to choose.
183
+
184
+ **`[checkpoint:human-action]` — Instruct and Wait**
185
+
186
+ 1. Stop execution.
187
+ 2. Tell the human exactly what they need to do (e.g., "Create an API key at [URL] and paste it here").
188
+ 3. State: "Task N requires your action: [instructions]. Let me know when done."
189
+ 4. Wait for the human to complete the action and confirm.
190
+
191
+ ---
192
+
193
+ ### Phase 3: VERIFY — Two-Tier Validation
194
+
195
+ **Quick gate (default):** The mechanical gate in Phase 2 Step 5 IS the standard verification. Every task commit must pass it before proceeding. No additional verification step is needed for normal execution.
196
+
197
+ **Deep audit (on-demand):** When `--deep` is passed or at milestone boundaries (e.g., end of a phase, final task), invoke the full `harness-verification` skill for 3-level audit:
198
+
199
+ 1. **EXISTS** — Do the artifacts the task claims to produce actually exist?
200
+ 2. **SUBSTANTIVE** — Do those artifacts contain meaningful, correct content (not stubs or placeholders)?
201
+ 3. **WIRED** — Are those artifacts integrated into the system (imported, routed, tested, reachable)?
202
+
203
+ If the deep audit fails at any level, treat it as a blocker. Record it and stop.
204
+
205
+ After all tasks pass verification:
206
+
207
+ ```json
208
+ emit_interaction({
209
+ path: "<project-root>",
210
+ type: "transition",
211
+ transition: {
212
+ completedPhase: "execution",
213
+ suggestedNext: "verification",
214
+ reason: "All plan tasks executed and verified",
215
+ artifacts: ["<list of created/modified files>"],
216
+ qualityGate: {
217
+ checks: [
218
+ { name: "all-tasks-complete", passed: true, detail: "<N>/<N> tasks" },
219
+ { name: "harness-validate", passed: true },
220
+ { name: "tests-pass", passed: true }
221
+ ],
222
+ allPassed: true
223
+ }
224
+ }
225
+ })
226
+ ```
227
+
228
+ ---
229
+
230
+ ### Phase 4: PERSIST — Save Progress and Learnings
231
+
232
+ Between tasks (especially between sessions):
233
+
234
+ 1. **Update state (session-scoped `{sessionDir}/state.json` if session is known, otherwise `.harness/state.json`)** with current position, progress, and `lastSession` context:
235
+
236
+ ```json
237
+ {
238
+ "lastSession": {
239
+ "lastSkill": "harness-execution",
240
+ "pendingTasks": ["Task 4", "Task 5"]
241
+ }
242
+ }
243
+ ```
244
+
245
+ ### Graph Refresh
246
+
247
+ If a knowledge graph exists at `.harness/graph/`, refresh it after code changes to keep graph queries accurate:
248
+
249
+ ```
250
+ harness scan [path]
251
+ ```
252
+
253
+ Skipping this step means subsequent graph queries (impact analysis, dependency health, test advisor) may return stale results.
254
+
255
+ 2. **Append tagged learnings to the session-scoped learnings file (`{sessionDir}/learnings.md` if session is known, otherwise `.harness/learnings.md`).** Tag every entry with skill and outcome:
256
+
257
+ ```markdown
258
+ ## YYYY-MM-DD — Task N: <task name>
259
+
260
+ - [skill:harness-execution] [outcome:success] What was accomplished
261
+ - [skill:harness-execution] [outcome:gotcha] What was surprising or non-obvious
262
+ - [skill:harness-execution] [outcome:decision] What was decided and why
263
+ ```
264
+
265
+ 3. **Record failures in the session-scoped failures file (`{sessionDir}/failures.md` if session is known, otherwise `.harness/failures.md`)** if any task was escalated after retry exhaustion (from Phase 2 Step 5). Include the approach attempted and why it failed, so future sessions avoid the same dead end.
266
+
267
+ 4. **Write the session-scoped handoff (`{sessionDir}/handoff.json` if session is known, otherwise `.harness/handoff.json`)** with structured context for the next skill or session:
268
+
269
+ ```json
270
+ {
271
+ "fromSkill": "harness-execution",
272
+ "timestamp": "YYYY-MM-DDTHH:MM:SSZ",
273
+ "summary": "Completed Tasks 1-3. Task 4 blocked on missing API endpoint.",
274
+ "pendingTasks": ["Task 4", "Task 5"],
275
+ "blockers": ["Task 4: /api/notifications endpoint not implemented"],
276
+ "learnings": ["Date comparison needs UTC normalization"]
277
+ }
278
+ ```
279
+
280
+ 5. **Write session summary.** Write/update the session summary for cold-start context restoration:
281
+
282
+ ```json
283
+ writeSessionSummary(projectPath, sessionSlug, {
284
+ session: "<session-slug>",
285
+ lastActive: "<ISO timestamp>",
286
+ skill: "harness-execution",
287
+ phase: "<current phase of plan>",
288
+ status: "<e.g., Task 4/6 complete, paused at CHECKPOINT>",
289
+ spec: "<spec path if known>",
290
+ plan: "<plan path>",
291
+ keyContext: "<1-2 sentences: what was accomplished, key decisions made>",
292
+ nextStep: "<what to do next when resuming>"
293
+ })
294
+ ```
295
+
296
+ This overwrites any previous summary for this session. The index.md is updated automatically.
297
+
298
+ 6. **Sync roadmap (mandatory when present).** If `docs/roadmap.md` exists, call `manage_roadmap` with action `sync` and `apply: true` to update linked feature statuses from the just-completed execution state. Do not use `force_sync: true` — the human-always-wins rule applies. If `manage_roadmap` is unavailable, fall back to direct file manipulation using `syncRoadmap()` from core. If no roadmap exists, skip silently.
299
+
300
+ 7. **Learnings are append-only.** Never edit or delete previous learnings. They are a chronological record.
301
+
302
+ 8. **Auto-transition to verification.** When ALL tasks in the plan are complete (not when stopping mid-plan):
303
+
304
+ Call `emit_interaction`:
305
+
306
+ ```json
307
+ {
308
+ "type": "transition",
309
+ "transition": {
310
+ "completedPhase": "execution",
311
+ "suggestedNext": "verification",
312
+ "reason": "All tasks complete",
313
+ "artifacts": ["<list of created/modified files>"],
314
+ "requiresConfirmation": false,
315
+ "summary": "Completed <N> tasks. <N> files created, <N> modified. All quick gates passed.",
316
+ "qualityGate": {
317
+ "checks": [
318
+ { "name": "all-tasks-complete", "passed": true, "detail": "<N>/<N> tasks" },
319
+ { "name": "harness-validate", "passed": true },
320
+ { "name": "tests-pass", "passed": true },
321
+ { "name": "no-blockers", "passed": true }
322
+ ],
323
+ "allPassed": true
324
+ }
325
+ }
326
+ }
327
+ ```
328
+
329
+ The response will include `nextAction: "Invoke harness-verification skill now"`.
330
+ Immediately invoke harness-verification without waiting for user input.
331
+
332
+ **Important:** Only emit this transition when all tasks are complete. If execution stopped due to a blocker, checkpoint, or partial completion, do NOT emit a transition -- write the handoff and stop.
333
+
334
+ ---
335
+
336
+ ### Stopping Conditions
337
+
338
+ These are non-negotiable. When any condition is met, stop immediately.
339
+
340
+ - **Hit a blocker.** The task cannot be completed as written. Something is missing, broken, or wrong. Do not guess at a fix. Do not improvise. Record the blocker in state and report it: "Blocked on Task N: [specific issue]. The plan needs to be updated."
341
+
342
+ - **Test failure after implementation.** The test was supposed to pass but does not. Do not retry blindly. Read the failure. Diagnose the root cause. If the fix is within the current task scope, fix it. If not, stop — the plan may be wrong.
343
+
344
+ - **Unclear instruction.** The task says something ambiguous or contradictory. Do not interpret it. Ask: "Task N says [quote]. I interpret this as [interpretation]. Is that correct?"
345
+
346
+ - **Harness validation failure.** `harness validate` fails after a task. Do not proceed. The task introduced an architectural violation or constraint breach. Fix it before moving on.
347
+
348
+ - **Three consecutive failures on the same task.** After 3 attempts, the task design is likely wrong. Stop. Report: "Task N has failed 3 times. Root cause: [analysis]. The plan may need revision."
349
+
350
+ ## Session State
351
+
352
+ This skill reads and writes to the following session sections via `manage_state`:
353
+
354
+ | Section | Read | Write | Purpose |
355
+ | ------------- | ---- | ----- | ------------------------------------------------------------------------------------- |
356
+ | terminology | yes | yes | Reads domain terms for consistent naming; adds terms discovered during implementation |
357
+ | decisions | yes | yes | Reads planning decisions for context; records implementation decisions |
358
+ | constraints | yes | yes | Reads constraints to respect boundaries; adds constraints discovered during coding |
359
+ | risks | yes | yes | Reads risks for awareness; updates risk status as mitigated or realized |
360
+ | openQuestions | yes | yes | Reads questions for context; resolves questions answered by implementation |
361
+ | evidence | yes | yes | Reads prior evidence; writes file:line citations, test outputs, and diff references |
362
+
363
+ **When to write:** After each task completion, append relevant entries. Evidence entries should be written for every significant technical assertion (test result, file reference, performance measurement). Mark openQuestions as resolved when implementation answers them.
364
+
365
+ **When to read:** During Phase 1 (PREPARE), read all sections via `gather_context` with `include: ["sessions"]` to inherit full accumulated context from brainstorming and planning.
366
+
367
+ ## Evidence Requirements
368
+
369
+ When this skill makes claims about task completion, test results, or code behavior, it MUST cite evidence using one of:
370
+
371
+ 1. **File reference:** `file:line` format (e.g., `src/services/notification-service.ts:42` -- "create method implemented with validation")
372
+ 2. **Test output:** Include the actual test command and its output:
373
+ ```
374
+ $ npx vitest run src/services/notification-service.test.ts
375
+ PASS src/services/notification-service.test.ts (8 tests)
376
+ ```
377
+ 3. **Diff evidence:** Before/after with file path for modifications to existing files
378
+ 4. **Harness output:** Include `harness validate` output as evidence of project health
379
+ 5. **Session evidence:** Write to the `evidence` session section after each task:
380
+ ```json
381
+ manage_state({
382
+ action: "append_entry",
383
+ session: "<current-session>",
384
+ section: "evidence",
385
+ authorSkill: "harness-execution",
386
+ content: "src/services/notification-service.ts:42 -- create method returns Notification with all required fields"
387
+ })
388
+ ```
389
+
390
+ **When to cite:** After every task completion in Phase 2 (EXECUTE). Every commit message claim ("added X", "fixed Y") must be backed by test output or file reference. During Phase 4 (PERSIST) when writing learnings that reference specific code behavior.
391
+
392
+ **Uncited claims:** Technical assertions without citations MUST be prefixed with `[UNVERIFIED]`. Example: `[UNVERIFIED] The notification service handles duplicate entries`. Uncited claims are flagged during review (Wave 2.2).
393
+
394
+ ## Harness Integration
395
+
396
+ - **`harness validate`** — Run after every task completion. Mandatory. No task is complete without a passing validation.
397
+ - **`gather_context`** — Used in PREPARE phase to load state, learnings, handoff, and validation in a single call instead of 4+ separate reads.
398
+ - **`harness check-deps`** — Run when tasks add new imports or modules. Catches boundary violations early.
399
+ - **`harness state show`** — View current execution position and progress.
400
+ - **`harness state learn "<message>"`** — Append a learning from the command line.
401
+ - **State file** — Session-scoped at `{sessionDir}/state.json` when session is known, otherwise `.harness/state.json`. Read at session start to resume position. Updated after every task.
402
+ - **Learnings file** — Session-scoped at `{sessionDir}/learnings.md` when session is known, otherwise `.harness/learnings.md`. Append-only knowledge capture. Read at session start for prior context.
403
+ - **Roadmap sync** — After completing plan execution, call `manage_roadmap` with action `sync` and `apply: true` to update roadmap status. Mandatory when `docs/roadmap.md` exists. Do not use `force_sync: true`. Falls back to `syncRoadmap()` from core if MCP tool is unavailable.
404
+ - **`emit_interaction`** -- Call at plan completion to auto-transition to harness-verification. Uses auto-transition (proceeds immediately without user confirmation).
405
+
406
+ ## Success Criteria
407
+
408
+ - Every task in the plan is executed in order, atomically, with one commit per task
409
+ - `.harness/state.json` accurately reflects current position and progress
410
+ - `.harness/learnings.md` contains entries for every session with non-trivial discoveries
411
+ - `harness validate` passes after every task
412
+ - Checkpoints were honored: execution paused at every `[checkpoint:*]` marker
413
+ - No improvisation: tasks were executed as written, or execution was stopped and the blocker was reported
414
+ - All stopping conditions were respected (no guessing past blockers, no blind retries)
415
+
416
+ ## Examples
417
+
418
+ ### Example: Executing a 5-Task Notification Plan
419
+
420
+ **Session Start (fresh):**
421
+
422
+ ```
423
+ Read plan: docs/plans/2026-03-14-notifications-plan.md (5 tasks)
424
+ Read state: .harness/state.json — file not found (fresh start, position: Task 1)
425
+ Read learnings: .harness/learnings.md — file not found (no prior context)
426
+ Run: harness validate — passes. Clean baseline confirmed.
427
+ ```
428
+
429
+ **Task 1: Define notification types**
430
+
431
+ ```
432
+ 1. Create src/types/notification.ts with Notification interface
433
+ 2. Run: harness validate — passes
434
+ 3. Commit: "feat(notifications): define Notification type"
435
+ 4. Update state: { position: Task 2, progress: { "Task 1": "complete" } }
436
+ ```
437
+
438
+ **Task 2: Create notification service (TDD)**
439
+
440
+ ```
441
+ 1. Write test: src/services/notification-service.test.ts
442
+ 2. Run test: FAIL — NotificationService is not defined (correct failure)
443
+ 3. Implement: src/services/notification-service.ts
444
+ 4. Run test: PASS
445
+ 5. Run: harness validate — passes
446
+ 6. Commit: "feat(notifications): add NotificationService.create"
447
+ 7. Update state: { position: Task 3, progress: { "Task 1": "complete", "Task 2": "complete" } }
448
+ ```
449
+
450
+ **Task 3: Add list and expiry (TDD) — has checkpoint**
451
+
452
+ ```
453
+ [checkpoint:human-verify] — "Tasks 1-2 complete. NotificationService can create
454
+ notifications. Tests pass. Continue to Task 3 (list and expiry methods)?"
455
+ Human: "Continue."
456
+
457
+ 1. Write tests: list by userId, filter expired
458
+ 2. Run tests: FAIL (methods not implemented)
459
+ 3. Implement list() and isExpired()
460
+ 4. Run tests: PASS
461
+ 5. Run: harness validate — passes
462
+ 6. Commit: "feat(notifications): add list and expiry to NotificationService"
463
+ 7. Update state, append learning:
464
+ "## 2026-03-14 — Task 3: list and expiry
465
+ - [gotcha]: Date comparison needed UTC normalization — used Date.now() not new Date()"
466
+ ```
467
+
468
+ **Context reset mid-plan (resume at Task 4):**
469
+
470
+ ```
471
+ Read plan: docs/plans/2026-03-14-notifications-plan.md
472
+ Read state: .harness/state.json — position: Task 4, Tasks 1-3 complete
473
+ Read learnings: .harness/learnings.md — "Date comparison needed UTC normalization"
474
+ Run: harness validate — passes. Resume from Task 4.
475
+ ```
476
+
477
+ ## Gates
478
+
479
+ These are hard stops. Violating any gate means the process has broken down.
480
+
481
+ - **No execution without a plan.** If no plan document exists, do not start. Use harness-planning to create one.
482
+ - **No improvisation.** Execute the plan as written. If the plan says "create file X with code Y," create file X with code Y. Do not add "improvements" or "optimizations" that are not in the plan.
483
+ - **No skipping tasks.** Tasks are ordered by dependency. Skipping a task means later tasks may fail. Execute in order.
484
+ - **No skipping validation.** `harness validate` runs after every task. No exceptions. A task that passes its tests but fails validation is not complete.
485
+ - **No ignoring checkpoints.** If a task has a `[checkpoint:*]` marker, execution must pause. Do not auto-continue past checkpoints.
486
+ - **No guessing past blockers.** If a task cannot be completed as written, stop. Report the blocker. Do not invent a workaround.
487
+ - **State must be updated.** After every task, `.harness/state.json` must reflect the new position. Skipping state updates makes resume impossible.
488
+
489
+ ## Escalation
490
+
491
+ - **When a task fails and the fix is outside task scope:** Report: "Task N failed because [reason]. The fix requires changes to [files/tasks outside scope]. The plan needs to be updated at Tasks [X, Y] before I can continue."
492
+ - **When the plan references files that do not exist:** The plan is out of date or was written against a different branch. Report: "Task N references [file] which does not exist. Plan may need regeneration."
493
+ - **When tests pass but behavior seems wrong:** Do not ignore your instinct, but also do not act on it unilaterally. Report: "Task N passes all tests, but I notice [observation]. Should I investigate before proceeding?"
494
+ - **When state is corrupted or inconsistent:** If `.harness/state.json` says Task 5 is complete but the code for Task 5 does not exist, the state is wrong. Report the inconsistency. Do not trust corrupted state — re-verify from Task 1 if needed.
495
+ - **When the human wants to skip ahead:** Explain the risk: "Skipping Task N means Tasks [X, Y] that depend on it may fail. If you want to skip, we should update the plan to remove the dependency." Get explicit approval before skipping.
496
+
497
+ ## Trace Output (Optional)
498
+
499
+ When `.harness/gate.json` has `"trace": true` or `--verbose` is passed, append one-sentence reasoning at each phase boundary to `.harness/trace.md`.
500
+
501
+ **Format:** `**[PHASE HH:MM:SS]** summary`
502
+
503
+ Example:
504
+
505
+ ```markdown
506
+ **[PREPARE 14:32:07]** Loaded plan with 5 tasks, resuming from Task 3 per state.json.
507
+ **[EXECUTE 14:32:15]** Task 3 committed; mechanical gate passed on first attempt.
508
+ **[VERIFY 14:35:42]** Deep audit requested at milestone; all 3 levels passed.
509
+ **[PERSIST 14:35:50]** State updated, handoff.json written with 2 pending tasks.
510
+ ```
511
+
512
+ This is for human debugging only. Not required for normal execution.
513
+
@@ -0,0 +1,3 @@
1
+ # Reserved for Phase B native integration
2
+ name: harness-execution
3
+ version: "1.0.0"
@@ -0,0 +1,164 @@
1
+ <!-- Generated by harness generate-slash-commands. Do not edit. -->
2
+
3
+ # Harness Hotspot Detector
4
+
5
+ > Identify modules that represent structural risk via co-change and churn analysis.
6
+
7
+ ## When to Use
8
+
9
+ - Weekly scheduled analysis to track codebase risk
10
+ - Before major refactoring — find the riskiest areas
11
+ - When investigating why changes keep breaking unrelated features
12
+ - NOT for finding dead code (use cleanup-dead-code)
13
+ - NOT for checking architecture rules (use enforce-architecture)
14
+
15
+ ## Prerequisites
16
+
17
+ A knowledge graph at `.harness/graph/` with git history enables full analysis. If no graph exists,
18
+ the skill uses static analysis fallbacks (see Graph Availability section).
19
+ Run `harness scan` to enable graph-enhanced analysis.
20
+
21
+ ### Graph Availability
22
+
23
+ Before starting, check if `.harness/graph/graph.json` exists.
24
+
25
+ **If graph exists:** Use graph tools as primary strategy. (Staleness sensitivity: **Low** — never auto-refresh.
26
+ Git-based churn data in the graph remains useful even when slightly stale.)
27
+
28
+ **If graph exists and is fresh (or refreshed):** Use graph tools as primary strategy.
29
+
30
+ **If no graph exists:** Output "Running without graph (run `harness scan` to
31
+ enable full analysis)" and use fallback strategies for all subsequent steps.
32
+
33
+ ## Process
34
+
35
+ ### Phase 1: CO-CHANGE — Analyze Co-Change Patterns
36
+
37
+ Query the graph for `co_changes_with` edges (created by GitIngestor):
38
+
39
+ ```
40
+ query_graph(rootNodeIds=[all file nodes], includeEdges=["co_changes_with"])
41
+ ```
42
+
43
+ Identify file pairs that frequently change together:
44
+
45
+ - **Co-located pairs** (same directory): Normal — they share a concern.
46
+ - **Distant pairs** (different modules): Suspicious — may indicate hidden coupling.
47
+
48
+ Flag distant co-change pairs as potential hotspots.
49
+
50
+ ### Phase 2: CHURN — Identify High-Churn Files
51
+
52
+ Query commit nodes to find files with the highest change frequency:
53
+
54
+ ```
55
+ query_graph(rootNodeIds=[commit nodes], includeTypes=["commit", "file"], includeEdges=["co_changes_with"])
56
+ ```
57
+
58
+ Rank files by:
59
+
60
+ - Total commit count touching the file
61
+ - Recent velocity (commits in last 30 days vs prior 30 days)
62
+ - Change size (total lines added + deleted)
63
+
64
+ High churn in shared utilities or core modules = high risk.
65
+
66
+ #### Fallback (without graph)
67
+
68
+ When no graph is available, git log provides nearly all the data needed (~90% completeness):
69
+
70
+ 1. **Per-file churn**: `git log --format="%H" -- <file>` for each source file (use glob to enumerate). Count commits per file. Sort descending to rank by churn.
71
+ 2. **Recent velocity**: `git log --since="30 days ago" --format="%H" -- <file>` vs `git log --since="60 days ago" --until="30 days ago" --format="%H" -- <file>` to compare recent vs prior 30-day windows.
72
+ 3. **Co-change detection**: `git log --format="%H %n" --name-only` to build a map of which files changed together in the same commit. File pairs that appear together in >3 commits are co-change candidates.
73
+ 4. **Distant co-change identification**: For co-change pairs, check if they share a parent directory (co-located = normal) or are in different modules (distant = suspicious).
74
+ 5. **Complexity proxy**: Use line count (`wc -l`) as a rough proxy for complexity when graph complexity metrics are unavailable.
75
+ 6. **Hidden dependency detection**: Cross-reference co-change pairs against import parsing (grep for import statements). Co-change pairs with no import relationship indicate hidden dependencies.
76
+
77
+ > Fallback completeness: ~90% — git log provides nearly all the data the graph stores for this use case.
78
+
79
+ ### Phase 3: COUPLING — Detect Hidden Dependencies
80
+
81
+ Cross-reference co-change data with structural data:
82
+
83
+ 1. **High logical coupling, low structural coupling**: Files that always change together but have no `imports` edge between them. This indicates a hidden dependency — changing one requires changing the other, but the code doesn't express this relationship.
84
+
85
+ 2. **High structural coupling, low logical coupling**: Files with `imports` edges but that rarely change together. This may indicate over-coupling — the import exists but the relationship is weak.
86
+
87
+ Use `get_relationships` to check structural edges between co-change pairs.
88
+
89
+ ### Phase 4: REPORT — Generate Ranked Hotspot Report
90
+
91
+ ```
92
+ ## Hotspot Analysis Report
93
+
94
+ ### Risk Hotspots (ranked by risk score)
95
+
96
+ 1. **src/services/billing.ts** — Risk: HIGH
97
+ - Churn: 23 commits (last 30 days: 8)
98
+ - Co-changes with: src/types/invoice.ts (distant, 15 co-changes)
99
+ - Hidden dependency: no imports edge to invoice.ts
100
+ - Recommendation: Extract shared billing types or add explicit dependency
101
+
102
+ 2. **src/utils/helpers.ts** — Risk: HIGH
103
+ - Churn: 45 commits (highest in codebase)
104
+ - Co-changes with: 12 different files across 4 modules
105
+ - Recommendation: Split into domain-specific utilities to reduce blast radius
106
+
107
+ 3. **src/middleware/auth.ts** — Risk: MEDIUM
108
+ - Churn: 15 commits
109
+ - Co-changes with: src/routes/login.ts (co-located, expected)
110
+ - No hidden dependencies detected
111
+
112
+ ### Summary
113
+ - Total hotspots detected: 5
114
+ - High risk: 2
115
+ - Medium risk: 3
116
+ - Hidden dependencies: 1
117
+ ```
118
+
119
+ ## Harness Integration
120
+
121
+ - **`harness scan`** — Recommended before this skill for full graph-enhanced analysis. If graph is missing, skill uses git log fallbacks.
122
+ - **`harness validate`** — Run after acting on findings to verify project health.
123
+ - **Graph tools** — This skill uses `query_graph`, `get_impact`, and `get_relationships` MCP tools.
124
+
125
+ ## Success Criteria
126
+
127
+ - Hotspots ranked by composite risk score (churn + coupling)
128
+ - Hidden dependencies identified (high co-change, no structural edge)
129
+ - Co-change patterns detected and classified (co-located vs distant)
130
+ - Report follows the structured output format
131
+ - All findings are backed by graph query evidence (with graph) or git log analysis (without graph)
132
+
133
+ ## Examples
134
+
135
+ ### Example: Detecting Hotspots in a Growing Codebase
136
+
137
+ ```
138
+ Input: Scheduled weekly analysis on project root
139
+
140
+ 1. CO-CHANGE — query_graph for co_changes_with edges
141
+ Found 4 distant co-change pairs
142
+ 2. CHURN — Ranked files by commit frequency
143
+ billing.ts: 23 commits, helpers.ts: 45 commits
144
+ 3. COUPLING — Cross-referenced co-change vs imports edges
145
+ billing.ts <-> invoice.ts: 15 co-changes, no imports edge
146
+ (hidden dependency detected)
147
+ 4. REPORT — Ranked hotspots by risk score
148
+
149
+ Output:
150
+ Hotspots: 5 total (2 high, 3 medium)
151
+ Hidden dependencies: 1 (billing.ts <-> invoice.ts)
152
+ Top recommendation: Extract shared billing types
153
+ ```
154
+
155
+ ## Gates
156
+
157
+ - **Graph preferred, fallback available.** If no graph exists, use git log for churn and co-change analysis. Do not stop — git log provides ~90% of the data needed.
158
+ - **Systematic analysis required.** Use graph `co_changes_with` edges when available; use `git log` commit analysis when not. Do not guess — parse actual git history.
159
+
160
+ ## Escalation
161
+
162
+ - **When hidden dependencies found**: Recommend making the dependency explicit (add import) or extracting shared code.
163
+ - **When a single file has >30 commits**: Flag as critical hotspot requiring architectural attention.
164
+