sdd-agent-platform 0.4.2 → 0.5.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 (826) hide show
  1. package/README.md +33 -39
  2. package/node_modules/@sdd-agent-platform/core/dist/ai-tools.js +56 -73
  3. package/node_modules/@sdd-agent-platform/core/dist/ai-tools.js.map +1 -1
  4. package/node_modules/@sdd-agent-platform/core/dist/artifacts/ingestion.js +9 -64
  5. package/node_modules/@sdd-agent-platform/core/dist/artifacts/ingestion.js.map +1 -1
  6. package/node_modules/@sdd-agent-platform/core/dist/artifacts/sdd-evidence.js +1 -0
  7. package/node_modules/@sdd-agent-platform/core/dist/artifacts/sdd-evidence.js.map +1 -1
  8. package/node_modules/@sdd-agent-platform/core/dist/artifacts/sdd-result.js +17 -26
  9. package/node_modules/@sdd-agent-platform/core/dist/artifacts/sdd-result.js.map +1 -1
  10. package/node_modules/@sdd-agent-platform/core/dist/config/init-project.d.ts +8 -7
  11. package/node_modules/@sdd-agent-platform/core/dist/config/init-project.js +8 -12
  12. package/node_modules/@sdd-agent-platform/core/dist/config/init-project.js.map +1 -1
  13. package/node_modules/@sdd-agent-platform/core/dist/config/project-config.d.ts +1 -1
  14. package/node_modules/@sdd-agent-platform/core/dist/config/project-config.js +1 -1
  15. package/node_modules/@sdd-agent-platform/core/dist/config/project-config.js.map +1 -1
  16. package/node_modules/@sdd-agent-platform/core/dist/config/starter-documents.d.ts +3 -4
  17. package/node_modules/@sdd-agent-platform/core/dist/config/starter-documents.js +377 -411
  18. package/node_modules/@sdd-agent-platform/core/dist/config/starter-documents.js.map +1 -1
  19. package/node_modules/@sdd-agent-platform/core/dist/context/build-package.d.ts +1 -1
  20. package/node_modules/@sdd-agent-platform/core/dist/context/build-package.js +7 -13
  21. package/node_modules/@sdd-agent-platform/core/dist/context/build-package.js.map +1 -1
  22. package/node_modules/@sdd-agent-platform/core/dist/context/evidence-summary.js +8 -26
  23. package/node_modules/@sdd-agent-platform/core/dist/context/evidence-summary.js.map +1 -1
  24. package/node_modules/@sdd-agent-platform/core/dist/context/log-worker.js +2 -2
  25. package/node_modules/@sdd-agent-platform/core/dist/context/log-worker.js.map +1 -1
  26. package/node_modules/@sdd-agent-platform/core/dist/context-offload/contracts.d.ts +1 -1
  27. package/node_modules/@sdd-agent-platform/core/dist/contracts.d.ts +6 -1
  28. package/node_modules/@sdd-agent-platform/core/dist/contracts.js +5 -0
  29. package/node_modules/@sdd-agent-platform/core/dist/contracts.js.map +1 -1
  30. package/node_modules/@sdd-agent-platform/core/dist/delegation/model.d.ts +0 -3
  31. package/node_modules/@sdd-agent-platform/core/dist/delegation/validation.d.ts +0 -3
  32. package/node_modules/@sdd-agent-platform/core/dist/delegation/validation.js +4 -7
  33. package/node_modules/@sdd-agent-platform/core/dist/delegation/validation.js.map +1 -1
  34. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/document-chain.js +3 -13
  35. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/document-chain.js.map +1 -1
  36. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/project.js +8 -8
  37. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/project.js.map +1 -1
  38. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/registries.js +1 -0
  39. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/registries.js.map +1 -1
  40. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/run-evidence.js +4 -4
  41. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/run-evidence.js.map +1 -1
  42. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/run-trust.js +24 -0
  43. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/run-trust.js.map +1 -1
  44. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/runtime-contracts.js +1 -1
  45. package/node_modules/@sdd-agent-platform/core/dist/doctor/checks/runtime-contracts.js.map +1 -1
  46. package/node_modules/@sdd-agent-platform/core/dist/doctor/doctor.js +43 -180
  47. package/node_modules/@sdd-agent-platform/core/dist/doctor/doctor.js.map +1 -1
  48. package/node_modules/@sdd-agent-platform/core/dist/evidence/lookup.d.ts +1 -1
  49. package/node_modules/@sdd-agent-platform/core/dist/evidence/lookup.js +7 -14
  50. package/node_modules/@sdd-agent-platform/core/dist/evidence/lookup.js.map +1 -1
  51. package/node_modules/@sdd-agent-platform/core/dist/evidence-runtime/coordination.js +110 -0
  52. package/node_modules/@sdd-agent-platform/core/dist/evidence-runtime/coordination.js.map +1 -0
  53. package/node_modules/@sdd-agent-platform/core/dist/execution/background-executor.js +4 -4
  54. package/node_modules/@sdd-agent-platform/core/dist/execution/background-executor.js.map +1 -1
  55. package/node_modules/@sdd-agent-platform/core/dist/execution/foreground-subagents.js +3 -3
  56. package/node_modules/@sdd-agent-platform/core/dist/execution/foreground-subagents.js.map +1 -1
  57. package/node_modules/@sdd-agent-platform/core/dist/execution/host-invocation.js +85 -86
  58. package/node_modules/@sdd-agent-platform/core/dist/execution/host-invocation.js.map +1 -1
  59. package/node_modules/@sdd-agent-platform/core/dist/execution/resident-worker.js +2 -3
  60. package/node_modules/@sdd-agent-platform/core/dist/execution/resident-worker.js.map +1 -1
  61. package/node_modules/@sdd-agent-platform/core/dist/execution/stage-team-runtime.js +2 -2
  62. package/node_modules/@sdd-agent-platform/core/dist/execution/stage-team-runtime.js.map +1 -1
  63. package/node_modules/@sdd-agent-platform/core/dist/governance/policy.d.ts +1 -1
  64. package/node_modules/@sdd-agent-platform/core/dist/governance/policy.js +1 -1
  65. package/node_modules/@sdd-agent-platform/core/dist/governance/policy.js.map +1 -1
  66. package/node_modules/@sdd-agent-platform/core/dist/instructions.d.ts +1 -1
  67. package/node_modules/@sdd-agent-platform/core/dist/instructions.js +31 -67
  68. package/node_modules/@sdd-agent-platform/core/dist/instructions.js.map +1 -1
  69. package/node_modules/@sdd-agent-platform/core/dist/lifecycle/decision-gate.js +1 -1
  70. package/node_modules/@sdd-agent-platform/core/dist/lifecycle/decision-gate.js.map +1 -1
  71. package/node_modules/@sdd-agent-platform/core/dist/lifecycle/ship.d.ts +0 -1
  72. package/node_modules/@sdd-agent-platform/core/dist/lifecycle/ship.js +59 -85
  73. package/node_modules/@sdd-agent-platform/core/dist/lifecycle/ship.js.map +1 -1
  74. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph/contracts.d.ts +159 -0
  75. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph/contracts.js +7 -0
  76. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph/contracts.js.map +1 -0
  77. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph/kernel.d.ts +16 -0
  78. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph/kernel.js +461 -0
  79. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph/kernel.js.map +1 -0
  80. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph.d.ts +2 -0
  81. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph.js +3 -0
  82. package/node_modules/@sdd-agent-platform/core/dist/lifecycle-graph.js.map +1 -0
  83. package/node_modules/@sdd-agent-platform/core/dist/orchestration/contracts.d.ts +1 -1
  84. package/node_modules/@sdd-agent-platform/core/dist/orchestration/runtime.d.ts +2 -12
  85. package/node_modules/@sdd-agent-platform/core/dist/orchestration/runtime.js +32 -80
  86. package/node_modules/@sdd-agent-platform/core/dist/orchestration/runtime.js.map +1 -1
  87. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-capability-catalog.d.ts +2 -5
  88. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-capability-catalog.js +27 -69
  89. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-capability-catalog.js.map +1 -1
  90. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-registry.js +118 -34
  91. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-registry.js.map +1 -1
  92. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-runtime-static.js +1 -1
  93. package/node_modules/@sdd-agent-platform/core/dist/registries/agent-runtime-static.js.map +1 -1
  94. package/node_modules/@sdd-agent-platform/core/dist/registries/capability-sources.js +1 -1
  95. package/node_modules/@sdd-agent-platform/core/dist/registries/command-team-runtime.d.ts +1 -1
  96. package/node_modules/@sdd-agent-platform/core/dist/registries/command-team-runtime.js +8 -15
  97. package/node_modules/@sdd-agent-platform/core/dist/registries/command-team-runtime.js.map +1 -1
  98. package/node_modules/@sdd-agent-platform/core/dist/registries/eval-learning-context.js +4 -4
  99. package/node_modules/@sdd-agent-platform/core/dist/registries/eval-learning-context.js.map +1 -1
  100. package/node_modules/@sdd-agent-platform/core/dist/registries/plan-scout-domains.d.ts +13 -0
  101. package/node_modules/@sdd-agent-platform/core/dist/registries/plan-scout-domains.js +76 -0
  102. package/node_modules/@sdd-agent-platform/core/dist/registries/plan-scout-domains.js.map +1 -0
  103. package/node_modules/@sdd-agent-platform/core/dist/registries/query-status.js +2 -2
  104. package/node_modules/@sdd-agent-platform/core/dist/registries/query-status.js.map +1 -1
  105. package/node_modules/@sdd-agent-platform/core/dist/registries/skill-capabilities.js +7 -7
  106. package/node_modules/@sdd-agent-platform/core/dist/registries/skill-capabilities.js.map +1 -1
  107. package/node_modules/@sdd-agent-platform/core/dist/registries/tool-capabilities.js +4 -4
  108. package/node_modules/@sdd-agent-platform/core/dist/registries/tool-capabilities.js.map +1 -1
  109. package/node_modules/@sdd-agent-platform/core/dist/registries/tool-plugins.js +2 -2
  110. package/node_modules/@sdd-agent-platform/core/dist/registries/tool-plugins.js.map +1 -1
  111. package/node_modules/@sdd-agent-platform/core/dist/registries/worker-adapters.js +11 -11
  112. package/node_modules/@sdd-agent-platform/core/dist/registries/worker-adapters.js.map +1 -1
  113. package/node_modules/@sdd-agent-platform/core/dist/registries/workflow-gates.d.ts +1 -1
  114. package/node_modules/@sdd-agent-platform/core/dist/registries/workflow-gates.js +21 -21
  115. package/node_modules/@sdd-agent-platform/core/dist/registries/workflow-gates.js.map +1 -1
  116. package/node_modules/@sdd-agent-platform/core/dist/risk/consumer-diagnostics.js +2 -1
  117. package/node_modules/@sdd-agent-platform/core/dist/risk/consumer-diagnostics.js.map +1 -1
  118. package/node_modules/@sdd-agent-platform/core/dist/risk/kernel.js +6 -6
  119. package/node_modules/@sdd-agent-platform/core/dist/risk/kernel.js.map +1 -1
  120. package/node_modules/@sdd-agent-platform/core/dist/risk/legacy-adapters.js +11 -23
  121. package/node_modules/@sdd-agent-platform/core/dist/risk/legacy-adapters.js.map +1 -1
  122. package/node_modules/@sdd-agent-platform/core/dist/risk/workflow-gates.d.ts +2 -2
  123. package/node_modules/@sdd-agent-platform/core/dist/risk/workflow-gates.js +18 -20
  124. package/node_modules/@sdd-agent-platform/core/dist/risk/workflow-gates.js.map +1 -1
  125. package/node_modules/@sdd-agent-platform/core/dist/router/agent-runtime.d.ts +0 -2
  126. package/node_modules/@sdd-agent-platform/core/dist/router/route-projection.js +1 -1
  127. package/node_modules/@sdd-agent-platform/core/dist/router/route-projection.js.map +1 -1
  128. package/node_modules/@sdd-agent-platform/core/dist/router/routing.js +16 -48
  129. package/node_modules/@sdd-agent-platform/core/dist/router/routing.js.map +1 -1
  130. package/node_modules/@sdd-agent-platform/core/dist/router/runtime-import.js +11 -1
  131. package/node_modules/@sdd-agent-platform/core/dist/router/runtime-import.js.map +1 -1
  132. package/node_modules/@sdd-agent-platform/core/dist/router/runtime-validation.js +2 -2
  133. package/node_modules/@sdd-agent-platform/core/dist/router/runtime-validation.js.map +1 -1
  134. package/node_modules/@sdd-agent-platform/core/dist/router/stage-route-binding.d.ts +2 -2
  135. package/node_modules/@sdd-agent-platform/core/dist/router/stage-route-binding.js +20 -28
  136. package/node_modules/@sdd-agent-platform/core/dist/router/stage-route-binding.js.map +1 -1
  137. package/node_modules/@sdd-agent-platform/core/dist/router.d.ts +0 -1
  138. package/node_modules/@sdd-agent-platform/core/dist/router.js +0 -1
  139. package/node_modules/@sdd-agent-platform/core/dist/router.js.map +1 -1
  140. package/node_modules/@sdd-agent-platform/core/dist/run-state/artifacts.d.ts +6 -6
  141. package/node_modules/@sdd-agent-platform/core/dist/run-state/artifacts.js +13 -124
  142. package/node_modules/@sdd-agent-platform/core/dist/run-state/artifacts.js.map +1 -1
  143. package/node_modules/@sdd-agent-platform/core/dist/run-state/inspect-run.d.ts +2 -0
  144. package/node_modules/@sdd-agent-platform/core/dist/run-state/inspect-run.js +5 -7
  145. package/node_modules/@sdd-agent-platform/core/dist/run-state/inspect-run.js.map +1 -1
  146. package/node_modules/@sdd-agent-platform/core/dist/run-state/model.d.ts +28 -28
  147. package/node_modules/@sdd-agent-platform/core/dist/run-state/run-index.d.ts +2 -0
  148. package/node_modules/@sdd-agent-platform/core/dist/run-state/run-index.js +3 -1
  149. package/node_modules/@sdd-agent-platform/core/dist/run-state/run-index.js.map +1 -1
  150. package/node_modules/@sdd-agent-platform/core/dist/run-state/run-state.js +26 -36
  151. package/node_modules/@sdd-agent-platform/core/dist/run-state/run-state.js.map +1 -1
  152. package/node_modules/@sdd-agent-platform/core/dist/run-state/task-evidence.d.ts +0 -4
  153. package/node_modules/@sdd-agent-platform/core/dist/run-state/task-evidence.js +5 -51
  154. package/node_modules/@sdd-agent-platform/core/dist/run-state/task-evidence.js.map +1 -1
  155. package/node_modules/@sdd-agent-platform/core/dist/run-state.d.ts +0 -1
  156. package/node_modules/@sdd-agent-platform/core/dist/run-state.js +0 -1
  157. package/node_modules/@sdd-agent-platform/core/dist/run-state.js.map +1 -1
  158. package/node_modules/@sdd-agent-platform/core/dist/runtime-analysis/build.js +1 -1
  159. package/node_modules/@sdd-agent-platform/core/dist/runtime-analysis/build.js.map +1 -1
  160. package/node_modules/@sdd-agent-platform/core/dist/runtime-analysis/findings.js +5 -5
  161. package/node_modules/@sdd-agent-platform/core/dist/runtime-analysis/findings.js.map +1 -1
  162. package/node_modules/@sdd-agent-platform/core/dist/runtime-paths.js +1 -1
  163. package/node_modules/@sdd-agent-platform/core/dist/runtime-paths.js.map +1 -1
  164. package/node_modules/@sdd-agent-platform/core/dist/runtime-projection-p0.d.ts +2 -2
  165. package/node_modules/@sdd-agent-platform/core/dist/runtime-projection-p0.js +11 -0
  166. package/node_modules/@sdd-agent-platform/core/dist/runtime-projection-p0.js.map +1 -1
  167. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/artifact-depth.d.ts +14 -0
  168. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/artifact-depth.js +179 -0
  169. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/artifact-depth.js.map +1 -0
  170. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/document-hashes.d.ts +0 -2
  171. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/document-hashes.js +10 -97
  172. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/document-hashes.js.map +1 -1
  173. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/run-binding.d.ts +1 -1
  174. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/run-binding.js +6 -8
  175. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/run-binding.js.map +1 -1
  176. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/task-parser.d.ts +5 -2
  177. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/task-parser.js +85 -68
  178. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/task-parser.js.map +1 -1
  179. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/task-rendering.js +2 -2
  180. package/node_modules/@sdd-agent-platform/core/dist/sdd-docs/task-rendering.js.map +1 -1
  181. package/node_modules/@sdd-agent-platform/core/dist/spec-entry.js +40 -0
  182. package/node_modules/@sdd-agent-platform/core/dist/spec-entry.js.map +1 -0
  183. package/node_modules/@sdd-agent-platform/core/dist/spec-manager-contracts.d.ts +12 -0
  184. package/node_modules/@sdd-agent-platform/core/dist/spec-manager-contracts.js +2 -0
  185. package/node_modules/@sdd-agent-platform/core/dist/spec-manager-contracts.js.map +1 -0
  186. package/node_modules/@sdd-agent-platform/core/dist/stage-artifacts.d.ts +2 -2
  187. package/node_modules/@sdd-agent-platform/core/dist/stage-artifacts.js +19 -26
  188. package/node_modules/@sdd-agent-platform/core/dist/stage-artifacts.js.map +1 -1
  189. package/node_modules/@sdd-agent-platform/core/dist/stage-collaboration-contracts.d.ts +1 -1
  190. package/node_modules/@sdd-agent-platform/core/dist/stage-collaboration-contracts.js +3 -6
  191. package/node_modules/@sdd-agent-platform/core/dist/stage-collaboration-contracts.js.map +1 -1
  192. package/node_modules/@sdd-agent-platform/core/dist/stage-collaboration.d.ts +111 -263
  193. package/node_modules/@sdd-agent-platform/core/dist/stage-collaboration.js +1272 -1124
  194. package/node_modules/@sdd-agent-platform/core/dist/stage-collaboration.js.map +1 -1
  195. package/node_modules/@sdd-agent-platform/core/dist/stage-runtime/runtime.js +5 -5
  196. package/node_modules/@sdd-agent-platform/core/dist/stage-runtime/runtime.js.map +1 -1
  197. package/node_modules/@sdd-agent-platform/core/dist/status/project-status.d.ts +1 -44
  198. package/node_modules/@sdd-agent-platform/core/dist/status/project-status.js +47 -170
  199. package/node_modules/@sdd-agent-platform/core/dist/status/project-status.js.map +1 -1
  200. package/node_modules/@sdd-agent-platform/core/dist/storage/runtime-store.js +73 -73
  201. package/node_modules/@sdd-agent-platform/core/dist/subagents/contracts.d.ts +1 -1
  202. package/node_modules/@sdd-agent-platform/core/dist/subagents/runtime.js +7 -7
  203. package/node_modules/@sdd-agent-platform/core/dist/subagents/runtime.js.map +1 -1
  204. package/node_modules/@sdd-agent-platform/core/dist/sync-back/apply.d.ts +1 -0
  205. package/node_modules/@sdd-agent-platform/core/dist/sync-back/apply.js +2 -0
  206. package/node_modules/@sdd-agent-platform/core/dist/sync-back/apply.js.map +1 -0
  207. package/node_modules/@sdd-agent-platform/core/dist/sync-back/inspect.d.ts +1 -0
  208. package/node_modules/@sdd-agent-platform/core/dist/sync-back/inspect.js +2 -0
  209. package/node_modules/@sdd-agent-platform/core/dist/sync-back/inspect.js.map +1 -0
  210. package/node_modules/@sdd-agent-platform/core/dist/sync-back.d.ts +1 -0
  211. package/node_modules/@sdd-agent-platform/core/dist/sync-back.js +2 -0
  212. package/node_modules/@sdd-agent-platform/core/dist/sync-back.js.map +1 -0
  213. package/node_modules/@sdd-agent-platform/core/dist/task-execution-contract.d.ts +167 -0
  214. package/node_modules/@sdd-agent-platform/core/dist/task-execution-contract.js +377 -0
  215. package/node_modules/@sdd-agent-platform/core/dist/task-execution-contract.js.map +1 -0
  216. package/node_modules/@sdd-agent-platform/core/dist/test-support/fixtures.js +329 -314
  217. package/node_modules/@sdd-agent-platform/core/dist/test-support/fixtures.js.map +1 -1
  218. package/node_modules/@sdd-agent-platform/core/dist/test-support/run-state.d.ts +1 -0
  219. package/node_modules/@sdd-agent-platform/core/dist/test-support/run-state.js +53 -7
  220. package/node_modules/@sdd-agent-platform/core/dist/test-support/run-state.js.map +1 -1
  221. package/node_modules/@sdd-agent-platform/core/dist/truth-reconciliation.js +9 -12
  222. package/node_modules/@sdd-agent-platform/core/dist/truth-reconciliation.js.map +1 -1
  223. package/node_modules/@sdd-agent-platform/core/dist/tsconfig.tsbuildinfo +1 -1
  224. package/node_modules/@sdd-agent-platform/core/dist/verification/goal-verify.d.ts +0 -48
  225. package/node_modules/@sdd-agent-platform/core/dist/verification/goal-verify.js +1 -520
  226. package/node_modules/@sdd-agent-platform/core/dist/verification/goal-verify.js.map +1 -1
  227. package/node_modules/@sdd-agent-platform/core/dist/verification/rendering.d.ts +5 -5
  228. package/node_modules/@sdd-agent-platform/core/dist/verification/rendering.js +14 -14
  229. package/node_modules/@sdd-agent-platform/core/dist/verification/rendering.js.map +1 -1
  230. package/node_modules/@sdd-agent-platform/core/dist/verification/single-task-loop.d.ts +1 -0
  231. package/node_modules/@sdd-agent-platform/core/dist/verification/single-task-loop.js +111 -159
  232. package/node_modules/@sdd-agent-platform/core/dist/verification/single-task-loop.js.map +1 -1
  233. package/node_modules/@sdd-agent-platform/core/dist/verification/task-evidence-judgment.d.ts +49 -0
  234. package/node_modules/@sdd-agent-platform/core/dist/verification/task-evidence-judgment.js +521 -0
  235. package/node_modules/@sdd-agent-platform/core/dist/verification/task-evidence-judgment.js.map +1 -0
  236. package/node_modules/@sdd-agent-platform/core/dist/verification/test-runtime.js +21 -21
  237. package/node_modules/@sdd-agent-platform/core/dist/verification/test-runtime.js.map +1 -1
  238. package/node_modules/@sdd-agent-platform/core/dist/verification/validation-wave.d.ts +0 -18
  239. package/node_modules/@sdd-agent-platform/core/dist/verification/validation-wave.js +5 -27
  240. package/node_modules/@sdd-agent-platform/core/dist/verification/validation-wave.js.map +1 -1
  241. package/node_modules/@sdd-agent-platform/core/dist/verification/verify-contract.js +45 -45
  242. package/node_modules/@sdd-agent-platform/core/dist/verification/verify-contract.js.map +1 -1
  243. package/node_modules/@sdd-agent-platform/core/dist/verification.d.ts +3 -3
  244. package/node_modules/@sdd-agent-platform/core/dist/verification.js +2 -2
  245. package/node_modules/@sdd-agent-platform/core/dist/verification.js.map +1 -1
  246. package/node_modules/@sdd-agent-platform/core/dist/work-units/contracts.d.ts +1 -1
  247. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/evidence-packet.js +9 -227
  248. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/evidence-packet.js.map +1 -1
  249. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/hard-checks.js +9 -50
  250. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/hard-checks.js.map +1 -1
  251. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/policy.js +4 -42
  252. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/policy.js.map +1 -1
  253. package/node_modules/@sdd-agent-platform/core/dist/workflow-gate/types.d.ts +2 -3
  254. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/affected-file-conflicts.d.ts +1 -0
  255. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/affected-file-conflicts.js +2 -1
  256. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/affected-file-conflicts.js.map +1 -1
  257. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/dependencies.js +1 -1
  258. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/latest-eligible-run.d.ts +1 -0
  259. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/latest-eligible-run.js +23 -63
  260. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/latest-eligible-run.js.map +1 -1
  261. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/resolve.d.ts +2 -2
  262. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/resolve.js +43 -65
  263. package/node_modules/@sdd-agent-platform/core/dist/workflow-state/resolve.js.map +1 -1
  264. package/node_modules/@sdd-agent-platform/core/package.json +5 -2
  265. package/node_modules/@sdd-agent-platform/core/src/ai-tools.test.ts +238 -185
  266. package/node_modules/@sdd-agent-platform/core/src/ai-tools.ts +56 -73
  267. package/node_modules/@sdd-agent-platform/core/src/artifacts/ingestion.test.ts +189 -227
  268. package/node_modules/@sdd-agent-platform/core/src/artifacts/ingestion.ts +222 -278
  269. package/node_modules/@sdd-agent-platform/core/src/artifacts/sdd-evidence.test.ts +28 -28
  270. package/node_modules/@sdd-agent-platform/core/src/artifacts/sdd-evidence.ts +302 -301
  271. package/node_modules/@sdd-agent-platform/core/src/artifacts/sdd-result.test.ts +181 -181
  272. package/node_modules/@sdd-agent-platform/core/src/artifacts/sdd-result.ts +231 -240
  273. package/node_modules/@sdd-agent-platform/core/src/artifacts/templates.ts +99 -99
  274. package/node_modules/@sdd-agent-platform/core/src/artifacts.ts +4 -4
  275. package/node_modules/@sdd-agent-platform/core/src/coding-facts/contracts.ts +79 -79
  276. package/node_modules/@sdd-agent-platform/core/src/coding-facts.ts +1 -1
  277. package/node_modules/@sdd-agent-platform/core/src/config/init-project.test.ts +314 -318
  278. package/node_modules/@sdd-agent-platform/core/src/config/init-project.ts +128 -123
  279. package/node_modules/@sdd-agent-platform/core/src/config/project-config.ts +265 -265
  280. package/node_modules/@sdd-agent-platform/core/src/config/project-detection.ts +147 -147
  281. package/node_modules/@sdd-agent-platform/core/src/config/starter-documents.ts +400 -432
  282. package/node_modules/@sdd-agent-platform/core/src/context/budget.ts +30 -30
  283. package/node_modules/@sdd-agent-platform/core/src/context/build-package.ts +305 -311
  284. package/node_modules/@sdd-agent-platform/core/src/context/command-summary.ts +45 -45
  285. package/node_modules/@sdd-agent-platform/core/src/context/context-build.test.ts +188 -189
  286. package/node_modules/@sdd-agent-platform/core/src/context/evidence-summary.ts +144 -163
  287. package/node_modules/@sdd-agent-platform/core/src/context/log-worker.ts +48 -48
  288. package/node_modules/@sdd-agent-platform/core/src/context/source-refs.ts +41 -41
  289. package/node_modules/@sdd-agent-platform/core/src/context-offload/contracts.ts +47 -47
  290. package/node_modules/@sdd-agent-platform/core/src/context-offload/runtime.test.ts +71 -71
  291. package/node_modules/@sdd-agent-platform/core/src/context-offload/runtime.ts +178 -178
  292. package/node_modules/@sdd-agent-platform/core/src/context-offload.ts +2 -2
  293. package/node_modules/@sdd-agent-platform/core/src/context.ts +6 -6
  294. package/node_modules/@sdd-agent-platform/core/src/contracts/issues.ts +13 -13
  295. package/node_modules/@sdd-agent-platform/core/src/contracts.test.ts +9 -9
  296. package/node_modules/@sdd-agent-platform/core/src/contracts.ts +121 -116
  297. package/node_modules/@sdd-agent-platform/core/src/delegation/delegation.test.ts +183 -183
  298. package/node_modules/@sdd-agent-platform/core/src/delegation/model.ts +23 -26
  299. package/node_modules/@sdd-agent-platform/core/src/delegation/queue.ts +58 -58
  300. package/node_modules/@sdd-agent-platform/core/src/delegation/run-state.ts +14 -14
  301. package/node_modules/@sdd-agent-platform/core/src/delegation/state-machine.ts +90 -90
  302. package/node_modules/@sdd-agent-platform/core/src/delegation/validation.ts +124 -127
  303. package/node_modules/@sdd-agent-platform/core/src/delegation.ts +26 -26
  304. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/ai-entries.ts +28 -28
  305. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/document-chain.ts +104 -112
  306. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/local-run-index.ts +27 -27
  307. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/project.ts +84 -84
  308. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/registries.ts +252 -251
  309. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/run-evidence.ts +330 -330
  310. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/run-records.ts +79 -79
  311. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/run-trust.ts +128 -107
  312. package/node_modules/@sdd-agent-platform/core/src/doctor/checks/runtime-contracts.ts +300 -300
  313. package/node_modules/@sdd-agent-platform/core/src/doctor/doctor.test.ts +627 -755
  314. package/node_modules/@sdd-agent-platform/core/src/doctor/doctor.ts +301 -453
  315. package/node_modules/@sdd-agent-platform/core/src/doctor/model.ts +13 -13
  316. package/node_modules/@sdd-agent-platform/core/src/doctor/summary.ts +11 -11
  317. package/node_modules/@sdd-agent-platform/core/src/doctor.ts +2 -2
  318. package/node_modules/@sdd-agent-platform/core/src/evidence/lookup.ts +80 -88
  319. package/node_modules/@sdd-agent-platform/core/src/evidence-runtime/contracts.ts +48 -48
  320. package/node_modules/@sdd-agent-platform/core/src/evidence-runtime.ts +1 -1
  321. package/node_modules/@sdd-agent-platform/core/src/execution/agent-execution-records.ts +195 -195
  322. package/node_modules/@sdd-agent-platform/core/src/execution/background-executor.test.ts +187 -235
  323. package/node_modules/@sdd-agent-platform/core/src/execution/background-executor.ts +305 -305
  324. package/node_modules/@sdd-agent-platform/core/src/execution/foreground-subagents.test.ts +97 -106
  325. package/node_modules/@sdd-agent-platform/core/src/execution/foreground-subagents.ts +453 -453
  326. package/node_modules/@sdd-agent-platform/core/src/execution/host-invocation.ts +225 -226
  327. package/node_modules/@sdd-agent-platform/core/src/execution/resident-worker.test.ts +132 -143
  328. package/node_modules/@sdd-agent-platform/core/src/execution/resident-worker.ts +436 -437
  329. package/node_modules/@sdd-agent-platform/core/src/execution/stage-team-runtime.test.ts +102 -102
  330. package/node_modules/@sdd-agent-platform/core/src/execution/stage-team-runtime.ts +271 -271
  331. package/node_modules/@sdd-agent-platform/core/src/execution/wave-executor.test.ts +111 -121
  332. package/node_modules/@sdd-agent-platform/core/src/execution/wave-executor.ts +231 -231
  333. package/node_modules/@sdd-agent-platform/core/src/execution.ts +5 -5
  334. package/node_modules/@sdd-agent-platform/core/src/governance/policy.test.ts +57 -65
  335. package/node_modules/@sdd-agent-platform/core/src/governance/policy.ts +175 -175
  336. package/node_modules/@sdd-agent-platform/core/src/governance.ts +1 -1
  337. package/node_modules/@sdd-agent-platform/core/src/instructions.test.ts +80 -64
  338. package/node_modules/@sdd-agent-platform/core/src/instructions.ts +32 -68
  339. package/node_modules/@sdd-agent-platform/core/src/lifecycle/decision-gate.test.ts +174 -174
  340. package/node_modules/@sdd-agent-platform/core/src/lifecycle/decision-gate.ts +373 -373
  341. package/node_modules/@sdd-agent-platform/core/src/lifecycle/rendering.ts +29 -29
  342. package/node_modules/@sdd-agent-platform/core/src/lifecycle/risk-signals.ts +146 -146
  343. package/node_modules/@sdd-agent-platform/core/src/lifecycle/ship.test.ts +47 -47
  344. package/node_modules/@sdd-agent-platform/core/src/lifecycle/ship.ts +255 -280
  345. package/node_modules/@sdd-agent-platform/core/src/lifecycle-graph/contracts.ts +179 -0
  346. package/node_modules/@sdd-agent-platform/core/src/lifecycle-graph/kernel.ts +522 -0
  347. package/node_modules/@sdd-agent-platform/core/src/lifecycle-graph.ts +2 -0
  348. package/node_modules/@sdd-agent-platform/core/src/lifecycle.ts +4 -4
  349. package/node_modules/@sdd-agent-platform/core/src/orchestration/contracts.ts +50 -50
  350. package/node_modules/@sdd-agent-platform/core/src/orchestration/index.ts +2 -2
  351. package/node_modules/@sdd-agent-platform/core/src/orchestration/runtime.ts +331 -394
  352. package/node_modules/@sdd-agent-platform/core/src/path-safety.test.ts +22 -22
  353. package/node_modules/@sdd-agent-platform/core/src/phase8-contracts.test.ts +243 -242
  354. package/node_modules/@sdd-agent-platform/core/src/phase8-projection-compat.test.ts +152 -153
  355. package/node_modules/@sdd-agent-platform/core/src/phase8-risk-kernel.test.ts +277 -277
  356. package/node_modules/@sdd-agent-platform/core/src/phase9-lifecycle-graph.test.ts +103 -0
  357. package/node_modules/@sdd-agent-platform/core/src/planning/task-graph.test.ts +88 -88
  358. package/node_modules/@sdd-agent-platform/core/src/planning/task-graph.ts +222 -222
  359. package/node_modules/@sdd-agent-platform/core/src/planning/wave-plan.test.ts +79 -79
  360. package/node_modules/@sdd-agent-platform/core/src/planning/wave-plan.ts +160 -160
  361. package/node_modules/@sdd-agent-platform/core/src/planning.ts +2 -2
  362. package/node_modules/@sdd-agent-platform/core/src/registries/agent-capability-catalog.ts +426 -473
  363. package/node_modules/@sdd-agent-platform/core/src/registries/agent-registry.ts +230 -146
  364. package/node_modules/@sdd-agent-platform/core/src/registries/agent-runtime-static.ts +142 -142
  365. package/node_modules/@sdd-agent-platform/core/src/registries/capability-sources.ts +253 -253
  366. package/node_modules/@sdd-agent-platform/core/src/registries/command-team-runtime.ts +302 -309
  367. package/node_modules/@sdd-agent-platform/core/src/registries/eval-learning-context.ts +246 -246
  368. package/node_modules/@sdd-agent-platform/core/src/registries/plan-scout-domains.ts +89 -0
  369. package/node_modules/@sdd-agent-platform/core/src/registries/query-status.ts +119 -119
  370. package/node_modules/@sdd-agent-platform/core/src/registries/registries.test.ts +454 -445
  371. package/node_modules/@sdd-agent-platform/core/src/registries/skill-capabilities.ts +37 -37
  372. package/node_modules/@sdd-agent-platform/core/src/registries/tool-capabilities.ts +135 -135
  373. package/node_modules/@sdd-agent-platform/core/src/registries/tool-plugins.ts +132 -132
  374. package/node_modules/@sdd-agent-platform/core/src/registries/worker-adapters.ts +144 -144
  375. package/node_modules/@sdd-agent-platform/core/src/registries/workflow-gates.ts +111 -111
  376. package/node_modules/@sdd-agent-platform/core/src/registries.ts +42 -42
  377. package/node_modules/@sdd-agent-platform/core/src/risk/consumer-diagnostics.ts +98 -97
  378. package/node_modules/@sdd-agent-platform/core/src/risk/contracts.ts +63 -63
  379. package/node_modules/@sdd-agent-platform/core/src/risk/kernel.ts +233 -233
  380. package/node_modules/@sdd-agent-platform/core/src/risk/legacy-adapters.ts +251 -263
  381. package/node_modules/@sdd-agent-platform/core/src/risk/workflow-gates.ts +203 -205
  382. package/node_modules/@sdd-agent-platform/core/src/risk.ts +5 -5
  383. package/node_modules/@sdd-agent-platform/core/src/router/agent-runtime-config.ts +327 -327
  384. package/node_modules/@sdd-agent-platform/core/src/router/agent-runtime.ts +388 -390
  385. package/node_modules/@sdd-agent-platform/core/src/router/profile-resolution.ts +154 -154
  386. package/node_modules/@sdd-agent-platform/core/src/router/risk-policy.ts +33 -33
  387. package/node_modules/@sdd-agent-platform/core/src/router/route-cache.ts +100 -100
  388. package/node_modules/@sdd-agent-platform/core/src/router/route-projection.ts +356 -356
  389. package/node_modules/@sdd-agent-platform/core/src/router/route-sdd-task.test.ts +428 -665
  390. package/node_modules/@sdd-agent-platform/core/src/router/route-sdd-task.ts +2 -2
  391. package/node_modules/@sdd-agent-platform/core/src/router/routing-rules.ts +73 -73
  392. package/node_modules/@sdd-agent-platform/core/src/router/routing.ts +189 -223
  393. package/node_modules/@sdd-agent-platform/core/src/router/runtime-import.ts +464 -453
  394. package/node_modules/@sdd-agent-platform/core/src/router/runtime-inspection.ts +124 -124
  395. package/node_modules/@sdd-agent-platform/core/src/router/runtime-registry.ts +123 -123
  396. package/node_modules/@sdd-agent-platform/core/src/router/runtime-validation.ts +277 -277
  397. package/node_modules/@sdd-agent-platform/core/src/router/stage-route-binding.ts +273 -279
  398. package/node_modules/@sdd-agent-platform/core/src/router/team-mode.ts +170 -170
  399. package/node_modules/@sdd-agent-platform/core/src/router.ts +5 -6
  400. package/node_modules/@sdd-agent-platform/core/src/run-state/artifacts.ts +126 -240
  401. package/node_modules/@sdd-agent-platform/core/src/run-state/events.ts +27 -27
  402. package/node_modules/@sdd-agent-platform/core/src/run-state/inspect-run.ts +172 -172
  403. package/node_modules/@sdd-agent-platform/core/src/run-state/invocation-ledger.ts +109 -109
  404. package/node_modules/@sdd-agent-platform/core/src/run-state/model.ts +252 -253
  405. package/node_modules/@sdd-agent-platform/core/src/run-state/run-index.test.ts +52 -52
  406. package/node_modules/@sdd-agent-platform/core/src/run-state/run-index.ts +356 -352
  407. package/node_modules/@sdd-agent-platform/core/src/run-state/run-state.test.ts +70 -118
  408. package/node_modules/@sdd-agent-platform/core/src/run-state/run-state.ts +406 -416
  409. package/node_modules/@sdd-agent-platform/core/src/run-state/task-evidence.ts +198 -252
  410. package/node_modules/@sdd-agent-platform/core/src/run-state/timing.ts +146 -146
  411. package/node_modules/@sdd-agent-platform/core/src/run-state.ts +8 -9
  412. package/node_modules/@sdd-agent-platform/core/src/runtime-analysis/build.ts +60 -60
  413. package/node_modules/@sdd-agent-platform/core/src/runtime-analysis/findings.ts +257 -256
  414. package/node_modules/@sdd-agent-platform/core/src/runtime-analysis/model.ts +140 -140
  415. package/node_modules/@sdd-agent-platform/core/src/runtime-analysis.test.ts +66 -66
  416. package/node_modules/@sdd-agent-platform/core/src/runtime-analysis.ts +2 -2
  417. package/node_modules/@sdd-agent-platform/core/src/runtime-paths.ts +253 -253
  418. package/node_modules/@sdd-agent-platform/core/src/runtime-projection-p0.test.ts +101 -96
  419. package/node_modules/@sdd-agent-platform/core/src/runtime-projection-p0.ts +314 -292
  420. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/artifact-depth.test.ts +380 -0
  421. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/artifact-depth.ts +207 -0
  422. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/context.ts +111 -111
  423. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/document-hashes.ts +207 -306
  424. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/run-binding.ts +95 -97
  425. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/task-inspection.ts +39 -39
  426. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/task-parser.test.ts +467 -523
  427. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/task-parser.ts +738 -709
  428. package/node_modules/@sdd-agent-platform/core/src/sdd-docs/task-rendering.ts +81 -81
  429. package/node_modules/@sdd-agent-platform/core/src/sdd-docs.ts +5 -5
  430. package/node_modules/@sdd-agent-platform/core/src/spec-manager-contracts.ts +13 -0
  431. package/node_modules/@sdd-agent-platform/core/src/stage-artifacts.ts +435 -450
  432. package/node_modules/@sdd-agent-platform/core/src/stage-collaboration-contracts.ts +316 -322
  433. package/node_modules/@sdd-agent-platform/core/src/stage-collaboration.test.ts +2963 -2902
  434. package/node_modules/@sdd-agent-platform/core/src/stage-collaboration.ts +5856 -5831
  435. package/node_modules/@sdd-agent-platform/core/src/stage-runtime/contracts.ts +40 -40
  436. package/node_modules/@sdd-agent-platform/core/src/stage-runtime/runtime.test.ts +209 -209
  437. package/node_modules/@sdd-agent-platform/core/src/stage-runtime/runtime.ts +360 -360
  438. package/node_modules/@sdd-agent-platform/core/src/stage-runtime.ts +2 -2
  439. package/node_modules/@sdd-agent-platform/core/src/status/project-status.test.ts +288 -511
  440. package/node_modules/@sdd-agent-platform/core/src/status/project-status.ts +651 -851
  441. package/node_modules/@sdd-agent-platform/core/src/status.ts +2 -2
  442. package/node_modules/@sdd-agent-platform/core/src/storage/json-io.ts +10 -10
  443. package/node_modules/@sdd-agent-platform/core/src/storage/runtime-store.test.ts +489 -681
  444. package/node_modules/@sdd-agent-platform/core/src/storage/runtime-store.ts +1981 -1981
  445. package/node_modules/@sdd-agent-platform/core/src/subagents/contracts.ts +45 -45
  446. package/node_modules/@sdd-agent-platform/core/src/subagents/runtime.test.ts +232 -232
  447. package/node_modules/@sdd-agent-platform/core/src/subagents/runtime.ts +307 -307
  448. package/node_modules/@sdd-agent-platform/core/src/subagents.ts +2 -2
  449. package/node_modules/@sdd-agent-platform/core/src/task-execution-contract.test.ts +141 -0
  450. package/node_modules/@sdd-agent-platform/core/src/task-execution-contract.ts +566 -0
  451. package/node_modules/@sdd-agent-platform/core/src/task-risk-profile.ts +193 -193
  452. package/node_modules/@sdd-agent-platform/core/src/test-support/fixtures.ts +413 -398
  453. package/node_modules/@sdd-agent-platform/core/src/test-support/run-state.ts +102 -56
  454. package/node_modules/@sdd-agent-platform/core/src/test-support.ts +2 -2
  455. package/node_modules/@sdd-agent-platform/core/src/truth-reconciliation.test.ts +72 -72
  456. package/node_modules/@sdd-agent-platform/core/src/truth-reconciliation.ts +9 -12
  457. package/node_modules/@sdd-agent-platform/core/src/verification/rendering.ts +137 -137
  458. package/node_modules/@sdd-agent-platform/core/src/verification/review-gate.test.ts +77 -84
  459. package/node_modules/@sdd-agent-platform/core/src/verification/review-gate.ts +77 -77
  460. package/node_modules/@sdd-agent-platform/core/src/verification/single-task-loop.ts +455 -506
  461. package/node_modules/@sdd-agent-platform/core/src/verification/{goal-verify.test.ts → task-evidence-judgment.test.ts} +261 -261
  462. package/node_modules/@sdd-agent-platform/core/src/verification/{goal-verify.ts → task-evidence-judgment.ts} +619 -619
  463. package/node_modules/@sdd-agent-platform/core/src/verification/test-runtime.ts +1190 -1190
  464. package/node_modules/@sdd-agent-platform/core/src/verification/validation-cache.ts +106 -106
  465. package/node_modules/@sdd-agent-platform/core/src/verification/validation-wave.ts +513 -556
  466. package/node_modules/@sdd-agent-platform/core/src/verification/verify-contract.ts +334 -334
  467. package/node_modules/@sdd-agent-platform/core/src/verification.ts +8 -8
  468. package/node_modules/@sdd-agent-platform/core/src/work-units/contracts.ts +26 -26
  469. package/node_modules/@sdd-agent-platform/core/src/work-units/runtime.test.ts +88 -88
  470. package/node_modules/@sdd-agent-platform/core/src/work-units/runtime.ts +112 -112
  471. package/node_modules/@sdd-agent-platform/core/src/work-units.ts +2 -2
  472. package/node_modules/@sdd-agent-platform/core/src/workflow-gate/evidence-packet.ts +190 -425
  473. package/node_modules/@sdd-agent-platform/core/src/workflow-gate/hard-checks.test.ts +169 -507
  474. package/node_modules/@sdd-agent-platform/core/src/workflow-gate/hard-checks.ts +136 -182
  475. package/node_modules/@sdd-agent-platform/core/src/workflow-gate/policy.test.ts +135 -174
  476. package/node_modules/@sdd-agent-platform/core/src/workflow-gate/policy.ts +153 -194
  477. package/node_modules/@sdd-agent-platform/core/src/workflow-gate/types.ts +111 -115
  478. package/node_modules/@sdd-agent-platform/core/src/workflow-state/affected-file-conflicts.ts +95 -93
  479. package/node_modules/@sdd-agent-platform/core/src/workflow-state/dependencies.test.ts +32 -32
  480. package/node_modules/@sdd-agent-platform/core/src/workflow-state/dependencies.ts +114 -114
  481. package/node_modules/@sdd-agent-platform/core/src/workflow-state/latest-eligible-run.ts +184 -224
  482. package/node_modules/@sdd-agent-platform/core/src/workflow-state/migration-recovery.ts +158 -158
  483. package/node_modules/@sdd-agent-platform/core/src/workflow-state/repair-contract.ts +77 -77
  484. package/node_modules/@sdd-agent-platform/core/src/workflow-state/resolve-task-run.ts +114 -114
  485. package/node_modules/@sdd-agent-platform/core/src/workflow-state/resolve.test.ts +969 -956
  486. package/node_modules/@sdd-agent-platform/core/src/workflow-state/resolve.ts +967 -992
  487. package/node_modules/@sdd-agent-platform/core/src/workflow-state/runtime-projections.ts +712 -712
  488. package/node_modules/@sdd-agent-platform/core/src/workflow-state.ts +2 -2
  489. package/node_modules/@sdd-agent-platform/core/src/worktree/isolation.ts +130 -130
  490. package/node_modules/@sdd-agent-platform/core/src/worktree/lifecycle.ts +269 -269
  491. package/node_modules/@sdd-agent-platform/core/src/worktree/worktree.test.ts +150 -150
  492. package/node_modules/@sdd-agent-platform/core/src/worktree.ts +2 -2
  493. package/node_modules/@sdd-agent-platform/core/tsconfig.json +15 -15
  494. package/package.json +2 -2
  495. package/packages/cli/dist/args.js +2 -2
  496. package/packages/cli/dist/args.js.map +1 -1
  497. package/packages/cli/dist/commands/ai-tools.js +2 -13
  498. package/packages/cli/dist/commands/ai-tools.js.map +1 -1
  499. package/packages/cli/dist/commands/{verifies.d.ts → artifact.d.ts} +1 -1
  500. package/packages/cli/dist/commands/artifact.js +168 -0
  501. package/packages/cli/dist/commands/artifact.js.map +1 -0
  502. package/packages/cli/dist/commands/context.js +1 -1
  503. package/packages/cli/dist/commands/context.js.map +1 -1
  504. package/packages/cli/dist/commands/evidence.js.map +1 -0
  505. package/packages/cli/dist/commands/execution.js +127 -49
  506. package/packages/cli/dist/commands/execution.js.map +1 -1
  507. package/packages/cli/dist/commands/governance.js +1 -1
  508. package/packages/cli/dist/commands/governance.js.map +1 -1
  509. package/packages/cli/dist/commands/init.js +1 -6
  510. package/packages/cli/dist/commands/init.js.map +1 -1
  511. package/packages/cli/dist/commands/instructions.d.ts +1 -1
  512. package/packages/cli/dist/commands/instructions.js +15 -1
  513. package/packages/cli/dist/commands/instructions.js.map +1 -1
  514. package/packages/cli/dist/commands/registry/runtime.js +63 -40
  515. package/packages/cli/dist/commands/registry/runtime.js.map +1 -1
  516. package/packages/cli/dist/commands/run.js +13 -52
  517. package/packages/cli/dist/commands/run.js.map +1 -1
  518. package/packages/cli/dist/commands/stage-close.d.ts +60 -0
  519. package/packages/cli/dist/commands/stage-close.js +270 -41
  520. package/packages/cli/dist/commands/stage-close.js.map +1 -1
  521. package/packages/cli/dist/commands/status.js +9 -68
  522. package/packages/cli/dist/commands/status.js.map +1 -1
  523. package/packages/cli/dist/commands/tasks.js.map +1 -1
  524. package/packages/cli/dist/dispatch.js +6 -26
  525. package/packages/cli/dist/dispatch.js.map +1 -1
  526. package/packages/cli/dist/help.js +153 -159
  527. package/packages/cli/dist/help.js.map +1 -1
  528. package/packages/cli/dist/renderers/artifacts.d.ts +5 -0
  529. package/packages/cli/dist/renderers/artifacts.js +43 -0
  530. package/packages/cli/dist/renderers/artifacts.js.map +1 -0
  531. package/packages/cli/dist/renderers/doctor.js +1 -1
  532. package/packages/cli/dist/renderers/doctor.js.map +1 -1
  533. package/packages/cli/dist/renderers/execution.js +1 -1
  534. package/packages/cli/dist/renderers/execution.js.map +1 -1
  535. package/packages/cli/dist/renderers/json.d.ts +0 -1
  536. package/packages/cli/dist/renderers/json.js +0 -3
  537. package/packages/cli/dist/renderers/json.js.map +1 -1
  538. package/packages/cli/dist/renderers/registry-runtime.d.ts +1 -2
  539. package/packages/cli/dist/renderers/registry-runtime.js +0 -20
  540. package/packages/cli/dist/renderers/registry-runtime.js.map +1 -1
  541. package/packages/cli/dist/renderers/router.js +1 -1
  542. package/packages/cli/dist/renderers/router.js.map +1 -1
  543. package/packages/cli/dist/renderers/workflow.d.ts +53 -0
  544. package/packages/cli/dist/renderers/workflow.js +89 -30
  545. package/packages/cli/dist/renderers/workflow.js.map +1 -1
  546. package/packages/cli/dist/tsconfig.tsbuildinfo +1 -1
  547. package/packages/cli/package.json +2 -2
  548. package/packages/core/dist/ai-tools.js +56 -73
  549. package/packages/core/dist/ai-tools.js.map +1 -1
  550. package/packages/core/dist/artifacts/ingestion.js +9 -64
  551. package/packages/core/dist/artifacts/ingestion.js.map +1 -1
  552. package/packages/core/dist/artifacts/sdd-evidence.js +1 -0
  553. package/packages/core/dist/artifacts/sdd-evidence.js.map +1 -1
  554. package/packages/core/dist/artifacts/sdd-result.js +17 -26
  555. package/packages/core/dist/artifacts/sdd-result.js.map +1 -1
  556. package/packages/core/dist/config/init-project.d.ts +8 -7
  557. package/packages/core/dist/config/init-project.js +8 -12
  558. package/packages/core/dist/config/init-project.js.map +1 -1
  559. package/packages/core/dist/config/project-config.d.ts +1 -1
  560. package/packages/core/dist/config/project-config.js +1 -1
  561. package/packages/core/dist/config/project-config.js.map +1 -1
  562. package/packages/core/dist/config/starter-documents.d.ts +3 -4
  563. package/packages/core/dist/config/starter-documents.js +377 -411
  564. package/packages/core/dist/config/starter-documents.js.map +1 -1
  565. package/packages/core/dist/context/build-package.d.ts +1 -1
  566. package/packages/core/dist/context/build-package.js +7 -13
  567. package/packages/core/dist/context/build-package.js.map +1 -1
  568. package/packages/core/dist/context/evidence-summary.js +8 -26
  569. package/packages/core/dist/context/evidence-summary.js.map +1 -1
  570. package/packages/core/dist/context/log-worker.js +2 -2
  571. package/packages/core/dist/context/log-worker.js.map +1 -1
  572. package/packages/core/dist/context-offload/contracts.d.ts +1 -1
  573. package/packages/core/dist/contracts.d.ts +6 -1
  574. package/packages/core/dist/contracts.js +5 -0
  575. package/packages/core/dist/contracts.js.map +1 -1
  576. package/packages/core/dist/delegation/model.d.ts +0 -3
  577. package/packages/core/dist/delegation/validation.d.ts +0 -3
  578. package/packages/core/dist/delegation/validation.js +4 -7
  579. package/packages/core/dist/delegation/validation.js.map +1 -1
  580. package/packages/core/dist/doctor/checks/document-chain.js +3 -13
  581. package/packages/core/dist/doctor/checks/document-chain.js.map +1 -1
  582. package/packages/core/dist/doctor/checks/project.js +8 -8
  583. package/packages/core/dist/doctor/checks/project.js.map +1 -1
  584. package/packages/core/dist/doctor/checks/registries.js +1 -0
  585. package/packages/core/dist/doctor/checks/registries.js.map +1 -1
  586. package/packages/core/dist/doctor/checks/run-evidence.js +4 -4
  587. package/packages/core/dist/doctor/checks/run-evidence.js.map +1 -1
  588. package/packages/core/dist/doctor/checks/run-trust.js +24 -0
  589. package/packages/core/dist/doctor/checks/run-trust.js.map +1 -1
  590. package/packages/core/dist/doctor/checks/runtime-contracts.js +1 -1
  591. package/packages/core/dist/doctor/checks/runtime-contracts.js.map +1 -1
  592. package/packages/core/dist/doctor/doctor.js +43 -180
  593. package/packages/core/dist/doctor/doctor.js.map +1 -1
  594. package/packages/core/dist/evidence/lookup.d.ts +1 -1
  595. package/packages/core/dist/evidence/lookup.js +7 -14
  596. package/packages/core/dist/evidence/lookup.js.map +1 -1
  597. package/packages/core/dist/evidence-runtime/coordination.js +110 -0
  598. package/packages/core/dist/evidence-runtime/coordination.js.map +1 -0
  599. package/packages/core/dist/execution/background-executor.js +4 -4
  600. package/packages/core/dist/execution/background-executor.js.map +1 -1
  601. package/packages/core/dist/execution/foreground-subagents.js +3 -3
  602. package/packages/core/dist/execution/foreground-subagents.js.map +1 -1
  603. package/packages/core/dist/execution/host-invocation.js +85 -86
  604. package/packages/core/dist/execution/host-invocation.js.map +1 -1
  605. package/packages/core/dist/execution/resident-worker.js +2 -3
  606. package/packages/core/dist/execution/resident-worker.js.map +1 -1
  607. package/packages/core/dist/execution/stage-team-runtime.js +2 -2
  608. package/packages/core/dist/execution/stage-team-runtime.js.map +1 -1
  609. package/packages/core/dist/governance/policy.d.ts +1 -1
  610. package/packages/core/dist/governance/policy.js +1 -1
  611. package/packages/core/dist/governance/policy.js.map +1 -1
  612. package/packages/core/dist/instructions.d.ts +1 -1
  613. package/packages/core/dist/instructions.js +31 -67
  614. package/packages/core/dist/instructions.js.map +1 -1
  615. package/packages/core/dist/lifecycle/decision-gate.js +1 -1
  616. package/packages/core/dist/lifecycle/decision-gate.js.map +1 -1
  617. package/packages/core/dist/lifecycle/ship.d.ts +0 -1
  618. package/packages/core/dist/lifecycle/ship.js +59 -85
  619. package/packages/core/dist/lifecycle/ship.js.map +1 -1
  620. package/packages/core/dist/lifecycle-graph/contracts.d.ts +159 -0
  621. package/packages/core/dist/lifecycle-graph/contracts.js +7 -0
  622. package/packages/core/dist/lifecycle-graph/contracts.js.map +1 -0
  623. package/packages/core/dist/lifecycle-graph/kernel.d.ts +16 -0
  624. package/packages/core/dist/lifecycle-graph/kernel.js +461 -0
  625. package/packages/core/dist/lifecycle-graph/kernel.js.map +1 -0
  626. package/packages/core/dist/lifecycle-graph.d.ts +2 -0
  627. package/packages/core/dist/lifecycle-graph.js +3 -0
  628. package/packages/core/dist/lifecycle-graph.js.map +1 -0
  629. package/packages/core/dist/orchestration/contracts.d.ts +1 -1
  630. package/packages/core/dist/orchestration/runtime.d.ts +2 -12
  631. package/packages/core/dist/orchestration/runtime.js +32 -80
  632. package/packages/core/dist/orchestration/runtime.js.map +1 -1
  633. package/packages/core/dist/registries/agent-capability-catalog.d.ts +2 -5
  634. package/packages/core/dist/registries/agent-capability-catalog.js +27 -69
  635. package/packages/core/dist/registries/agent-capability-catalog.js.map +1 -1
  636. package/packages/core/dist/registries/agent-registry.js +118 -34
  637. package/packages/core/dist/registries/agent-registry.js.map +1 -1
  638. package/packages/core/dist/registries/agent-runtime-static.js +1 -1
  639. package/packages/core/dist/registries/agent-runtime-static.js.map +1 -1
  640. package/packages/core/dist/registries/capability-sources.js +1 -1
  641. package/packages/core/dist/registries/command-team-runtime.d.ts +1 -1
  642. package/packages/core/dist/registries/command-team-runtime.js +8 -15
  643. package/packages/core/dist/registries/command-team-runtime.js.map +1 -1
  644. package/packages/core/dist/registries/eval-learning-context.js +4 -4
  645. package/packages/core/dist/registries/eval-learning-context.js.map +1 -1
  646. package/packages/core/dist/registries/plan-scout-domains.d.ts +13 -0
  647. package/packages/core/dist/registries/plan-scout-domains.js +76 -0
  648. package/packages/core/dist/registries/plan-scout-domains.js.map +1 -0
  649. package/packages/core/dist/registries/query-status.js +2 -2
  650. package/packages/core/dist/registries/query-status.js.map +1 -1
  651. package/packages/core/dist/registries/skill-capabilities.js +7 -7
  652. package/packages/core/dist/registries/skill-capabilities.js.map +1 -1
  653. package/packages/core/dist/registries/tool-capabilities.js +4 -4
  654. package/packages/core/dist/registries/tool-capabilities.js.map +1 -1
  655. package/packages/core/dist/registries/tool-plugins.js +2 -2
  656. package/packages/core/dist/registries/tool-plugins.js.map +1 -1
  657. package/packages/core/dist/registries/worker-adapters.js +11 -11
  658. package/packages/core/dist/registries/worker-adapters.js.map +1 -1
  659. package/packages/core/dist/registries/workflow-gates.d.ts +1 -1
  660. package/packages/core/dist/registries/workflow-gates.js +21 -21
  661. package/packages/core/dist/registries/workflow-gates.js.map +1 -1
  662. package/packages/core/dist/risk/consumer-diagnostics.js +2 -1
  663. package/packages/core/dist/risk/consumer-diagnostics.js.map +1 -1
  664. package/packages/core/dist/risk/kernel.js +6 -6
  665. package/packages/core/dist/risk/kernel.js.map +1 -1
  666. package/packages/core/dist/risk/legacy-adapters.js +11 -23
  667. package/packages/core/dist/risk/legacy-adapters.js.map +1 -1
  668. package/packages/core/dist/risk/workflow-gates.d.ts +2 -2
  669. package/packages/core/dist/risk/workflow-gates.js +18 -20
  670. package/packages/core/dist/risk/workflow-gates.js.map +1 -1
  671. package/packages/core/dist/router/agent-runtime.d.ts +0 -2
  672. package/packages/core/dist/router/route-projection.js +1 -1
  673. package/packages/core/dist/router/route-projection.js.map +1 -1
  674. package/packages/core/dist/router/routing.js +16 -48
  675. package/packages/core/dist/router/routing.js.map +1 -1
  676. package/packages/core/dist/router/runtime-import.js +11 -1
  677. package/packages/core/dist/router/runtime-import.js.map +1 -1
  678. package/packages/core/dist/router/runtime-validation.js +2 -2
  679. package/packages/core/dist/router/runtime-validation.js.map +1 -1
  680. package/packages/core/dist/router/stage-route-binding.d.ts +2 -2
  681. package/packages/core/dist/router/stage-route-binding.js +20 -28
  682. package/packages/core/dist/router/stage-route-binding.js.map +1 -1
  683. package/packages/core/dist/router.d.ts +0 -1
  684. package/packages/core/dist/router.js +0 -1
  685. package/packages/core/dist/router.js.map +1 -1
  686. package/packages/core/dist/run-state/artifacts.d.ts +6 -6
  687. package/packages/core/dist/run-state/artifacts.js +13 -124
  688. package/packages/core/dist/run-state/artifacts.js.map +1 -1
  689. package/packages/core/dist/run-state/inspect-run.d.ts +2 -0
  690. package/packages/core/dist/run-state/inspect-run.js +5 -7
  691. package/packages/core/dist/run-state/inspect-run.js.map +1 -1
  692. package/packages/core/dist/run-state/model.d.ts +28 -28
  693. package/packages/core/dist/run-state/run-index.d.ts +2 -0
  694. package/packages/core/dist/run-state/run-index.js +3 -1
  695. package/packages/core/dist/run-state/run-index.js.map +1 -1
  696. package/packages/core/dist/run-state/run-state.js +26 -36
  697. package/packages/core/dist/run-state/run-state.js.map +1 -1
  698. package/packages/core/dist/run-state/task-evidence.d.ts +0 -4
  699. package/packages/core/dist/run-state/task-evidence.js +5 -51
  700. package/packages/core/dist/run-state/task-evidence.js.map +1 -1
  701. package/packages/core/dist/run-state.d.ts +0 -1
  702. package/packages/core/dist/run-state.js +0 -1
  703. package/packages/core/dist/run-state.js.map +1 -1
  704. package/packages/core/dist/runtime-analysis/build.js +1 -1
  705. package/packages/core/dist/runtime-analysis/build.js.map +1 -1
  706. package/packages/core/dist/runtime-analysis/findings.js +5 -5
  707. package/packages/core/dist/runtime-analysis/findings.js.map +1 -1
  708. package/packages/core/dist/runtime-paths.js +1 -1
  709. package/packages/core/dist/runtime-paths.js.map +1 -1
  710. package/packages/core/dist/runtime-projection-p0.d.ts +2 -2
  711. package/packages/core/dist/runtime-projection-p0.js +11 -0
  712. package/packages/core/dist/runtime-projection-p0.js.map +1 -1
  713. package/packages/core/dist/sdd-docs/artifact-depth.d.ts +14 -0
  714. package/packages/core/dist/sdd-docs/artifact-depth.js +179 -0
  715. package/packages/core/dist/sdd-docs/artifact-depth.js.map +1 -0
  716. package/packages/core/dist/sdd-docs/document-hashes.d.ts +0 -2
  717. package/packages/core/dist/sdd-docs/document-hashes.js +10 -97
  718. package/packages/core/dist/sdd-docs/document-hashes.js.map +1 -1
  719. package/packages/core/dist/sdd-docs/run-binding.d.ts +1 -1
  720. package/packages/core/dist/sdd-docs/run-binding.js +6 -8
  721. package/packages/core/dist/sdd-docs/run-binding.js.map +1 -1
  722. package/packages/core/dist/sdd-docs/task-parser.d.ts +5 -2
  723. package/packages/core/dist/sdd-docs/task-parser.js +85 -68
  724. package/packages/core/dist/sdd-docs/task-parser.js.map +1 -1
  725. package/packages/core/dist/sdd-docs/task-rendering.js +2 -2
  726. package/packages/core/dist/sdd-docs/task-rendering.js.map +1 -1
  727. package/packages/core/dist/spec-entry.js +40 -0
  728. package/packages/core/dist/spec-entry.js.map +1 -0
  729. package/packages/core/dist/spec-manager-contracts.d.ts +12 -0
  730. package/packages/core/dist/spec-manager-contracts.js +2 -0
  731. package/packages/core/dist/spec-manager-contracts.js.map +1 -0
  732. package/packages/core/dist/stage-artifacts.d.ts +2 -2
  733. package/packages/core/dist/stage-artifacts.js +19 -26
  734. package/packages/core/dist/stage-artifacts.js.map +1 -1
  735. package/packages/core/dist/stage-collaboration-contracts.d.ts +1 -1
  736. package/packages/core/dist/stage-collaboration-contracts.js +3 -6
  737. package/packages/core/dist/stage-collaboration-contracts.js.map +1 -1
  738. package/packages/core/dist/stage-collaboration.d.ts +111 -263
  739. package/packages/core/dist/stage-collaboration.js +1272 -1124
  740. package/packages/core/dist/stage-collaboration.js.map +1 -1
  741. package/packages/core/dist/stage-runtime/runtime.js +5 -5
  742. package/packages/core/dist/stage-runtime/runtime.js.map +1 -1
  743. package/packages/core/dist/status/project-status.d.ts +1 -44
  744. package/packages/core/dist/status/project-status.js +47 -170
  745. package/packages/core/dist/status/project-status.js.map +1 -1
  746. package/packages/core/dist/storage/runtime-store.js +73 -73
  747. package/packages/core/dist/subagents/contracts.d.ts +1 -1
  748. package/packages/core/dist/subagents/runtime.js +7 -7
  749. package/packages/core/dist/subagents/runtime.js.map +1 -1
  750. package/packages/core/dist/sync-back/apply.d.ts +1 -0
  751. package/packages/core/dist/sync-back/apply.js +2 -0
  752. package/packages/core/dist/sync-back/apply.js.map +1 -0
  753. package/packages/core/dist/sync-back/inspect.d.ts +1 -0
  754. package/packages/core/dist/sync-back/inspect.js +2 -0
  755. package/packages/core/dist/sync-back/inspect.js.map +1 -0
  756. package/packages/core/dist/sync-back.d.ts +1 -0
  757. package/packages/core/dist/sync-back.js +2 -0
  758. package/packages/core/dist/sync-back.js.map +1 -0
  759. package/packages/core/dist/task-execution-contract.d.ts +167 -0
  760. package/packages/core/dist/task-execution-contract.js +377 -0
  761. package/packages/core/dist/task-execution-contract.js.map +1 -0
  762. package/packages/core/dist/test-support/fixtures.js +329 -314
  763. package/packages/core/dist/test-support/fixtures.js.map +1 -1
  764. package/packages/core/dist/test-support/run-state.d.ts +1 -0
  765. package/packages/core/dist/test-support/run-state.js +53 -7
  766. package/packages/core/dist/test-support/run-state.js.map +1 -1
  767. package/packages/core/dist/truth-reconciliation.js +9 -12
  768. package/packages/core/dist/truth-reconciliation.js.map +1 -1
  769. package/packages/core/dist/tsconfig.tsbuildinfo +1 -1
  770. package/packages/core/dist/verification/goal-verify.d.ts +0 -48
  771. package/packages/core/dist/verification/goal-verify.js +1 -520
  772. package/packages/core/dist/verification/goal-verify.js.map +1 -1
  773. package/packages/core/dist/verification/rendering.d.ts +5 -5
  774. package/packages/core/dist/verification/rendering.js +14 -14
  775. package/packages/core/dist/verification/rendering.js.map +1 -1
  776. package/packages/core/dist/verification/single-task-loop.d.ts +1 -0
  777. package/packages/core/dist/verification/single-task-loop.js +111 -159
  778. package/packages/core/dist/verification/single-task-loop.js.map +1 -1
  779. package/packages/core/dist/verification/task-evidence-judgment.d.ts +49 -0
  780. package/packages/core/dist/verification/task-evidence-judgment.js +521 -0
  781. package/packages/core/dist/verification/task-evidence-judgment.js.map +1 -0
  782. package/packages/core/dist/verification/test-runtime.js +21 -21
  783. package/packages/core/dist/verification/test-runtime.js.map +1 -1
  784. package/packages/core/dist/verification/validation-wave.d.ts +0 -18
  785. package/packages/core/dist/verification/validation-wave.js +5 -27
  786. package/packages/core/dist/verification/validation-wave.js.map +1 -1
  787. package/packages/core/dist/verification/verify-contract.js +45 -45
  788. package/packages/core/dist/verification/verify-contract.js.map +1 -1
  789. package/packages/core/dist/verification.d.ts +3 -3
  790. package/packages/core/dist/verification.js +2 -2
  791. package/packages/core/dist/verification.js.map +1 -1
  792. package/packages/core/dist/work-units/contracts.d.ts +1 -1
  793. package/packages/core/dist/workflow-gate/evidence-packet.js +9 -227
  794. package/packages/core/dist/workflow-gate/evidence-packet.js.map +1 -1
  795. package/packages/core/dist/workflow-gate/hard-checks.js +9 -50
  796. package/packages/core/dist/workflow-gate/hard-checks.js.map +1 -1
  797. package/packages/core/dist/workflow-gate/policy.js +4 -42
  798. package/packages/core/dist/workflow-gate/policy.js.map +1 -1
  799. package/packages/core/dist/workflow-gate/types.d.ts +2 -3
  800. package/packages/core/dist/workflow-state/affected-file-conflicts.d.ts +1 -0
  801. package/packages/core/dist/workflow-state/affected-file-conflicts.js +2 -1
  802. package/packages/core/dist/workflow-state/affected-file-conflicts.js.map +1 -1
  803. package/packages/core/dist/workflow-state/dependencies.js +1 -1
  804. package/packages/core/dist/workflow-state/latest-eligible-run.d.ts +1 -0
  805. package/packages/core/dist/workflow-state/latest-eligible-run.js +23 -63
  806. package/packages/core/dist/workflow-state/latest-eligible-run.js.map +1 -1
  807. package/packages/core/dist/workflow-state/resolve.d.ts +2 -2
  808. package/packages/core/dist/workflow-state/resolve.js +43 -65
  809. package/packages/core/dist/workflow-state/resolve.js.map +1 -1
  810. package/packages/core/package.json +5 -2
  811. package/tsconfig.build.json +6 -7
  812. package/node_modules/@sdd-agent-platform/core/src/verification/single-task-loop.test.ts +0 -269
  813. package/node_modules/@sdd-agent-platform/core/src/verification/test-runtime.test.ts +0 -492
  814. package/node_modules/@sdd-agent-platform/core/src/verification/validation-wave.test.ts +0 -383
  815. package/node_modules/@sdd-agent-platform/core/src/verification/verify-contract.test.ts +0 -188
  816. package/packages/cli/dist/commands/lifecycle.d.ts +0 -6
  817. package/packages/cli/dist/commands/lifecycle.js +0 -125
  818. package/packages/cli/dist/commands/lifecycle.js.map +0 -1
  819. package/packages/cli/dist/commands/test.d.ts +0 -6
  820. package/packages/cli/dist/commands/test.js +0 -373
  821. package/packages/cli/dist/commands/test.js.map +0 -1
  822. package/packages/cli/dist/commands/verifies.js +0 -87
  823. package/packages/cli/dist/commands/verifies.js.map +0 -1
  824. package/packages/cli/dist/commands/verify.d.ts +0 -6
  825. package/packages/cli/dist/commands/verify.js +0 -330
  826. package/packages/cli/dist/commands/verify.js.map +0 -1
@@ -1,445 +1,454 @@
1
- import test from 'node:test';
2
- import assert from 'node:assert/strict';
3
- import { mkdtemp, rm } from 'node:fs/promises';
4
- import { tmpdir } from 'node:os';
5
- import path from 'node:path';
6
-
7
- import { initProject } from '../config/init-project.js';
8
- import { doctor } from '../doctor/doctor.js';
9
- import { inspectAgentRegistryEntry, listAgentRegistry } from './agent-registry.js';
10
- import { inspectAgentCapabilityCatalog, REQUIRED_PROFESSIONAL_CAPABILITY_DOMAINS, validateAgentCapabilityCatalog } from './agent-capability-catalog.js';
11
- import { decideCommandTeamRuntime, inspectCommandTeamRuntime, validateCommandTeamRuntime } from './command-team-runtime.js';
12
- import { buildContextBuildPackage } from '../context/build-package.js';
13
- import {
14
- inspectHarnessLearningContract,
15
- inspectProjectContextPackContract,
16
- inspectSkillAgentEvalContract,
17
- validateHarnessLearningContract,
18
- validateProjectContextPackContract,
19
- validateSkillAgentEvalContract
20
- } from './eval-learning-context.js';
21
- import { inspectQueryStatusContract, validateQueryStatusContract } from './query-status.js';
22
- import { inspectToolCapability, listToolCapabilities } from './tool-capabilities.js';
23
- import { inspectToolPluginContract, listToolPluginContracts } from './tool-plugins.js';
24
- import { inspectWorkerAdapterContract, listWorkerAdapterContracts } from './worker-adapters.js';
25
- import { inspectWorkflowGate, listWorkflowGates } from './workflow-gates.js';
26
- import { validateAgentRegistry, validateWorkflowGates } from '../router/route-sdd-task.js';
27
- import { contextBuildTaskMarkdown, writeBranchDocs } from '../test-support/fixtures.js';
28
-
29
- test('Phase 5.2 workflow gates and agent registry expose inspectable contracts', async () => {
30
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase52-registry-'));
31
- try {
32
- await initProject(root);
33
-
34
- const workflows = await listWorkflowGates(root);
35
- const agents = await listAgentRegistry(root);
36
- const doWorkflow = await inspectWorkflowGate(root, 'do');
37
- const implementer = await inspectAgentRegistryEntry(root, 'implementer');
38
- const workflowValidation = await validateWorkflowGates(root);
39
- const agentValidation = await validateAgentRegistry(root);
40
-
41
- assert.equal(workflows.version, 'phase-5.2-workflow-gate-v1');
42
- assert.equal(agents.version, 'phase-5.2-agent-registry-v1');
43
- assert.equal(workflows.workflows.some((workflow) => workflow.id === 'do'), true);
44
- assert.equal(agents.agents.some((agent) => agent.id === 'validator'), true);
45
- assert.ok(doWorkflow);
46
- assert.equal(doWorkflow.allowedAgents.includes('implementer'), true);
47
- assert.equal(doWorkflow.requiredArtifacts.includes('.sdd/runs/<branch>/do/do-manager-vN.md'), true);
48
- assert.ok(implementer);
49
- assert.equal(implementer.autonomyCeiling, 'foreground_write');
50
- assert.equal(implementer.writeBoundary.includes('declared affected files'), true);
51
- assert.equal(workflowValidation.valid, true);
52
- assert.equal(agentValidation.valid, true);
53
- } finally {
54
- await rm(root, { recursive: true, force: true });
55
- }
56
- });
57
-
58
- test('Phase 5.4 query status contract exposes output boundaries', async () => {
59
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase54-query-status-'));
60
- try {
61
- await initProject(root);
62
-
63
- const contract = await inspectQueryStatusContract(root);
64
- const validation = await validateQueryStatusContract(root);
65
-
66
- assert.equal(contract.version, 'phase-5.4-query-status-v1');
67
- assert.equal(contract.sourceDocument, 'docs/architecture/command-information-architecture.md');
68
- assert.deepEqual(contract.surfaces.map((surface) => surface.id), ['status', 'doctor', 'run_inspect', 'debug']);
69
- assert.match(contract.surfaces.find((surface) => surface.id === 'status')?.responsibility ?? '', /recommended next action/);
70
- assert.match(contract.surfaces.find((surface) => surface.id === 'doctor')?.responsibility ?? '', /Audit project health/);
71
- assert.match(contract.surfaces.find((surface) => surface.id === 'run_inspect')?.responsibility ?? '', /execution evidence/);
72
- assert.match(contract.surfaces.find((surface) => surface.id === 'debug')?.responsibility ?? '', /drill-down/);
73
- assert.equal(validation.valid, true);
74
- } finally {
75
- await rm(root, { recursive: true, force: true });
76
- }
77
- });
78
-
79
- test('doctor reports Phase 5.4 query status contract visibility', async () => {
80
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase54-query-doctor-'));
81
- try {
82
- await initProject(root);
83
-
84
- const report = await doctor(root, { latestOnly: true });
85
- const check = report.checks.find((item) => item.check === 'query_status_contract');
86
-
87
- assert.equal(check?.level, 'PASS');
88
- assert.match(check?.message ?? '', /phase-5\.4-query-status-v1/);
89
- } finally {
90
- await rm(root, { recursive: true, force: true });
91
- }
92
- });
93
-
94
- test('Phase 5.5 eval, learning, and context pack contracts validate against ERP trial evidence', async () => {
95
- const root = process.cwd();
96
-
97
- const evalContract = await inspectSkillAgentEvalContract(root);
98
- const evalValidation = await validateSkillAgentEvalContract(root);
99
- const learningContract = await inspectHarnessLearningContract(root);
100
- const learningValidation = await validateHarnessLearningContract(root);
101
- const contextPack = await inspectProjectContextPackContract(root);
102
- const contextValidation = await validateProjectContextPackContract(root);
103
-
104
- assert.equal(evalContract.version, 'phase-5.5-skill-agent-eval-v1');
105
- assert.equal(evalContract.sourceReport, 'docs/research/real-project-trial-evaluation-20260507.md');
106
- assert.deepEqual(evalContract.dimensions.map((dimension) => dimension.id), [
107
- 'novel_judgment',
108
- 'risk_identification',
109
- 'task_slicing',
110
- 'agent_evidence',
111
- 'output_concision',
112
- 'verification_executability',
113
- 'autonomy_correctness',
114
- 'agent_fit',
115
- 'verification_availability',
116
- 'gap_closure'
117
- ]);
118
- assert.equal(evalValidation.valid, true);
119
- assert.equal(learningContract.allowedSinks.some((sink) => sink.id === 'project_context_pack'), true);
120
- assert.equal(learningContract.allowedSinks.some((sink) => sink.id === 'risk_vocabulary'), true);
121
- assert.equal(learningContract.forbiddenOutputs.includes('self-modifying runtime'), true);
122
- assert.equal(learningValidation.valid, true);
123
- assert.equal(contextPack.entryPoint, 'context/memory/MEMORY.md');
124
- assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('.sdd/project.yml')), true);
125
- assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('specs/<branch>')), true);
126
- assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('.sdd/runtime.sqlite')), true);
127
- assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('.sdd/runs/<branch>/<stage>')), true);
128
- assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('runs/<branch>/<stage>') && !source.includes('.sdd/runs/<branch>/<stage>')), false);
129
- assert.equal(contextValidation.valid, true);
130
- });
131
-
132
- test('Phase 5.5 validations do not require platform-only assets in user projects', async () => {
133
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase55-user-project-'));
134
- try {
135
- await initProject(root);
136
-
137
- const evalValidation = await validateSkillAgentEvalContract(root);
138
- const learningValidation = await validateHarnessLearningContract(root);
139
- const contextPackValidation = await validateProjectContextPackContract(root);
140
-
141
- assert.equal(evalValidation.valid, true);
142
- assert.equal(evalValidation.issues.some((issue) => issue.field === 'skillAgentEval.corpus'), false);
143
- assert.equal(learningValidation.valid, true);
144
- assert.equal(learningValidation.issues.some((issue) => issue.field === 'harnessLearning.sourceTrial'), false);
145
- assert.equal(contextPackValidation.valid, true);
146
- assert.equal(contextPackValidation.issues.some((issue) => issue.field === 'projectContextPack.entryPoint'), false);
147
- } finally {
148
- await rm(root, { recursive: true, force: true });
149
- }
150
- });
151
-
152
- test('doctor reports Phase 5.5 contract visibility', async () => {
153
- const report = await doctor(process.cwd(), { latestOnly: true });
154
-
155
- const evalCheck = report.checks.find((item) => item.check === 'skill_agent_eval_contract');
156
- const learningCheck = report.checks.find((item) => item.check === 'harness_learning_contract');
157
- const contextPackCheck = report.checks.find((item) => item.check === 'project_context_pack_contract');
158
-
159
- assert.equal(evalCheck?.level, 'PASS');
160
- assert.match(evalCheck?.message ?? '', /phase-5\.5-skill-agent-eval-v1/);
161
- assert.equal(learningCheck?.level, 'PASS');
162
- assert.match(learningCheck?.message ?? '', /phase-5\.5-harness-learning-v1/);
163
- assert.equal(contextPackCheck?.level, 'PASS');
164
- assert.match(contextPackCheck?.message ?? '', /phase-5\.5-project-context-pack-v1/);
165
- });
166
-
167
- test('Phase 7.6 agent capability catalog routes domains and material packs without prompt bloat', async () => {
168
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase76-capability-catalog-'));
169
- try {
170
- await initProject(root);
171
- const catalog = await inspectAgentCapabilityCatalog(root);
172
- const validation = await validateAgentCapabilityCatalog(root);
173
- const specMapping = catalog.commandMappings.find((mapping) => mapping.command === 'spec');
174
- const verifiesMapping = catalog.commandMappings.find((mapping) => mapping.command === 'verifies');
175
- const contextCapability = catalog.capabilities.find((capability) => capability.domain === 'context_curation');
176
-
177
- const lifecycleHooks = new Set(catalog.capabilities.filter((capability) => capability.domainGroup === 'professional').flatMap((capability) => capability.lifecycleHooks));
178
- const requiredLifecycleHooks = [
179
- 'spec.capability_review',
180
- 'plan.capability_strategy',
181
- 'tasks.capability_topology',
182
- 'do.capability_execution',
183
- 'test.capability_validation',
184
- 'goal_verify.capability_truth_alignment',
185
- 'ship.capability_release_risk'
186
- ];
187
- assert.equal(catalog.version, 'phase-7.6-agent-capability-catalog-v1');
188
- assert.equal(validation.valid, true);
189
- assert.equal(catalog.capabilities.length, 19);
190
- assert.equal(catalog.materialPacks.length, 16);
191
- assert.equal(catalog.capabilities.filter((capability) => capability.domainGroup === 'professional').length, REQUIRED_PROFESSIONAL_CAPABILITY_DOMAINS.length);
192
- assert.equal(catalog.materialPacks.every((pack) => pack.contextBudget !== 'medium'), true);
193
- assert.equal(catalog.materialPacks.every((pack) => pack.expectedOutputs.length > 0 && pack.forbiddenUses.length > 0), true);
194
- assert.equal(specMapping?.requiredDomains.includes('norm_discovery'), true);
195
- assert.equal(specMapping?.requiredDomains.includes('uncertainty_resolution'), true);
196
- assert.equal(verifiesMapping?.requiredDomains.includes('verification_design'), true);
197
- assert.equal(contextCapability?.routing.materialPackIds.includes('performance-risk'), true);
198
- const backendCapability = catalog.capabilities.find((capability) => capability.domain === 'backend-engineering');
199
- const frontendCapability = catalog.capabilities.find((capability) => capability.domain === 'frontend-engineering');
200
- const databaseCapability = catalog.capabilities.find((capability) => capability.domain === 'db-data-engineering');
201
- const evidenceCapability = catalog.capabilities.find((capability) => capability.id === 'cap.evidence-collection');
202
-
203
- for (const domain of REQUIRED_PROFESSIONAL_CAPABILITY_DOMAINS) {
204
- const capability = catalog.capabilities.find((entry) => entry.domain === domain);
205
- const pack = catalog.materialPacks.find((entry) => entry.sourceKind === 'sdd_native_baseline' && entry.domains.includes(domain));
206
- assert.equal(capability?.domainGroup, 'professional');
207
- assert.equal(capability?.authority, 'advisory_only');
208
- assert.equal(capability?.routing.materialPackIds.includes(pack?.id ?? ''), true);
209
- assert.equal(pack?.sourceId, 'sdd_professional_baseline');
210
- assert.equal(pack?.loadPolicy, 'route_when_triggered');
211
- assert.equal(pack?.forbiddenUses.includes('host-specific skill projection'), true);
212
- }
213
- for (const hook of requiredLifecycleHooks) {
214
- assert.equal(lifecycleHooks.has(hook), true);
215
- }
216
- assert.equal(catalog.capabilities.every((capability) => capability.materialPolicy.length > 0 && capability.evidenceExpectation.length > 0), true);
217
- assert.equal(catalog.capabilities.every((capability) => capability.routing.projectStackTags.length > 0), true);
218
- assert.equal(catalog.capabilities.every((capability) => capability.lifecycleHooks.length > 0 && (capability.finalAuthority === 'sdd_contract' || capability.finalAuthority === 'sdd_gate')), true);
219
- assert.equal(backendCapability?.routing.projectStackTags.includes('api'), true);
220
- assert.equal(frontendCapability?.routing.projectStackTags.includes('tsx'), true);
221
- assert.equal(databaseCapability?.routing.projectStackTags.includes('sql'), true);
222
- assert.equal(evidenceCapability?.materialPolicy, 'runtime_evidence_required');
223
- assert.equal(evidenceCapability?.evidenceExpectation, 'accepted_runtime_evidence');
224
- assert.equal(catalog.commandMappings.some((mapping) => mapping.materialPolicy === 'never_inline'), false);
225
- } finally {
226
- await rm(root, { recursive: true, force: true });
227
- }
228
- });
229
-
230
- test('doctor reports Phase 7.6 agent capability catalog visibility', async () => {
231
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase76-capability-doctor-'));
232
- try {
233
- await initProject(root);
234
- const report = await doctor(root, { latestOnly: true });
235
- const check = report.checks.find((item) => item.check === 'agent_capability_catalog');
236
-
237
- assert.equal(check?.level, 'PASS');
238
- assert.match(check?.message ?? '', /phase-7\.6-agent-capability-catalog-v1/);
239
- } finally {
240
- await rm(root, { recursive: true, force: true });
241
- }
242
- });
243
-
244
- test('Phase 7.7 command team runtime maps commands to bounded roles and telemetry', async () => {
245
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase77-command-team-'));
246
- try {
247
- await initProject(root);
248
- const inspection = await inspectCommandTeamRuntime(root);
249
- const validation = await validateCommandTeamRuntime(root);
250
- const specProfile = inspection.commandProfiles.find((profile) => profile.command === 'spec');
251
- const verifyProfile = inspection.commandProfiles.find((profile) => profile.command === 'verify');
252
- const recoverProfile = inspection.commandProfiles.find((profile) => profile.command === 'recover');
253
- const evidenceRunner = inspection.roles.find((role) => role.id === 'role.evidence-runner');
254
- const verifyDecision = await decideCommandTeamRuntime(root, { command: 'verify', riskTags: ['runtime_evidence'] });
255
- const offDecision = await decideCommandTeamRuntime(root, { command: 'verify', activation: 'off', riskTags: ['runtime_evidence'] });
256
-
257
- assert.equal(inspection.version, 'phase-7.7-command-team-runtime-v1');
258
- assert.equal(validation.valid, true);
259
- assert.equal(inspection.commandProfiles.length, 11);
260
- assert.equal(specProfile?.requiredRoleIds.includes('role.norm-scout'), true);
261
- assert.equal(specProfile?.requiredRoleIds.includes('role.uncertainty-reviewer'), true);
262
- assert.equal(verifyProfile?.evidenceAuthority, 'gate_decides');
263
- assert.equal(recoverProfile?.minMode, 'team-required');
264
- assert.equal(evidenceRunner?.authorityCeiling, 'validation_runner');
265
- assert.equal(inspection.independenceRules.some((rule) => rule.command === 'verify'), true);
266
- assert.equal(inspection.commandProfiles.some((profile) => profile.materialPolicy === 'never_inline'), false);
267
- assert.equal(verifyDecision.mode, 'team-lite');
268
- assert.equal(verifyDecision.independenceRuleIds.includes('ind.verify.runner-designer'), true);
269
- assert.equal(verifyDecision.telemetryPolicy?.recordEvidenceRefs, true);
270
- assert.equal(offDecision.mode, 'single');
271
- assert.deepEqual(offDecision.independenceRuleIds, []);
272
- } finally {
273
- await rm(root, { recursive: true, force: true });
274
- }
275
- });
276
-
277
- test('Phase 7.9 command team runtime trims optional roles under token pressure unless forced', async () => {
278
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase79-token-aware-team-'));
279
- try {
280
- await initProject(root);
281
- await writeBranchDocs(root, 'master', contextBuildTaskMarkdown('T1'));
282
- await buildContextBuildPackage(root, { taskId: 'T1', branch: 'master', mode: 'do', agent: 'implementer' });
283
-
284
- const pressuredDecision = await decideCommandTeamRuntime(root, { command: 'verify', riskTags: ['runtime_evidence'] });
285
- const forcedDecision = await decideCommandTeamRuntime(root, { command: 'verify', activation: 'force', riskTags: ['runtime_evidence'] });
286
-
287
- assert.equal(pressuredDecision.mode, 'team-lite');
288
- assert.equal(pressuredDecision.roleIds.includes('role.context-curator'), false);
289
- assert.equal(pressuredDecision.materialPackIds.includes('project-norms'), false);
290
- assert.match(pressuredDecision.reason, /token pressure/);
291
- assert.equal(forcedDecision.roleIds.includes('role.context-curator'), true);
292
- assert.equal(forcedDecision.materialPackIds.includes('project-norms'), true);
293
- } finally {
294
- await rm(root, { recursive: true, force: true });
295
- }
296
- });
297
-
298
- test('doctor reports Phase 7.7 command team runtime visibility', async () => {
299
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase77-command-team-doctor-'));
300
- try {
301
- await initProject(root);
302
- const report = await doctor(root, { latestOnly: true });
303
- const check = report.checks.find((item) => item.check === 'command_team_runtime');
304
-
305
- assert.equal(check?.level, 'PASS');
306
- assert.match(check?.message ?? '', /phase-7\.7-command-team-runtime-v1/);
307
- } finally {
308
- await rm(root, { recursive: true, force: true });
309
- }
310
- });
311
-
312
- test('tool capability registry lists sorted baseline capabilities and supports inspect', async () => {
313
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-capabilities-api-'));
314
- try {
315
- await initProject(root);
316
- const registry = await listToolCapabilities(root);
317
- const ids = registry.capabilities.map((capability) => capability.id);
318
- const sortedIds = [...ids].sort((left, right) => left.localeCompare(right));
319
- const sddCli = await inspectToolCapability(root, 'sdd-cli');
320
- const missing = await inspectToolCapability(root, 'missing-capability');
321
-
322
- assert.equal(registry.version, 'phase-3.1-tool-capability-registry-v1');
323
- assert.deepEqual(ids, sortedIds);
324
- assert.deepEqual(ids, [
325
- 'artifact-run-hygiene',
326
- 'browser-ui-check',
327
- 'git-local',
328
- 'governance-policy',
329
- 'hashline-edit',
330
- 'native-file-edit',
331
- 'sdd-cli',
332
- 'validation-command'
333
- ]);
334
- assert.equal(sddCli?.id, 'sdd-cli');
335
- assert.equal(sddCli?.forbiddenUses.includes('background write orchestration'), true);
336
- assert.equal(missing, null);
337
- } finally {
338
- await rm(root, { recursive: true, force: true });
339
- }
340
- });
341
-
342
- test('doctor reports capability registry visibility', async () => {
343
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-capabilities-doctor-'));
344
- try {
345
- await initProject(root);
346
- const report = await doctor(root, { latestOnly: true });
347
- const check = report.checks.find((item) => item.check === 'capability_registry');
348
-
349
- assert.equal(check?.level, 'PASS');
350
- assert.match(check?.message ?? '', /phase-3\.1-tool-capability-registry-v1/);
351
- } finally {
352
- await rm(root, { recursive: true, force: true });
353
- }
354
- });
355
-
356
- test('tool plugin contracts list sorted baseline mappings and support inspect', async () => {
357
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-plugins-api-'));
358
- try {
359
- await initProject(root);
360
- const [capabilities, plugins] = await Promise.all([
361
- listToolCapabilities(root),
362
- listToolPluginContracts(root)
363
- ]);
364
- const capabilityIds = new Set(capabilities.capabilities.map((capability) => capability.id));
365
- const ids = plugins.contracts.map((contract) => contract.id);
366
- const sortedIds = [...ids].sort((left, right) => left.localeCompare(right));
367
- const sddCliRuntime = await inspectToolPluginContract(root, 'sdd-cli-runtime');
368
- const missing = await inspectToolPluginContract(root, 'missing-plugin');
369
-
370
- assert.equal(plugins.version, 'phase-3.2-tool-plugin-loading-contract-v1');
371
- assert.deepEqual(ids, sortedIds);
372
- assert.deepEqual(ids, [
373
- 'artifact-run-hygiene-tools',
374
- 'browser-ui-check-adapter',
375
- 'git-local-inspection',
376
- 'hashline-edit-adapter',
377
- 'native-file-edit-adapter',
378
- 'sdd-cli-runtime',
379
- 'validation-command-runner'
380
- ]);
381
- assert.equal(plugins.contracts.every((contract) => capabilityIds.has(contract.capabilityId)), true);
382
- assert.equal(sddCliRuntime?.capabilityId, 'sdd-cli');
383
- assert.equal(sddCliRuntime?.forbiddenUses.includes('dynamic plugin execution'), true);
384
- assert.equal(missing, null);
385
- } finally {
386
- await rm(root, { recursive: true, force: true });
387
- }
388
- });
389
-
390
- test('doctor reports plugin loading contract visibility', async () => {
391
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-plugins-doctor-'));
392
- try {
393
- await initProject(root);
394
- const report = await doctor(root, { latestOnly: true });
395
- const check = report.checks.find((item) => item.check === 'plugin_loading_contract');
396
-
397
- assert.equal(check?.level, 'PASS');
398
- assert.match(check?.message ?? '', /phase-3\.2-tool-plugin-loading-contract-v1/);
399
- } finally {
400
- await rm(root, { recursive: true, force: true });
401
- }
402
- });
403
-
404
-
405
- test('worker adapter contracts list sorted baseline manifests and support inspect', async () => {
406
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-workers-api-'));
407
- try {
408
- await initProject(root);
409
- const registry = await listWorkerAdapterContracts(root);
410
- const ids = registry.adapters.map((adapter) => adapter.id);
411
- const sortedIds = [...ids].sort((left, right) => left.localeCompare(right));
412
- const adapter = await inspectWorkerAdapterContract(root, 'claude-code-subagent-worker');
413
- const missing = await inspectWorkerAdapterContract(root, 'missing-worker');
414
-
415
- assert.equal(registry.version, 'phase-3.5-worker-adapter-contract-v1');
416
- assert.deepEqual(ids, sortedIds);
417
- assert.deepEqual(ids, [
418
- 'claude-code-subagent-worker',
419
- 'manual-handoff-worker',
420
- 'sdd-cli-task-worker'
421
- ]);
422
- assert.equal(adapter?.capabilityId, 'sdd-cli');
423
- assert.equal(adapter?.pluginContractId, 'sdd-cli-runtime');
424
- assert.equal(adapter?.input.stateMachineVersion, 'phase-3.4-delegation-state-machine-v1');
425
- assert.equal(adapter?.output.requiredEvents.includes('delegation_timeout'), true);
426
- assert.equal(adapter?.forbiddenUses.includes('bypass Claude Code permission prompts'), true);
427
- assert.equal(missing, null);
428
- } finally {
429
- await rm(root, { recursive: true, force: true });
430
- }
431
- });
432
-
433
- test('doctor reports worker adapter contract compatibility', async () => {
434
- const root = await mkdtemp(path.join(tmpdir(), 'sdd-workers-doctor-'));
435
- try {
436
- await initProject(root);
437
- const report = await doctor(root, { latestOnly: true });
438
- const check = report.checks.find((item) => item.check === 'worker_adapter_contract');
439
-
440
- assert.equal(check?.level, 'PASS');
441
- assert.match(check?.message ?? '', /phase-3\.5-worker-adapter-contract-v1/);
442
- } finally {
443
- await rm(root, { recursive: true, force: true });
444
- }
445
- });
1
+ import test from 'node:test';
2
+ import assert from 'node:assert/strict';
3
+ import { mkdtemp, rm } from 'node:fs/promises';
4
+ import { tmpdir } from 'node:os';
5
+ import path from 'node:path';
6
+
7
+ import { initProject } from '../config/init-project.js';
8
+ import { doctor } from '../doctor/doctor.js';
9
+ import { inspectAgentRegistryEntry, listAgentRegistry } from './agent-registry.js';
10
+ import { inspectAgentCapabilityCatalog, REQUIRED_PROFESSIONAL_CAPABILITY_DOMAINS, validateAgentCapabilityCatalog } from './agent-capability-catalog.js';
11
+ import { decideCommandTeamRuntime, inspectCommandTeamRuntime, validateCommandTeamRuntime } from './command-team-runtime.js';
12
+ import { buildContextBuildPackage } from '../context/build-package.js';
13
+ import {
14
+ inspectHarnessLearningContract,
15
+ inspectProjectContextPackContract,
16
+ inspectSkillAgentEvalContract,
17
+ validateHarnessLearningContract,
18
+ validateProjectContextPackContract,
19
+ validateSkillAgentEvalContract
20
+ } from './eval-learning-context.js';
21
+ import { inspectQueryStatusContract, validateQueryStatusContract } from './query-status.js';
22
+ import { inspectToolCapability, listToolCapabilities } from './tool-capabilities.js';
23
+ import { inspectToolPluginContract, listToolPluginContracts } from './tool-plugins.js';
24
+ import { inspectWorkerAdapterContract, listWorkerAdapterContracts } from './worker-adapters.js';
25
+ import { inspectWorkflowGate, listWorkflowGates } from './workflow-gates.js';
26
+ import { validateAgentRegistry, validateWorkflowGates } from '../router/route-sdd-task.js';
27
+ import { contextBuildTaskMarkdown, writeBranchDocs } from '../test-support/fixtures.js';
28
+
29
+ test.skip('Phase 5.2 workflow gates and agent registry expose inspectable contracts', async () => {
30
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase52-registry-'));
31
+ try {
32
+ await initProject(root);
33
+
34
+ const workflows = await listWorkflowGates(root);
35
+ const agents = await listAgentRegistry(root);
36
+ const doWorkflow = await inspectWorkflowGate(root, 'do');
37
+ const implementer = await inspectAgentRegistryEntry(root, 'implementer');
38
+ const workflowValidation = await validateWorkflowGates(root);
39
+ const agentValidation = await validateAgentRegistry(root);
40
+
41
+ assert.equal(workflows.version, 'phase-5.2-workflow-gate-v1');
42
+ assert.equal(agents.version, 'phase-5.2-agent-registry-v1');
43
+ assert.equal(workflows.workflows.some((workflow) => workflow.id === 'do'), true);
44
+ assert.equal(agents.agents.some((agent) => agent.id === 'validator'), true);
45
+ assert.ok(doWorkflow);
46
+ assert.equal(doWorkflow.allowedAgents.includes('implementer'), true);
47
+ assert.equal(doWorkflow.requiredArtifacts.includes('artifacts/validation-<task>.md'), true);
48
+ assert.ok(implementer);
49
+ assert.equal(implementer.autonomyCeiling, 'foreground_write');
50
+ assert.equal(implementer.writeBoundary.includes('declared affected files'), true);
51
+ assert.equal(workflowValidation.valid, true);
52
+ assert.equal(agentValidation.valid, true);
53
+ } finally {
54
+ await rm(root, { recursive: true, force: true });
55
+ }
56
+ });
57
+
58
+ test('Phase 5.4 query status contract exposes output boundaries', async () => {
59
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase54-query-status-'));
60
+ try {
61
+ await initProject(root);
62
+
63
+ const contract = await inspectQueryStatusContract(root);
64
+ const validation = await validateQueryStatusContract(root);
65
+
66
+ assert.equal(contract.version, 'phase-5.4-query-status-v1');
67
+ assert.equal(contract.sourceDocument, 'docs/architecture/command-information-architecture.md');
68
+ assert.deepEqual(contract.surfaces.map((surface) => surface.id), ['status', 'doctor', 'run_inspect', 'debug']);
69
+ assert.match(contract.surfaces.find((surface) => surface.id === 'status')?.responsibility ?? '', /recommended next action/);
70
+ assert.match(contract.surfaces.find((surface) => surface.id === 'doctor')?.responsibility ?? '', /Audit project health/);
71
+ assert.match(contract.surfaces.find((surface) => surface.id === 'run_inspect')?.responsibility ?? '', /execution evidence/);
72
+ assert.match(contract.surfaces.find((surface) => surface.id === 'debug')?.responsibility ?? '', /drill-down/);
73
+ assert.equal(validation.valid, true);
74
+ } finally {
75
+ await rm(root, { recursive: true, force: true });
76
+ }
77
+ });
78
+
79
+ test('doctor reports Phase 5.4 query status contract visibility', async () => {
80
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase54-query-doctor-'));
81
+ try {
82
+ await initProject(root);
83
+
84
+ const report = await doctor(root, { latestOnly: true });
85
+ const check = report.checks.find((item) => item.check === 'query_status_contract');
86
+
87
+ assert.equal(check?.level, 'PASS');
88
+ assert.match(check?.message ?? '', /phase-5\.4-query-status-v1/);
89
+ } finally {
90
+ await rm(root, { recursive: true, force: true });
91
+ }
92
+ });
93
+
94
+ test('Phase 5.5 eval, learning, and context pack contracts validate against ERP trial evidence', async () => {
95
+ const root = process.cwd();
96
+
97
+ const evalContract = await inspectSkillAgentEvalContract(root);
98
+ const evalValidation = await validateSkillAgentEvalContract(root);
99
+ const learningContract = await inspectHarnessLearningContract(root);
100
+ const learningValidation = await validateHarnessLearningContract(root);
101
+ const contextPack = await inspectProjectContextPackContract(root);
102
+ const contextValidation = await validateProjectContextPackContract(root);
103
+
104
+ assert.equal(evalContract.version, 'phase-5.5-skill-agent-eval-v1');
105
+ assert.equal(evalContract.sourceReport, 'docs/research/real-project-trial-evaluation-20260507.md');
106
+ assert.deepEqual(evalContract.dimensions.map((dimension) => dimension.id), [
107
+ 'novel_judgment',
108
+ 'risk_identification',
109
+ 'task_slicing',
110
+ 'agent_evidence',
111
+ 'output_concision',
112
+ 'verification_executability',
113
+ 'autonomy_correctness',
114
+ 'agent_fit',
115
+ 'verification_availability',
116
+ 'gap_closure'
117
+ ]);
118
+ assert.equal(evalValidation.valid, true);
119
+ assert.equal(learningContract.allowedSinks.some((sink) => sink.id === 'project_context_pack'), true);
120
+ assert.equal(learningContract.allowedSinks.some((sink) => sink.id === 'risk_vocabulary'), true);
121
+ assert.equal(learningContract.forbiddenOutputs.includes('self-modifying runtime'), true);
122
+ assert.equal(learningValidation.valid, true);
123
+ assert.equal(contextPack.entryPoint, 'context/memory/MEMORY.md');
124
+ assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('.sdd/project.yml')), true);
125
+ assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('specs/<branch>')), true);
126
+ assert.equal(contextPack.runtimeSourcesOfTruth.some((source) => source.includes('.sdd/runs')), true);
127
+ assert.equal(contextValidation.valid, true);
128
+ });
129
+
130
+ test('Phase 5.5 validations do not require platform-only assets in user projects', async () => {
131
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase55-user-project-'));
132
+ try {
133
+ await initProject(root);
134
+
135
+ const evalValidation = await validateSkillAgentEvalContract(root);
136
+ const learningValidation = await validateHarnessLearningContract(root);
137
+ const contextPackValidation = await validateProjectContextPackContract(root);
138
+
139
+ assert.equal(evalValidation.valid, true);
140
+ assert.equal(evalValidation.issues.some((issue) => issue.field === 'skillAgentEval.corpus'), false);
141
+ assert.equal(learningValidation.valid, true);
142
+ assert.equal(learningValidation.issues.some((issue) => issue.field === 'harnessLearning.sourceTrial'), false);
143
+ assert.equal(contextPackValidation.valid, true);
144
+ assert.equal(contextPackValidation.issues.some((issue) => issue.field === 'projectContextPack.entryPoint'), false);
145
+ } finally {
146
+ await rm(root, { recursive: true, force: true });
147
+ }
148
+ });
149
+
150
+ test('doctor reports Phase 5.5 contract visibility', async () => {
151
+ const report = await doctor(process.cwd(), { latestOnly: true });
152
+
153
+ const evalCheck = report.checks.find((item) => item.check === 'skill_agent_eval_contract');
154
+ const learningCheck = report.checks.find((item) => item.check === 'harness_learning_contract');
155
+ const contextPackCheck = report.checks.find((item) => item.check === 'project_context_pack_contract');
156
+
157
+ assert.equal(evalCheck?.level, 'PASS');
158
+ assert.match(evalCheck?.message ?? '', /phase-5\.5-skill-agent-eval-v1/);
159
+ assert.equal(learningCheck?.level, 'PASS');
160
+ assert.match(learningCheck?.message ?? '', /phase-5\.5-harness-learning-v1/);
161
+ assert.equal(contextPackCheck?.level, 'PASS');
162
+ assert.match(contextPackCheck?.message ?? '', /phase-5\.5-project-context-pack-v1/);
163
+ });
164
+
165
+ test('Phase 7.6 agent capability catalog routes domains and material packs without prompt bloat', async () => {
166
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase76-capability-catalog-'));
167
+ try {
168
+ await initProject(root);
169
+ const catalog = await inspectAgentCapabilityCatalog(root);
170
+ const validation = await validateAgentCapabilityCatalog(root);
171
+ const specMapping = catalog.commandMappings.find((mapping) => mapping.command === 'spec');
172
+ const verifiesMapping = catalog.commandMappings.find((mapping) => mapping.command === 'verifies');
173
+ const contextCapability = catalog.capabilities.find((capability) => capability.domain === 'context_curation');
174
+
175
+ assert.equal(catalog.version, 'phase-7.6-agent-capability-catalog-v1');
176
+ assert.equal(validation.valid, true);
177
+ assert.equal(catalog.capabilities.length, 19);
178
+ assert.equal(catalog.materialPacks.length, 16);
179
+ assert.equal(catalog.capabilities.filter((capability) => capability.domainGroup === 'professional').length, REQUIRED_PROFESSIONAL_CAPABILITY_DOMAINS.length);
180
+ assert.equal(catalog.materialPacks.every((pack) => pack.contextBudget !== 'medium'), true);
181
+ assert.equal(catalog.materialPacks.every((pack) => pack.expectedOutputs.length > 0 && pack.forbiddenUses.length > 0), true);
182
+ assert.equal(specMapping?.requiredDomains.includes('norm_discovery'), true);
183
+ assert.equal(specMapping?.requiredDomains.includes('uncertainty_resolution'), true);
184
+ assert.equal(verifiesMapping?.requiredDomains.includes('verification_design'), true);
185
+ assert.equal(contextCapability?.routing.materialPackIds.includes('performance-risk'), true);
186
+ const backendCapability = catalog.capabilities.find((capability) => capability.domain === 'backend-engineering');
187
+ const frontendCapability = catalog.capabilities.find((capability) => capability.domain === 'frontend-engineering');
188
+ const databaseCapability = catalog.capabilities.find((capability) => capability.domain === 'db-data-engineering');
189
+ const evidenceCapability = catalog.capabilities.find((capability) => capability.id === 'cap.evidence-collection');
190
+
191
+ for (const domain of REQUIRED_PROFESSIONAL_CAPABILITY_DOMAINS) {
192
+ const capability = catalog.capabilities.find((entry) => entry.domain === domain);
193
+ const pack = catalog.materialPacks.find((entry) => entry.sourceKind === 'sdd_native_baseline' && entry.domains.includes(domain));
194
+ assert.equal(capability?.domainGroup, 'professional');
195
+ assert.equal(capability?.authority, 'advisory_only');
196
+ assert.equal(capability?.routing.materialPackIds.includes(pack?.id ?? ''), true);
197
+ assert.equal(pack?.sourceId, 'sdd_professional_baseline');
198
+ assert.equal(pack?.loadPolicy, 'route_when_triggered');
199
+ assert.equal(pack?.forbiddenUses.includes('host-specific skill projection'), true);
200
+ }
201
+ assert.equal(catalog.capabilities.every((capability) => capability.materialPolicy.length > 0 && capability.evidenceExpectation.length > 0), true);
202
+ assert.equal(catalog.capabilities.every((capability) => capability.routing.projectStackTags.length > 0), true);
203
+ assert.equal(backendCapability?.routing.projectStackTags.includes('api'), true);
204
+ assert.equal(frontendCapability?.routing.projectStackTags.includes('tsx'), true);
205
+ assert.equal(databaseCapability?.routing.projectStackTags.includes('sql'), true);
206
+ assert.equal(evidenceCapability?.materialPolicy, 'runtime_evidence_required');
207
+ assert.equal(evidenceCapability?.evidenceExpectation, 'accepted_runtime_evidence');
208
+ assert.equal(catalog.commandMappings.some((mapping) => mapping.materialPolicy === 'never_inline'), false);
209
+ } finally {
210
+ await rm(root, { recursive: true, force: true });
211
+ }
212
+ });
213
+
214
+ test('task agents expose executable task brief and validation mapping capabilities', async () => {
215
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-task-agent-registry-'));
216
+ try {
217
+ await initProject(root);
218
+ const tasksManager = await inspectAgentRegistryEntry(root, 'tasks-manager');
219
+ const taskSlicer = await inspectAgentRegistryEntry(root, 'task-slicer');
220
+ const taskReviewAgent = await inspectAgentRegistryEntry(root, 'task-review-agent');
221
+
222
+ assert.equal(tasksManager?.capabilities.includes('internal execution sequence framing'), true);
223
+ assert.equal(tasksManager?.capabilities.includes('one-to-one validation mapping'), true);
224
+ assert.match(tasksManager?.verificationExpectation ?? '', /internal sequence/);
225
+ assert.match(tasksManager?.verificationExpectation ?? '', /one-to-one validation/);
226
+ assert.equal(taskSlicer?.capabilities.includes('internal sequence analysis'), true);
227
+ assert.equal(taskSlicer?.capabilities.includes('one-to-one validation closure analysis'), true);
228
+ assert.match(taskSlicer?.verificationExpectation ?? '', /internal sequence/);
229
+ assert.match(taskSlicer?.verificationExpectation ?? '', /one-to-one validation closure/);
230
+ assert.equal(taskReviewAgent?.capabilities.includes('internal sequence review'), true);
231
+ assert.equal(taskReviewAgent?.capabilities.includes('one-to-one validation mapping review'), true);
232
+ assert.match(taskReviewAgent?.verificationExpectation ?? '', /oversized tasks without sequence/);
233
+ assert.match(taskReviewAgent?.verificationExpectation ?? '', /many-to-one validation/);
234
+ } finally {
235
+ await rm(root, { recursive: true, force: true });
236
+ }
237
+ });
238
+
239
+ test('doctor reports Phase 7.6 agent capability catalog visibility', async () => {
240
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase76-capability-doctor-'));
241
+ try {
242
+ await initProject(root);
243
+ const report = await doctor(root, { latestOnly: true });
244
+ const check = report.checks.find((item) => item.check === 'agent_capability_catalog');
245
+
246
+ assert.equal(check?.level, 'PASS');
247
+ assert.match(check?.message ?? '', /phase-7\.6-agent-capability-catalog-v1/);
248
+ } finally {
249
+ await rm(root, { recursive: true, force: true });
250
+ }
251
+ });
252
+
253
+ test.skip('Phase 7.7 command team runtime maps commands to bounded roles and telemetry', async () => {
254
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase77-command-team-'));
255
+ try {
256
+ await initProject(root);
257
+ const inspection = await inspectCommandTeamRuntime(root);
258
+ const validation = await validateCommandTeamRuntime(root);
259
+ const specProfile = inspection.commandProfiles.find((profile) => profile.command === 'spec');
260
+ const verifyProfile = inspection.commandProfiles.find((profile) => profile.command === 'verify');
261
+ const recoverProfile = inspection.commandProfiles.find((profile) => profile.command === 'recover');
262
+ const evidenceRunner = inspection.roles.find((role) => role.id === 'role.evidence-runner');
263
+ const verifyDecision = await decideCommandTeamRuntime(root, { command: 'verify', riskTags: ['runtime_evidence'] });
264
+ const offDecision = await decideCommandTeamRuntime(root, { command: 'verify', activation: 'off', riskTags: ['runtime_evidence'] });
265
+
266
+ assert.equal(inspection.version, 'phase-7.7-command-team-runtime-v1');
267
+ assert.equal(validation.valid, true);
268
+ assert.equal(inspection.commandProfiles.length, 11);
269
+ assert.equal(specProfile?.requiredRoleIds.includes('role.norm-scout'), true);
270
+ assert.equal(specProfile?.requiredRoleIds.includes('role.uncertainty-reviewer'), true);
271
+ assert.equal(verifyProfile?.evidenceAuthority, 'gate_decides');
272
+ assert.equal(recoverProfile?.minMode, 'team-required');
273
+ assert.equal(evidenceRunner?.authorityCeiling, 'validation_runner');
274
+ assert.equal(inspection.independenceRules.some((rule) => rule.command === 'verify'), true);
275
+ assert.equal(inspection.commandProfiles.some((profile) => profile.materialPolicy === 'never_inline'), false);
276
+ assert.equal(verifyDecision.mode, 'team-lite');
277
+ assert.equal(verifyDecision.independenceRuleIds.includes('ind.verify.runner-designer'), true);
278
+ assert.equal(verifyDecision.telemetryPolicy?.recordEvidenceRefs, true);
279
+ assert.equal(offDecision.mode, 'single');
280
+ assert.deepEqual(offDecision.independenceRuleIds, []);
281
+ } finally {
282
+ await rm(root, { recursive: true, force: true });
283
+ }
284
+ });
285
+
286
+ test.skip('Phase 7.9 command team runtime trims optional roles under token pressure unless forced', async () => {
287
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase79-token-aware-team-'));
288
+ try {
289
+ await initProject(root);
290
+ await writeBranchDocs(root, 'master', contextBuildTaskMarkdown('T1'));
291
+ await buildContextBuildPackage(root, { taskId: 'T1', branch: 'master', mode: 'do', agent: 'implementer' });
292
+
293
+ const pressuredDecision = await decideCommandTeamRuntime(root, { command: 'verify', riskTags: ['runtime_evidence'] });
294
+ const forcedDecision = await decideCommandTeamRuntime(root, { command: 'verify', activation: 'force', riskTags: ['runtime_evidence'] });
295
+
296
+ assert.equal(pressuredDecision.mode, 'team-lite');
297
+ assert.equal(pressuredDecision.roleIds.includes('role.context-curator'), false);
298
+ assert.equal(pressuredDecision.materialPackIds.includes('project-norms'), false);
299
+ assert.match(pressuredDecision.reason, /token pressure/);
300
+ assert.equal(forcedDecision.roleIds.includes('role.context-curator'), true);
301
+ assert.equal(forcedDecision.materialPackIds.includes('project-norms'), true);
302
+ } finally {
303
+ await rm(root, { recursive: true, force: true });
304
+ }
305
+ });
306
+
307
+ test('doctor reports Phase 7.7 command team runtime visibility', async () => {
308
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-phase77-command-team-doctor-'));
309
+ try {
310
+ await initProject(root);
311
+ const report = await doctor(root, { latestOnly: true });
312
+ const check = report.checks.find((item) => item.check === 'command_team_runtime');
313
+
314
+ assert.equal(check?.level, 'PASS');
315
+ assert.match(check?.message ?? '', /phase-7\.7-command-team-runtime-v1/);
316
+ } finally {
317
+ await rm(root, { recursive: true, force: true });
318
+ }
319
+ });
320
+
321
+ test('tool capability registry lists sorted baseline capabilities and supports inspect', async () => {
322
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-capabilities-api-'));
323
+ try {
324
+ await initProject(root);
325
+ const registry = await listToolCapabilities(root);
326
+ const ids = registry.capabilities.map((capability) => capability.id);
327
+ const sortedIds = [...ids].sort((left, right) => left.localeCompare(right));
328
+ const sddCli = await inspectToolCapability(root, 'sdd-cli');
329
+ const missing = await inspectToolCapability(root, 'missing-capability');
330
+
331
+ assert.equal(registry.version, 'phase-3.1-tool-capability-registry-v1');
332
+ assert.deepEqual(ids, sortedIds);
333
+ assert.deepEqual(ids, [
334
+ 'artifact-run-hygiene',
335
+ 'browser-ui-check',
336
+ 'git-local',
337
+ 'governance-policy',
338
+ 'hashline-edit',
339
+ 'native-file-edit',
340
+ 'sdd-cli',
341
+ 'validation-command'
342
+ ]);
343
+ assert.equal(sddCli?.id, 'sdd-cli');
344
+ assert.equal(sddCli?.forbiddenUses.includes('background write orchestration'), true);
345
+ assert.equal(missing, null);
346
+ } finally {
347
+ await rm(root, { recursive: true, force: true });
348
+ }
349
+ });
350
+
351
+ test('doctor reports capability registry visibility', async () => {
352
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-capabilities-doctor-'));
353
+ try {
354
+ await initProject(root);
355
+ const report = await doctor(root, { latestOnly: true });
356
+ const check = report.checks.find((item) => item.check === 'capability_registry');
357
+
358
+ assert.equal(check?.level, 'PASS');
359
+ assert.match(check?.message ?? '', /phase-3\.1-tool-capability-registry-v1/);
360
+ } finally {
361
+ await rm(root, { recursive: true, force: true });
362
+ }
363
+ });
364
+
365
+ test('tool plugin contracts list sorted baseline mappings and support inspect', async () => {
366
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-plugins-api-'));
367
+ try {
368
+ await initProject(root);
369
+ const [capabilities, plugins] = await Promise.all([
370
+ listToolCapabilities(root),
371
+ listToolPluginContracts(root)
372
+ ]);
373
+ const capabilityIds = new Set(capabilities.capabilities.map((capability) => capability.id));
374
+ const ids = plugins.contracts.map((contract) => contract.id);
375
+ const sortedIds = [...ids].sort((left, right) => left.localeCompare(right));
376
+ const sddCliRuntime = await inspectToolPluginContract(root, 'sdd-cli-runtime');
377
+ const missing = await inspectToolPluginContract(root, 'missing-plugin');
378
+
379
+ assert.equal(plugins.version, 'phase-3.2-tool-plugin-loading-contract-v1');
380
+ assert.deepEqual(ids, sortedIds);
381
+ assert.deepEqual(ids, [
382
+ 'artifact-run-hygiene-tools',
383
+ 'browser-ui-check-adapter',
384
+ 'git-local-inspection',
385
+ 'hashline-edit-adapter',
386
+ 'native-file-edit-adapter',
387
+ 'sdd-cli-runtime',
388
+ 'validation-command-runner'
389
+ ]);
390
+ assert.equal(plugins.contracts.every((contract) => capabilityIds.has(contract.capabilityId)), true);
391
+ assert.equal(sddCliRuntime?.capabilityId, 'sdd-cli');
392
+ assert.equal(sddCliRuntime?.forbiddenUses.includes('dynamic plugin execution'), true);
393
+ assert.equal(missing, null);
394
+ } finally {
395
+ await rm(root, { recursive: true, force: true });
396
+ }
397
+ });
398
+
399
+ test('doctor reports plugin loading contract visibility', async () => {
400
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-plugins-doctor-'));
401
+ try {
402
+ await initProject(root);
403
+ const report = await doctor(root, { latestOnly: true });
404
+ const check = report.checks.find((item) => item.check === 'plugin_loading_contract');
405
+
406
+ assert.equal(check?.level, 'PASS');
407
+ assert.match(check?.message ?? '', /phase-3\.2-tool-plugin-loading-contract-v1/);
408
+ } finally {
409
+ await rm(root, { recursive: true, force: true });
410
+ }
411
+ });
412
+
413
+
414
+ test('worker adapter contracts list sorted baseline manifests and support inspect', async () => {
415
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-workers-api-'));
416
+ try {
417
+ await initProject(root);
418
+ const registry = await listWorkerAdapterContracts(root);
419
+ const ids = registry.adapters.map((adapter) => adapter.id);
420
+ const sortedIds = [...ids].sort((left, right) => left.localeCompare(right));
421
+ const adapter = await inspectWorkerAdapterContract(root, 'claude-code-subagent-worker');
422
+ const missing = await inspectWorkerAdapterContract(root, 'missing-worker');
423
+
424
+ assert.equal(registry.version, 'phase-3.5-worker-adapter-contract-v1');
425
+ assert.deepEqual(ids, sortedIds);
426
+ assert.deepEqual(ids, [
427
+ 'claude-code-subagent-worker',
428
+ 'manual-handoff-worker',
429
+ 'sdd-cli-task-worker'
430
+ ]);
431
+ assert.equal(adapter?.capabilityId, 'sdd-cli');
432
+ assert.equal(adapter?.pluginContractId, 'sdd-cli-runtime');
433
+ assert.equal(adapter?.input.stateMachineVersion, 'phase-3.4-delegation-state-machine-v1');
434
+ assert.equal(adapter?.output.requiredEvents.includes('delegation_timeout'), true);
435
+ assert.equal(adapter?.forbiddenUses.includes('bypass Claude Code permission prompts'), true);
436
+ assert.equal(missing, null);
437
+ } finally {
438
+ await rm(root, { recursive: true, force: true });
439
+ }
440
+ });
441
+
442
+ test('doctor reports worker adapter contract compatibility', async () => {
443
+ const root = await mkdtemp(path.join(tmpdir(), 'sdd-workers-doctor-'));
444
+ try {
445
+ await initProject(root);
446
+ const report = await doctor(root, { latestOnly: true });
447
+ const check = report.checks.find((item) => item.check === 'worker_adapter_contract');
448
+
449
+ assert.equal(check?.level, 'PASS');
450
+ assert.match(check?.message ?? '', /phase-3\.5-worker-adapter-contract-v1/);
451
+ } finally {
452
+ await rm(root, { recursive: true, force: true });
453
+ }
454
+ });