@zigrivers/scaffold 3.25.1 → 3.26.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 (492) hide show
  1. package/README.md +118 -0
  2. package/dist/cli/commands/complete.d.ts.map +1 -1
  3. package/dist/cli/commands/complete.js +6 -13
  4. package/dist/cli/commands/complete.js.map +1 -1
  5. package/dist/cli/commands/complete.test.js +18 -0
  6. package/dist/cli/commands/complete.test.js.map +1 -1
  7. package/dist/cli/commands/knowledge.test.js +4 -4
  8. package/dist/cli/commands/knowledge.test.js.map +1 -1
  9. package/dist/cli/commands/observe.d.ts +58 -0
  10. package/dist/cli/commands/observe.d.ts.map +1 -0
  11. package/dist/cli/commands/observe.js +430 -0
  12. package/dist/cli/commands/observe.js.map +1 -0
  13. package/dist/cli/commands/observe.test.d.ts +2 -0
  14. package/dist/cli/commands/observe.test.d.ts.map +1 -0
  15. package/dist/cli/commands/observe.test.js +452 -0
  16. package/dist/cli/commands/observe.test.js.map +1 -0
  17. package/dist/cli/commands/run.js +3 -3
  18. package/dist/cli/commands/run.js.map +1 -1
  19. package/dist/cli/commands/run.test.js +1 -1
  20. package/dist/cli/commands/run.test.js.map +1 -1
  21. package/dist/cli/index.d.ts.map +1 -1
  22. package/dist/cli/index.js +2 -0
  23. package/dist/cli/index.js.map +1 -1
  24. package/dist/observability/adapters/audit-history.d.ts +17 -0
  25. package/dist/observability/adapters/audit-history.d.ts.map +1 -0
  26. package/dist/observability/adapters/audit-history.js +113 -0
  27. package/dist/observability/adapters/audit-history.js.map +1 -0
  28. package/dist/observability/adapters/audit-history.test.d.ts +2 -0
  29. package/dist/observability/adapters/audit-history.test.d.ts.map +1 -0
  30. package/dist/observability/adapters/audit-history.test.js +137 -0
  31. package/dist/observability/adapters/audit-history.test.js.map +1 -0
  32. package/dist/observability/adapters/beads.d.ts +9 -0
  33. package/dist/observability/adapters/beads.d.ts.map +1 -0
  34. package/dist/observability/adapters/beads.js +40 -0
  35. package/dist/observability/adapters/beads.js.map +1 -0
  36. package/dist/observability/adapters/beads.test.d.ts +2 -0
  37. package/dist/observability/adapters/beads.test.d.ts.map +1 -0
  38. package/dist/observability/adapters/beads.test.js +25 -0
  39. package/dist/observability/adapters/beads.test.js.map +1 -0
  40. package/dist/observability/adapters/gh.d.ts +27 -0
  41. package/dist/observability/adapters/gh.d.ts.map +1 -0
  42. package/dist/observability/adapters/gh.js +118 -0
  43. package/dist/observability/adapters/gh.js.map +1 -0
  44. package/dist/observability/adapters/gh.test.d.ts +2 -0
  45. package/dist/observability/adapters/gh.test.d.ts.map +1 -0
  46. package/dist/observability/adapters/gh.test.js +79 -0
  47. package/dist/observability/adapters/gh.test.js.map +1 -0
  48. package/dist/observability/adapters/git.d.ts +24 -0
  49. package/dist/observability/adapters/git.d.ts.map +1 -0
  50. package/dist/observability/adapters/git.js +110 -0
  51. package/dist/observability/adapters/git.js.map +1 -0
  52. package/dist/observability/adapters/git.test.d.ts +2 -0
  53. package/dist/observability/adapters/git.test.d.ts.map +1 -0
  54. package/dist/observability/adapters/git.test.js +66 -0
  55. package/dist/observability/adapters/git.test.js.map +1 -0
  56. package/dist/observability/adapters/mmr.d.ts +15 -0
  57. package/dist/observability/adapters/mmr.d.ts.map +1 -0
  58. package/dist/observability/adapters/mmr.js +85 -0
  59. package/dist/observability/adapters/mmr.js.map +1 -0
  60. package/dist/observability/adapters/mmr.test.d.ts +2 -0
  61. package/dist/observability/adapters/mmr.test.d.ts.map +1 -0
  62. package/dist/observability/adapters/mmr.test.js +55 -0
  63. package/dist/observability/adapters/mmr.test.js.map +1 -0
  64. package/dist/observability/adapters/pipeline-docs.d.ts +8 -0
  65. package/dist/observability/adapters/pipeline-docs.d.ts.map +1 -0
  66. package/dist/observability/adapters/pipeline-docs.js +68 -0
  67. package/dist/observability/adapters/pipeline-docs.js.map +1 -0
  68. package/dist/observability/adapters/pipeline-docs.test.d.ts +2 -0
  69. package/dist/observability/adapters/pipeline-docs.test.d.ts.map +1 -0
  70. package/dist/observability/adapters/pipeline-docs.test.js +58 -0
  71. package/dist/observability/adapters/pipeline-docs.test.js.map +1 -0
  72. package/dist/observability/adapters/state.d.ts +21 -0
  73. package/dist/observability/adapters/state.d.ts.map +1 -0
  74. package/dist/observability/adapters/state.js +87 -0
  75. package/dist/observability/adapters/state.js.map +1 -0
  76. package/dist/observability/adapters/state.test.d.ts +2 -0
  77. package/dist/observability/adapters/state.test.d.ts.map +1 -0
  78. package/dist/observability/adapters/state.test.js +92 -0
  79. package/dist/observability/adapters/state.test.js.map +1 -0
  80. package/dist/observability/adapters/tests.d.ts +20 -0
  81. package/dist/observability/adapters/tests.d.ts.map +1 -0
  82. package/dist/observability/adapters/tests.js +52 -0
  83. package/dist/observability/adapters/tests.js.map +1 -0
  84. package/dist/observability/adapters/tests.test.d.ts +2 -0
  85. package/dist/observability/adapters/tests.test.d.ts.map +1 -0
  86. package/dist/observability/adapters/tests.test.js +66 -0
  87. package/dist/observability/adapters/tests.test.js.map +1 -0
  88. package/dist/observability/adapters/types.d.ts +7 -0
  89. package/dist/observability/adapters/types.d.ts.map +1 -0
  90. package/dist/observability/adapters/types.js +2 -0
  91. package/dist/observability/adapters/types.js.map +1 -0
  92. package/dist/observability/checks/lens-a-tdd.d.ts +3 -0
  93. package/dist/observability/checks/lens-a-tdd.d.ts.map +1 -0
  94. package/dist/observability/checks/lens-a-tdd.js +34 -0
  95. package/dist/observability/checks/lens-a-tdd.js.map +1 -0
  96. package/dist/observability/checks/lens-a-tdd.test.d.ts +2 -0
  97. package/dist/observability/checks/lens-a-tdd.test.d.ts.map +1 -0
  98. package/dist/observability/checks/lens-a-tdd.test.js +62 -0
  99. package/dist/observability/checks/lens-a-tdd.test.js.map +1 -0
  100. package/dist/observability/checks/lens-b-ac-coverage.d.ts +3 -0
  101. package/dist/observability/checks/lens-b-ac-coverage.d.ts.map +1 -0
  102. package/dist/observability/checks/lens-b-ac-coverage.js +63 -0
  103. package/dist/observability/checks/lens-b-ac-coverage.js.map +1 -0
  104. package/dist/observability/checks/lens-b-ac-coverage.test.d.ts +2 -0
  105. package/dist/observability/checks/lens-b-ac-coverage.test.d.ts.map +1 -0
  106. package/dist/observability/checks/lens-b-ac-coverage.test.js +59 -0
  107. package/dist/observability/checks/lens-b-ac-coverage.test.js.map +1 -0
  108. package/dist/observability/checks/lens-c-standards.d.ts +3 -0
  109. package/dist/observability/checks/lens-c-standards.d.ts.map +1 -0
  110. package/dist/observability/checks/lens-c-standards.js +104 -0
  111. package/dist/observability/checks/lens-c-standards.js.map +1 -0
  112. package/dist/observability/checks/lens-c-standards.test.d.ts +2 -0
  113. package/dist/observability/checks/lens-c-standards.test.d.ts.map +1 -0
  114. package/dist/observability/checks/lens-c-standards.test.js +79 -0
  115. package/dist/observability/checks/lens-c-standards.test.js.map +1 -0
  116. package/dist/observability/checks/lens-d-stack.d.ts +3 -0
  117. package/dist/observability/checks/lens-d-stack.d.ts.map +1 -0
  118. package/dist/observability/checks/lens-d-stack.js +108 -0
  119. package/dist/observability/checks/lens-d-stack.js.map +1 -0
  120. package/dist/observability/checks/lens-d-stack.test.d.ts +2 -0
  121. package/dist/observability/checks/lens-d-stack.test.d.ts.map +1 -0
  122. package/dist/observability/checks/lens-d-stack.test.js +60 -0
  123. package/dist/observability/checks/lens-d-stack.test.js.map +1 -0
  124. package/dist/observability/checks/lens-e-design.d.ts +3 -0
  125. package/dist/observability/checks/lens-e-design.d.ts.map +1 -0
  126. package/dist/observability/checks/lens-e-design.js +76 -0
  127. package/dist/observability/checks/lens-e-design.js.map +1 -0
  128. package/dist/observability/checks/lens-e-design.test.d.ts +2 -0
  129. package/dist/observability/checks/lens-e-design.test.d.ts.map +1 -0
  130. package/dist/observability/checks/lens-e-design.test.js +85 -0
  131. package/dist/observability/checks/lens-e-design.test.js.map +1 -0
  132. package/dist/observability/checks/lens-f-scope.d.ts +3 -0
  133. package/dist/observability/checks/lens-f-scope.d.ts.map +1 -0
  134. package/dist/observability/checks/lens-f-scope.js +92 -0
  135. package/dist/observability/checks/lens-f-scope.js.map +1 -0
  136. package/dist/observability/checks/lens-f-scope.test.d.ts +2 -0
  137. package/dist/observability/checks/lens-f-scope.test.d.ts.map +1 -0
  138. package/dist/observability/checks/lens-f-scope.test.js +63 -0
  139. package/dist/observability/checks/lens-f-scope.test.js.map +1 -0
  140. package/dist/observability/checks/lens-g-decisions.d.ts +3 -0
  141. package/dist/observability/checks/lens-g-decisions.d.ts.map +1 -0
  142. package/dist/observability/checks/lens-g-decisions.js +139 -0
  143. package/dist/observability/checks/lens-g-decisions.js.map +1 -0
  144. package/dist/observability/checks/lens-g-decisions.test.d.ts +2 -0
  145. package/dist/observability/checks/lens-g-decisions.test.d.ts.map +1 -0
  146. package/dist/observability/checks/lens-g-decisions.test.js +118 -0
  147. package/dist/observability/checks/lens-g-decisions.test.js.map +1 -0
  148. package/dist/observability/checks/lens-h-cross-doc.d.ts +3 -0
  149. package/dist/observability/checks/lens-h-cross-doc.d.ts.map +1 -0
  150. package/dist/observability/checks/lens-h-cross-doc.js +322 -0
  151. package/dist/observability/checks/lens-h-cross-doc.js.map +1 -0
  152. package/dist/observability/checks/lens-h-cross-doc.test.d.ts +2 -0
  153. package/dist/observability/checks/lens-h-cross-doc.test.d.ts.map +1 -0
  154. package/dist/observability/checks/lens-h-cross-doc.test.js +174 -0
  155. package/dist/observability/checks/lens-h-cross-doc.test.js.map +1 -0
  156. package/dist/observability/engine/abort-snapshot.d.ts +10 -0
  157. package/dist/observability/engine/abort-snapshot.d.ts.map +1 -0
  158. package/dist/observability/engine/abort-snapshot.js +36 -0
  159. package/dist/observability/engine/abort-snapshot.js.map +1 -0
  160. package/dist/observability/engine/abort-snapshot.test.d.ts +2 -0
  161. package/dist/observability/engine/abort-snapshot.test.d.ts.map +1 -0
  162. package/dist/observability/engine/abort-snapshot.test.js +66 -0
  163. package/dist/observability/engine/abort-snapshot.test.js.map +1 -0
  164. package/dist/observability/engine/api.d.ts +24 -0
  165. package/dist/observability/engine/api.d.ts.map +1 -0
  166. package/dist/observability/engine/api.js +203 -0
  167. package/dist/observability/engine/api.js.map +1 -0
  168. package/dist/observability/engine/api.test.d.ts +2 -0
  169. package/dist/observability/engine/api.test.d.ts.map +1 -0
  170. package/dist/observability/engine/api.test.js +174 -0
  171. package/dist/observability/engine/api.test.js.map +1 -0
  172. package/dist/observability/engine/checks/findings-aggregator.d.ts +6 -0
  173. package/dist/observability/engine/checks/findings-aggregator.d.ts.map +1 -0
  174. package/dist/observability/engine/checks/findings-aggregator.js +56 -0
  175. package/dist/observability/engine/checks/findings-aggregator.js.map +1 -0
  176. package/dist/observability/engine/checks/findings-aggregator.test.d.ts +2 -0
  177. package/dist/observability/engine/checks/findings-aggregator.test.d.ts.map +1 -0
  178. package/dist/observability/engine/checks/findings-aggregator.test.js +63 -0
  179. package/dist/observability/engine/checks/findings-aggregator.test.js.map +1 -0
  180. package/dist/observability/engine/checks/fix-threshold.d.ts +3 -0
  181. package/dist/observability/engine/checks/fix-threshold.d.ts.map +1 -0
  182. package/dist/observability/engine/checks/fix-threshold.js +24 -0
  183. package/dist/observability/engine/checks/fix-threshold.js.map +1 -0
  184. package/dist/observability/engine/checks/fix-threshold.test.d.ts +2 -0
  185. package/dist/observability/engine/checks/fix-threshold.test.d.ts.map +1 -0
  186. package/dist/observability/engine/checks/fix-threshold.test.js +29 -0
  187. package/dist/observability/engine/checks/fix-threshold.test.js.map +1 -0
  188. package/dist/observability/engine/checks/observability-config.d.ts +64 -0
  189. package/dist/observability/engine/checks/observability-config.d.ts.map +1 -0
  190. package/dist/observability/engine/checks/observability-config.js +56 -0
  191. package/dist/observability/engine/checks/observability-config.js.map +1 -0
  192. package/dist/observability/engine/checks/observability-config.test.d.ts +2 -0
  193. package/dist/observability/engine/checks/observability-config.test.d.ts.map +1 -0
  194. package/dist/observability/engine/checks/observability-config.test.js +39 -0
  195. package/dist/observability/engine/checks/observability-config.test.js.map +1 -0
  196. package/dist/observability/engine/checks/registry.d.ts +19 -0
  197. package/dist/observability/engine/checks/registry.d.ts.map +1 -0
  198. package/dist/observability/engine/checks/registry.js +44 -0
  199. package/dist/observability/engine/checks/registry.js.map +1 -0
  200. package/dist/observability/engine/checks/registry.test.d.ts +2 -0
  201. package/dist/observability/engine/checks/registry.test.d.ts.map +1 -0
  202. package/dist/observability/engine/checks/registry.test.js +23 -0
  203. package/dist/observability/engine/checks/registry.test.js.map +1 -0
  204. package/dist/observability/engine/checks/runner.d.ts +23 -0
  205. package/dist/observability/engine/checks/runner.d.ts.map +1 -0
  206. package/dist/observability/engine/checks/runner.js +66 -0
  207. package/dist/observability/engine/checks/runner.js.map +1 -0
  208. package/dist/observability/engine/checks/runner.test.d.ts +2 -0
  209. package/dist/observability/engine/checks/runner.test.d.ts.map +1 -0
  210. package/dist/observability/engine/checks/runner.test.js +95 -0
  211. package/dist/observability/engine/checks/runner.test.js.map +1 -0
  212. package/dist/observability/engine/doc-graph/component-parser.d.ts +3 -0
  213. package/dist/observability/engine/doc-graph/component-parser.d.ts.map +1 -0
  214. package/dist/observability/engine/doc-graph/component-parser.js +42 -0
  215. package/dist/observability/engine/doc-graph/component-parser.js.map +1 -0
  216. package/dist/observability/engine/doc-graph/component-parser.test.d.ts +2 -0
  217. package/dist/observability/engine/doc-graph/component-parser.test.d.ts.map +1 -0
  218. package/dist/observability/engine/doc-graph/component-parser.test.js +40 -0
  219. package/dist/observability/engine/doc-graph/component-parser.test.js.map +1 -0
  220. package/dist/observability/engine/doc-graph/component-use-detector.d.ts +8 -0
  221. package/dist/observability/engine/doc-graph/component-use-detector.d.ts.map +1 -0
  222. package/dist/observability/engine/doc-graph/component-use-detector.js +62 -0
  223. package/dist/observability/engine/doc-graph/component-use-detector.js.map +1 -0
  224. package/dist/observability/engine/doc-graph/component-use-detector.test.d.ts +2 -0
  225. package/dist/observability/engine/doc-graph/component-use-detector.test.d.ts.map +1 -0
  226. package/dist/observability/engine/doc-graph/component-use-detector.test.js +38 -0
  227. package/dist/observability/engine/doc-graph/component-use-detector.test.js.map +1 -0
  228. package/dist/observability/engine/doc-graph/decision-parser.d.ts +3 -0
  229. package/dist/observability/engine/doc-graph/decision-parser.d.ts.map +1 -0
  230. package/dist/observability/engine/doc-graph/decision-parser.js +60 -0
  231. package/dist/observability/engine/doc-graph/decision-parser.js.map +1 -0
  232. package/dist/observability/engine/doc-graph/decision-parser.test.d.ts +2 -0
  233. package/dist/observability/engine/doc-graph/decision-parser.test.d.ts.map +1 -0
  234. package/dist/observability/engine/doc-graph/decision-parser.test.js +65 -0
  235. package/dist/observability/engine/doc-graph/decision-parser.test.js.map +1 -0
  236. package/dist/observability/engine/doc-graph/design-props.d.ts +9 -0
  237. package/dist/observability/engine/doc-graph/design-props.d.ts.map +1 -0
  238. package/dist/observability/engine/doc-graph/design-props.js +50 -0
  239. package/dist/observability/engine/doc-graph/design-props.js.map +1 -0
  240. package/dist/observability/engine/doc-graph/edge-builder.d.ts +28 -0
  241. package/dist/observability/engine/doc-graph/edge-builder.d.ts.map +1 -0
  242. package/dist/observability/engine/doc-graph/edge-builder.js +75 -0
  243. package/dist/observability/engine/doc-graph/edge-builder.js.map +1 -0
  244. package/dist/observability/engine/doc-graph/edge-builder.test.d.ts +2 -0
  245. package/dist/observability/engine/doc-graph/edge-builder.test.d.ts.map +1 -0
  246. package/dist/observability/engine/doc-graph/edge-builder.test.js +124 -0
  247. package/dist/observability/engine/doc-graph/edge-builder.test.js.map +1 -0
  248. package/dist/observability/engine/doc-graph/feature-parser.d.ts +3 -0
  249. package/dist/observability/engine/doc-graph/feature-parser.d.ts.map +1 -0
  250. package/dist/observability/engine/doc-graph/feature-parser.js +78 -0
  251. package/dist/observability/engine/doc-graph/feature-parser.js.map +1 -0
  252. package/dist/observability/engine/doc-graph/feature-parser.test.d.ts +2 -0
  253. package/dist/observability/engine/doc-graph/feature-parser.test.d.ts.map +1 -0
  254. package/dist/observability/engine/doc-graph/feature-parser.test.js +51 -0
  255. package/dist/observability/engine/doc-graph/feature-parser.test.js.map +1 -0
  256. package/dist/observability/engine/doc-graph/index.d.ts +3 -0
  257. package/dist/observability/engine/doc-graph/index.d.ts.map +1 -0
  258. package/dist/observability/engine/doc-graph/index.js +138 -0
  259. package/dist/observability/engine/doc-graph/index.js.map +1 -0
  260. package/dist/observability/engine/doc-graph/index.test.d.ts +2 -0
  261. package/dist/observability/engine/doc-graph/index.test.d.ts.map +1 -0
  262. package/dist/observability/engine/doc-graph/index.test.js +82 -0
  263. package/dist/observability/engine/doc-graph/index.test.js.map +1 -0
  264. package/dist/observability/engine/doc-graph/parse-markdown.d.ts +15 -0
  265. package/dist/observability/engine/doc-graph/parse-markdown.d.ts.map +1 -0
  266. package/dist/observability/engine/doc-graph/parse-markdown.js +79 -0
  267. package/dist/observability/engine/doc-graph/parse-markdown.js.map +1 -0
  268. package/dist/observability/engine/doc-graph/parse-markdown.test.d.ts +2 -0
  269. package/dist/observability/engine/doc-graph/parse-markdown.test.d.ts.map +1 -0
  270. package/dist/observability/engine/doc-graph/parse-markdown.test.js +50 -0
  271. package/dist/observability/engine/doc-graph/parse-markdown.test.js.map +1 -0
  272. package/dist/observability/engine/doc-graph/plan-task-parser.d.ts +3 -0
  273. package/dist/observability/engine/doc-graph/plan-task-parser.d.ts.map +1 -0
  274. package/dist/observability/engine/doc-graph/plan-task-parser.js +38 -0
  275. package/dist/observability/engine/doc-graph/plan-task-parser.js.map +1 -0
  276. package/dist/observability/engine/doc-graph/plan-task-parser.test.d.ts +2 -0
  277. package/dist/observability/engine/doc-graph/plan-task-parser.test.d.ts.map +1 -0
  278. package/dist/observability/engine/doc-graph/plan-task-parser.test.js +38 -0
  279. package/dist/observability/engine/doc-graph/plan-task-parser.test.js.map +1 -0
  280. package/dist/observability/engine/doc-graph/playbook-task-parser.d.ts +3 -0
  281. package/dist/observability/engine/doc-graph/playbook-task-parser.d.ts.map +1 -0
  282. package/dist/observability/engine/doc-graph/playbook-task-parser.js +40 -0
  283. package/dist/observability/engine/doc-graph/playbook-task-parser.js.map +1 -0
  284. package/dist/observability/engine/doc-graph/playbook-task-parser.test.d.ts +2 -0
  285. package/dist/observability/engine/doc-graph/playbook-task-parser.test.d.ts.map +1 -0
  286. package/dist/observability/engine/doc-graph/playbook-task-parser.test.js +31 -0
  287. package/dist/observability/engine/doc-graph/playbook-task-parser.test.js.map +1 -0
  288. package/dist/observability/engine/doc-graph/rule-parser.d.ts +3 -0
  289. package/dist/observability/engine/doc-graph/rule-parser.d.ts.map +1 -0
  290. package/dist/observability/engine/doc-graph/rule-parser.js +65 -0
  291. package/dist/observability/engine/doc-graph/rule-parser.js.map +1 -0
  292. package/dist/observability/engine/doc-graph/rule-parser.test.d.ts +2 -0
  293. package/dist/observability/engine/doc-graph/rule-parser.test.d.ts.map +1 -0
  294. package/dist/observability/engine/doc-graph/rule-parser.test.js +44 -0
  295. package/dist/observability/engine/doc-graph/rule-parser.test.js.map +1 -0
  296. package/dist/observability/engine/doc-graph/story-parser.d.ts +8 -0
  297. package/dist/observability/engine/doc-graph/story-parser.d.ts.map +1 -0
  298. package/dist/observability/engine/doc-graph/story-parser.js +109 -0
  299. package/dist/observability/engine/doc-graph/story-parser.js.map +1 -0
  300. package/dist/observability/engine/doc-graph/story-parser.test.d.ts +2 -0
  301. package/dist/observability/engine/doc-graph/story-parser.test.d.ts.map +1 -0
  302. package/dist/observability/engine/doc-graph/story-parser.test.js +66 -0
  303. package/dist/observability/engine/doc-graph/story-parser.test.js.map +1 -0
  304. package/dist/observability/engine/doc-graph/test-discovery.d.ts +3 -0
  305. package/dist/observability/engine/doc-graph/test-discovery.d.ts.map +1 -0
  306. package/dist/observability/engine/doc-graph/test-discovery.js +122 -0
  307. package/dist/observability/engine/doc-graph/test-discovery.js.map +1 -0
  308. package/dist/observability/engine/doc-graph/test-discovery.test.d.ts +2 -0
  309. package/dist/observability/engine/doc-graph/test-discovery.test.d.ts.map +1 -0
  310. package/dist/observability/engine/doc-graph/test-discovery.test.js +39 -0
  311. package/dist/observability/engine/doc-graph/test-discovery.test.js.map +1 -0
  312. package/dist/observability/engine/doc-graph/token-parser.d.ts +3 -0
  313. package/dist/observability/engine/doc-graph/token-parser.d.ts.map +1 -0
  314. package/dist/observability/engine/doc-graph/token-parser.js +67 -0
  315. package/dist/observability/engine/doc-graph/token-parser.js.map +1 -0
  316. package/dist/observability/engine/doc-graph/token-parser.test.d.ts +2 -0
  317. package/dist/observability/engine/doc-graph/token-parser.test.d.ts.map +1 -0
  318. package/dist/observability/engine/doc-graph/token-parser.test.js +39 -0
  319. package/dist/observability/engine/doc-graph/token-parser.test.js.map +1 -0
  320. package/dist/observability/engine/doc-graph/token-use-detector.d.ts +10 -0
  321. package/dist/observability/engine/doc-graph/token-use-detector.d.ts.map +1 -0
  322. package/dist/observability/engine/doc-graph/token-use-detector.js +105 -0
  323. package/dist/observability/engine/doc-graph/token-use-detector.js.map +1 -0
  324. package/dist/observability/engine/doc-graph/token-use-detector.test.d.ts +2 -0
  325. package/dist/observability/engine/doc-graph/token-use-detector.test.d.ts.map +1 -0
  326. package/dist/observability/engine/doc-graph/token-use-detector.test.js +60 -0
  327. package/dist/observability/engine/doc-graph/token-use-detector.test.js.map +1 -0
  328. package/dist/observability/engine/event-schemas.d.ts +12 -0
  329. package/dist/observability/engine/event-schemas.d.ts.map +1 -0
  330. package/dist/observability/engine/event-schemas.js +182 -0
  331. package/dist/observability/engine/event-schemas.js.map +1 -0
  332. package/dist/observability/engine/event-schemas.test.d.ts +2 -0
  333. package/dist/observability/engine/event-schemas.test.d.ts.map +1 -0
  334. package/dist/observability/engine/event-schemas.test.js +200 -0
  335. package/dist/observability/engine/event-schemas.test.js.map +1 -0
  336. package/dist/observability/engine/fix-agent-dispatcher.d.ts +19 -0
  337. package/dist/observability/engine/fix-agent-dispatcher.d.ts.map +1 -0
  338. package/dist/observability/engine/fix-agent-dispatcher.js +88 -0
  339. package/dist/observability/engine/fix-agent-dispatcher.js.map +1 -0
  340. package/dist/observability/engine/fix-agent-dispatcher.test.d.ts +2 -0
  341. package/dist/observability/engine/fix-agent-dispatcher.test.d.ts.map +1 -0
  342. package/dist/observability/engine/fix-agent-dispatcher.test.js +54 -0
  343. package/dist/observability/engine/fix-agent-dispatcher.test.js.map +1 -0
  344. package/dist/observability/engine/fix-flow.d.ts +30 -0
  345. package/dist/observability/engine/fix-flow.d.ts.map +1 -0
  346. package/dist/observability/engine/fix-flow.js +105 -0
  347. package/dist/observability/engine/fix-flow.js.map +1 -0
  348. package/dist/observability/engine/fix-flow.test.d.ts +2 -0
  349. package/dist/observability/engine/fix-flow.test.d.ts.map +1 -0
  350. package/dist/observability/engine/fix-flow.test.js +127 -0
  351. package/dist/observability/engine/fix-flow.test.js.map +1 -0
  352. package/dist/observability/engine/fix-plan.d.ts +3 -0
  353. package/dist/observability/engine/fix-plan.d.ts.map +1 -0
  354. package/dist/observability/engine/fix-plan.js +13 -0
  355. package/dist/observability/engine/fix-plan.js.map +1 -0
  356. package/dist/observability/engine/fix-plan.test.d.ts +2 -0
  357. package/dist/observability/engine/fix-plan.test.d.ts.map +1 -0
  358. package/dist/observability/engine/fix-plan.test.js +44 -0
  359. package/dist/observability/engine/fix-plan.test.js.map +1 -0
  360. package/dist/observability/engine/harvester.d.ts +16 -0
  361. package/dist/observability/engine/harvester.d.ts.map +1 -0
  362. package/dist/observability/engine/harvester.js +106 -0
  363. package/dist/observability/engine/harvester.js.map +1 -0
  364. package/dist/observability/engine/harvester.test.d.ts +2 -0
  365. package/dist/observability/engine/harvester.test.d.ts.map +1 -0
  366. package/dist/observability/engine/harvester.test.js +99 -0
  367. package/dist/observability/engine/harvester.test.js.map +1 -0
  368. package/dist/observability/engine/identity.d.ts +6 -0
  369. package/dist/observability/engine/identity.d.ts.map +1 -0
  370. package/dist/observability/engine/identity.js +50 -0
  371. package/dist/observability/engine/identity.js.map +1 -0
  372. package/dist/observability/engine/identity.test.d.ts +2 -0
  373. package/dist/observability/engine/identity.test.d.ts.map +1 -0
  374. package/dist/observability/engine/identity.test.js +29 -0
  375. package/dist/observability/engine/identity.test.js.map +1 -0
  376. package/dist/observability/engine/ledger-writer.d.ts +10 -0
  377. package/dist/observability/engine/ledger-writer.d.ts.map +1 -0
  378. package/dist/observability/engine/ledger-writer.js +50 -0
  379. package/dist/observability/engine/ledger-writer.js.map +1 -0
  380. package/dist/observability/engine/ledger-writer.test.d.ts +2 -0
  381. package/dist/observability/engine/ledger-writer.test.d.ts.map +1 -0
  382. package/dist/observability/engine/ledger-writer.test.js +72 -0
  383. package/dist/observability/engine/ledger-writer.test.js.map +1 -0
  384. package/dist/observability/engine/llm-dispatcher.d.ts +16 -0
  385. package/dist/observability/engine/llm-dispatcher.d.ts.map +1 -0
  386. package/dist/observability/engine/llm-dispatcher.js +183 -0
  387. package/dist/observability/engine/llm-dispatcher.js.map +1 -0
  388. package/dist/observability/engine/llm-dispatcher.test.d.ts +2 -0
  389. package/dist/observability/engine/llm-dispatcher.test.d.ts.map +1 -0
  390. package/dist/observability/engine/llm-dispatcher.test.js +109 -0
  391. package/dist/observability/engine/llm-dispatcher.test.js.map +1 -0
  392. package/dist/observability/engine/phase-audit.d.ts +22 -0
  393. package/dist/observability/engine/phase-audit.d.ts.map +1 -0
  394. package/dist/observability/engine/phase-audit.js +98 -0
  395. package/dist/observability/engine/phase-audit.js.map +1 -0
  396. package/dist/observability/engine/phase-audit.test.d.ts +2 -0
  397. package/dist/observability/engine/phase-audit.test.d.ts.map +1 -0
  398. package/dist/observability/engine/phase-audit.test.js +82 -0
  399. package/dist/observability/engine/phase-audit.test.js.map +1 -0
  400. package/dist/observability/engine/phase-subsets.d.ts +5 -0
  401. package/dist/observability/engine/phase-subsets.d.ts.map +1 -0
  402. package/dist/observability/engine/phase-subsets.js +23 -0
  403. package/dist/observability/engine/phase-subsets.js.map +1 -0
  404. package/dist/observability/engine/phase-subsets.test.d.ts +2 -0
  405. package/dist/observability/engine/phase-subsets.test.d.ts.map +1 -0
  406. package/dist/observability/engine/phase-subsets.test.js +24 -0
  407. package/dist/observability/engine/phase-subsets.test.js.map +1 -0
  408. package/dist/observability/engine/redact.d.ts +9 -0
  409. package/dist/observability/engine/redact.d.ts.map +1 -0
  410. package/dist/observability/engine/redact.js +134 -0
  411. package/dist/observability/engine/redact.js.map +1 -0
  412. package/dist/observability/engine/redact.test.d.ts +2 -0
  413. package/dist/observability/engine/redact.test.d.ts.map +1 -0
  414. package/dist/observability/engine/redact.test.js +244 -0
  415. package/dist/observability/engine/redact.test.js.map +1 -0
  416. package/dist/observability/engine/stall.d.ts +13 -0
  417. package/dist/observability/engine/stall.d.ts.map +1 -0
  418. package/dist/observability/engine/stall.js +167 -0
  419. package/dist/observability/engine/stall.js.map +1 -0
  420. package/dist/observability/engine/stall.test.d.ts +2 -0
  421. package/dist/observability/engine/stall.test.d.ts.map +1 -0
  422. package/dist/observability/engine/stall.test.js +148 -0
  423. package/dist/observability/engine/stall.test.js.map +1 -0
  424. package/dist/observability/engine/synthesizer.d.ts +35 -0
  425. package/dist/observability/engine/synthesizer.d.ts.map +1 -0
  426. package/dist/observability/engine/synthesizer.js +298 -0
  427. package/dist/observability/engine/synthesizer.js.map +1 -0
  428. package/dist/observability/engine/synthesizer.test.d.ts +2 -0
  429. package/dist/observability/engine/synthesizer.test.d.ts.map +1 -0
  430. package/dist/observability/engine/synthesizer.test.js +183 -0
  431. package/dist/observability/engine/synthesizer.test.js.map +1 -0
  432. package/dist/observability/engine/types.d.ts +422 -0
  433. package/dist/observability/engine/types.d.ts.map +1 -0
  434. package/dist/observability/engine/types.js +3 -0
  435. package/dist/observability/engine/types.js.map +1 -0
  436. package/dist/observability/engine/types.test.d.ts +2 -0
  437. package/dist/observability/engine/types.test.d.ts.map +1 -0
  438. package/dist/observability/engine/types.test.js +16 -0
  439. package/dist/observability/engine/types.test.js.map +1 -0
  440. package/dist/observability/renderers/_lib.d.ts +7 -0
  441. package/dist/observability/renderers/_lib.d.ts.map +1 -0
  442. package/dist/observability/renderers/_lib.js +28 -0
  443. package/dist/observability/renderers/_lib.js.map +1 -0
  444. package/dist/observability/renderers/dashboard.d.ts +5 -0
  445. package/dist/observability/renderers/dashboard.d.ts.map +1 -0
  446. package/dist/observability/renderers/dashboard.js +100 -0
  447. package/dist/observability/renderers/dashboard.js.map +1 -0
  448. package/dist/observability/renderers/dashboard.test.d.ts +2 -0
  449. package/dist/observability/renderers/dashboard.test.d.ts.map +1 -0
  450. package/dist/observability/renderers/dashboard.test.js +142 -0
  451. package/dist/observability/renderers/dashboard.test.js.map +1 -0
  452. package/dist/observability/renderers/markdown.d.ts +4 -0
  453. package/dist/observability/renderers/markdown.d.ts.map +1 -0
  454. package/dist/observability/renderers/markdown.js +225 -0
  455. package/dist/observability/renderers/markdown.js.map +1 -0
  456. package/dist/observability/renderers/markdown.test.d.ts +2 -0
  457. package/dist/observability/renderers/markdown.test.d.ts.map +1 -0
  458. package/dist/observability/renderers/markdown.test.js +169 -0
  459. package/dist/observability/renderers/markdown.test.js.map +1 -0
  460. package/dist/observability/renderers/mmr-findings.d.ts +10 -0
  461. package/dist/observability/renderers/mmr-findings.d.ts.map +1 -0
  462. package/dist/observability/renderers/mmr-findings.js +21 -0
  463. package/dist/observability/renderers/mmr-findings.js.map +1 -0
  464. package/dist/observability/renderers/mmr-findings.test.d.ts +2 -0
  465. package/dist/observability/renderers/mmr-findings.test.d.ts.map +1 -0
  466. package/dist/observability/renderers/mmr-findings.test.js +86 -0
  467. package/dist/observability/renderers/mmr-findings.test.js.map +1 -0
  468. package/dist/observability/renderers/sidecar.d.ts +5 -0
  469. package/dist/observability/renderers/sidecar.d.ts.map +1 -0
  470. package/dist/observability/renderers/sidecar.js +51 -0
  471. package/dist/observability/renderers/sidecar.js.map +1 -0
  472. package/dist/observability/renderers/sidecar.test.d.ts +2 -0
  473. package/dist/observability/renderers/sidecar.test.d.ts.map +1 -0
  474. package/dist/observability/renderers/sidecar.test.js +77 -0
  475. package/dist/observability/renderers/sidecar.test.js.map +1 -0
  476. package/dist/observability/renderers/terminal.d.ts +7 -0
  477. package/dist/observability/renderers/terminal.d.ts.map +1 -0
  478. package/dist/observability/renderers/terminal.js +96 -0
  479. package/dist/observability/renderers/terminal.js.map +1 -0
  480. package/dist/observability/renderers/terminal.test.d.ts +2 -0
  481. package/dist/observability/renderers/terminal.test.d.ts.map +1 -0
  482. package/dist/observability/renderers/terminal.test.js +163 -0
  483. package/dist/observability/renderers/terminal.test.js.map +1 -0
  484. package/dist/state/state-manager.d.ts +7 -2
  485. package/dist/state/state-manager.d.ts.map +1 -1
  486. package/dist/state/state-manager.js +31 -2
  487. package/dist/state/state-manager.js.map +1 -1
  488. package/dist/state/state-manager.test.js +88 -3
  489. package/dist/state/state-manager.test.js.map +1 -1
  490. package/dist/types/state.d.ts +2 -0
  491. package/dist/types/state.d.ts.map +1 -1
  492. package/package.json +16 -1
@@ -0,0 +1,52 @@
1
+ import { access, readFile } from 'node:fs/promises';
2
+ import { join } from 'node:path';
3
+ const REL = '.scaffold/last-test-run.json';
4
+ export const testsAdapter = {
5
+ id: 'tests',
6
+ async probe(cwd) {
7
+ try {
8
+ await access(join(cwd, REL));
9
+ }
10
+ catch {
11
+ return { status: 'unavailable', reason: 'no cached test run; run tests to populate' };
12
+ }
13
+ return { status: 'available', evidence_paths: [REL] };
14
+ },
15
+ async lastRun(cwd) {
16
+ try {
17
+ return JSON.parse(await readFile(join(cwd, REL), 'utf8'));
18
+ }
19
+ catch {
20
+ return null;
21
+ }
22
+ },
23
+ async replayEvents(cwd, opts) {
24
+ const run = await testsAdapter.lastRun(cwd);
25
+ if (!run)
26
+ return [];
27
+ const cutoff = new Date(Date.now() - opts.sinceHours * 3_600_000).toISOString();
28
+ if (run.ran_at < cutoff)
29
+ return [];
30
+ const out = [{
31
+ sort_id: `tests:run:${run.ran_at}`,
32
+ correlation_id: null,
33
+ ts: run.ran_at,
34
+ source: 'tests', kind: 'test_run_completed',
35
+ summary: `tests: ${run.passed} passed, ${run.failed} failed`,
36
+ }];
37
+ if (run.failed > 0) {
38
+ const firstFail = run.results.find((r) => r.status === 'failing');
39
+ if (firstFail) {
40
+ out.push({
41
+ sort_id: `tests:fail:${firstFail.file_path}:${firstFail.name}`,
42
+ correlation_id: null,
43
+ ts: run.ran_at,
44
+ source: 'tests', kind: 'test_run_failed',
45
+ summary: `failing: ${firstFail.name} (${firstFail.file_path})`,
46
+ });
47
+ }
48
+ }
49
+ return out;
50
+ },
51
+ };
52
+ //# sourceMappingURL=tests.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tests.js","sourceRoot":"","sources":["../../../src/observability/adapters/tests.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAiBhC,MAAM,GAAG,GAAG,8BAA8B,CAAA;AAE1C,MAAM,CAAC,MAAM,YAAY,GAGrB;IACF,EAAE,EAAE,OAAO;IAEX,KAAK,CAAC,KAAK,CAAC,GAAW;QACrB,IAAI,CAAC;YACH,MAAM,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QAC9B,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,2CAA2C,EAAE,CAAA;QACvF,CAAC;QACD,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,GAAG,CAAC,EAAE,CAAA;IACvD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,GAAW;QACvB,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,QAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,MAAM,CAAC,CAAY,CAAA;QACtE,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAI,CAAA;QACb,CAAC;IACH,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,GAAW,EAAE,IAA4B;QAC1D,MAAM,GAAG,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAC3C,IAAI,CAAC,GAAG;YAAE,OAAO,EAAE,CAAA;QACnB,MAAM,MAAM,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC,WAAW,EAAE,CAAA;QAC/E,IAAI,GAAG,CAAC,MAAM,GAAG,MAAM;YAAE,OAAO,EAAE,CAAA;QAClC,MAAM,GAAG,GAAkB,CAAC;gBAC1B,OAAO,EAAE,aAAa,GAAG,CAAC,MAAM,EAAE;gBAClC,cAAc,EAAE,IAAI;gBACpB,EAAE,EAAE,GAAG,CAAC,MAAM;gBACd,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,oBAAoB;gBAC3C,OAAO,EAAE,UAAU,GAAG,CAAC,MAAM,YAAY,GAAG,CAAC,MAAM,SAAS;aAC7D,CAAC,CAAA;QACF,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACnB,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC,CAAA;YACjE,IAAI,SAAS,EAAE,CAAC;gBACd,GAAG,CAAC,IAAI,CAAC;oBACP,OAAO,EAAE,cAAc,SAAS,CAAC,SAAS,IAAI,SAAS,CAAC,IAAI,EAAE;oBAC9D,cAAc,EAAE,IAAI;oBACpB,EAAE,EAAE,GAAG,CAAC,MAAM;oBACd,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,iBAAiB;oBACxC,OAAO,EAAE,YAAY,SAAS,CAAC,IAAI,KAAK,SAAS,CAAC,SAAS,GAAG;iBAC/D,CAAC,CAAA;YACJ,CAAC;QACH,CAAC;QACD,OAAO,GAAG,CAAA;IACZ,CAAC;CACF,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tests.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tests.test.d.ts","sourceRoot":"","sources":["../../../src/observability/adapters/tests.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,66 @@
1
+ import { describe, it, expect, beforeEach, afterEach } from 'vitest';
2
+ import { mkdtempSync, rmSync, writeFileSync, mkdirSync } from 'node:fs';
3
+ import { tmpdir } from 'node:os';
4
+ import { join } from 'node:path';
5
+ import { testsAdapter } from './tests.js';
6
+ describe('tests adapter', () => {
7
+ let dir;
8
+ beforeEach(() => { dir = mkdtempSync(join(tmpdir(), 'observe-t-')); });
9
+ afterEach(() => { rmSync(dir, { recursive: true, force: true }); });
10
+ it('probe returns unavailable when no cached run exists', async () => {
11
+ const s = await testsAdapter.probe(dir);
12
+ expect(s.status).toBe('unavailable');
13
+ });
14
+ it('probe returns available when last-test-run.json exists', async () => {
15
+ mkdirSync(join(dir, '.scaffold'), { recursive: true });
16
+ writeFileSync(join(dir, '.scaffold/last-test-run.json'), JSON.stringify({
17
+ ran_at: '2026-04-30T00:00:00Z',
18
+ passed: 100,
19
+ failed: 0,
20
+ results: [{ name: 't1', file_path: 'src/a.test.ts', status: 'passing' }],
21
+ }));
22
+ const s = await testsAdapter.probe(dir);
23
+ expect(s.status).toBe('available');
24
+ expect(s.evidence_paths).toEqual(['.scaffold/last-test-run.json']);
25
+ });
26
+ it('lastRun returns parsed results when available', async () => {
27
+ mkdirSync(join(dir, '.scaffold'), { recursive: true });
28
+ writeFileSync(join(dir, '.scaffold/last-test-run.json'), JSON.stringify({
29
+ ran_at: '2026-04-30T00:00:00Z',
30
+ passed: 1,
31
+ failed: 0,
32
+ results: [{ name: 't1', file_path: 'src/a.test.ts', status: 'passing' }],
33
+ }));
34
+ const r = await testsAdapter.lastRun(dir);
35
+ expect(r?.results[0].status).toBe('passing');
36
+ });
37
+ });
38
+ describe('tests adapter — replayEvents', () => {
39
+ let dir;
40
+ beforeEach(() => { dir = mkdtempSync(join(tmpdir(), 'observe-t-rep-')); });
41
+ afterEach(() => { rmSync(dir, { recursive: true, force: true }); });
42
+ it('returns one ReplayEvent per cached test run (failed runs noted)', async () => {
43
+ mkdirSync(join(dir, '.scaffold'), { recursive: true });
44
+ const recentTs = new Date(Date.now() - 1 * 3_600_000).toISOString();
45
+ writeFileSync(join(dir, '.scaffold/last-test-run.json'), JSON.stringify({
46
+ ran_at: recentTs,
47
+ passed: 100, failed: 2,
48
+ results: [
49
+ { name: 'login passes', file_path: 'src/a.test.ts', status: 'passing' },
50
+ { name: 'reset broken', file_path: 'src/b.test.ts', status: 'failing' },
51
+ ],
52
+ }));
53
+ const events = await testsAdapter.replayEvents(dir, { sinceHours: 24 });
54
+ expect(events).toHaveLength(2);
55
+ const run = events.find((e) => e.kind === 'test_run_completed');
56
+ const failure = events.find((e) => e.kind === 'test_run_failed');
57
+ expect(run).toBeDefined();
58
+ expect(failure).toBeDefined();
59
+ expect(run?.summary).toContain('100 passed');
60
+ expect(failure?.summary).toContain('reset broken');
61
+ });
62
+ it('returns [] when no cached run exists', async () => {
63
+ expect(await testsAdapter.replayEvents(dir, { sinceHours: 24 })).toEqual([]);
64
+ });
65
+ });
66
+ //# sourceMappingURL=tests.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tests.test.js","sourceRoot":"","sources":["../../../src/observability/adapters/tests.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAA;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AACvE,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAA;AAChC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAA;AAChC,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAEzC,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,IAAI,GAAW,CAAA;IACf,UAAU,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,YAAY,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;IACrE,SAAS,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;IAElE,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACvC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA;IACtC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wDAAwD,EAAE,KAAK,IAAI,EAAE;QACtE,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QACtD,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,8BAA8B,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC;YACtE,MAAM,EAAE,sBAAsB;YAC9B,MAAM,EAAE,GAAG;YACX,MAAM,EAAE,CAAC;YACT,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SACzE,CAAC,CAAC,CAAA;QACH,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;QACvC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;QAClC,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,CAAC,8BAA8B,CAAC,CAAC,CAAA;IACpE,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QACtD,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,8BAA8B,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC;YACtE,MAAM,EAAE,sBAAsB;YAC9B,MAAM,EAAE,CAAC;YACT,MAAM,EAAE,CAAC;YACT,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC;SACzE,CAAC,CAAC,CAAA;QACH,MAAM,CAAC,GAAG,MAAM,YAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QACzC,MAAM,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAC9C,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA;AAEF,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,IAAI,GAAW,CAAA;IACf,UAAU,CAAC,GAAG,EAAE,GAAG,GAAG,GAAG,WAAW,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,gBAAgB,CAAC,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;IACzE,SAAS,CAAC,GAAG,EAAE,GAAG,MAAM,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA,CAAC,CAAC,CAAC,CAAA;IAElE,EAAE,CAAC,iEAAiE,EAAE,KAAK,IAAI,EAAE;QAC/E,SAAS,CAAC,IAAI,CAAC,GAAG,EAAE,WAAW,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QACtD,MAAM,QAAQ,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC,WAAW,EAAE,CAAA;QACnE,aAAa,CAAC,IAAI,CAAC,GAAG,EAAE,8BAA8B,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC;YACtE,MAAM,EAAE,QAAQ;YAChB,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC;YACtB,OAAO,EAAE;gBACP,EAAE,IAAI,EAAE,cAAc,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE;gBACvE,EAAE,IAAI,EAAE,cAAc,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,EAAE,SAAS,EAAE;aACxE;SACF,CAAC,CAAC,CAAA;QACH,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,YAAY,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,CAAA;QACvE,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,oBAAoB,CAAC,CAAA;QAC/D,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,iBAAiB,CAAC,CAAA;QAChE,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAA;QACzB,MAAM,CAAC,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QAC7B,MAAM,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAA;QAC5C,MAAM,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAA;IACpD,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,CAAC,MAAM,YAAY,CAAC,YAAY,CAAC,GAAG,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;IAC9E,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
@@ -0,0 +1,7 @@
1
+ import type { AdapterId, AdapterStatus } from '../engine/types.js';
2
+ export type { AdapterId, AdapterStatus };
3
+ export interface BaseAdapter {
4
+ readonly id: AdapterId;
5
+ probe(cwd: string): Promise<AdapterStatus>;
6
+ }
7
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/observability/adapters/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAA;AAElE,YAAY,EAAE,SAAS,EAAE,aAAa,EAAE,CAAA;AAExC,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,EAAE,EAAE,SAAS,CAAA;IACtB,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAAA;CAC3C"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/observability/adapters/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,3 @@
1
+ import type { LensFn } from '../engine/checks/runner.js';
2
+ export declare const lensATdd: LensFn;
3
+ //# sourceMappingURL=lens-a-tdd.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-a-tdd.d.ts","sourceRoot":"","sources":["../../../src/observability/checks/lens-a-tdd.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAQxD,eAAO,MAAM,QAAQ,EAAE,MA8BtB,CAAA"}
@@ -0,0 +1,34 @@
1
+ import { createHash } from 'node:crypto';
2
+ const lensId = 'A-tdd';
3
+ function makeFindingId(parts) {
4
+ return createHash('sha256').update(parts.join('::')).digest('hex').slice(0, 16);
5
+ }
6
+ export const lensATdd = async (graph) => {
7
+ const findings = [];
8
+ const now = new Date().toISOString();
9
+ // (b) Detect skipped tests via last_status set during discovery
10
+ for (const test of graph.tests) {
11
+ if (test.last_status !== 'skip')
12
+ continue;
13
+ const acEdge = graph.edges.find((e) => e.kind === 'ac_to_test' && e.to === test.id);
14
+ const acId = acEdge?.from;
15
+ const storyId = acId ? graph.acceptance_criteria.find((a) => a.id === acId)?.story_id : undefined;
16
+ const story = storyId ? graph.stories.find((s) => s.id === storyId) : undefined;
17
+ const severity = story?.priority === 'must' ? 'P0' : 'P1';
18
+ findings.push({
19
+ id: makeFindingId([lensId, 'skip', test.file_path, test.name]),
20
+ lens_id: lensId,
21
+ severity,
22
+ title: `skipped test: ${test.name}`,
23
+ description: `Test "${test.name}" (${test.file_path}) is skipped.`,
24
+ source_doc: 'docs/tdd-standards.md',
25
+ evidence: { kind: 'rule_violation', rule_id: 'tdd-no-skip', file: `file:${test.file_path}` },
26
+ confidence: 'high',
27
+ first_seen: now, last_seen: now,
28
+ status: 'open',
29
+ fix_hint: { kind: 'add_test', target: test.file_path, prompt: `Re-enable test "${test.name}".` },
30
+ });
31
+ }
32
+ return findings;
33
+ };
34
+ //# sourceMappingURL=lens-a-tdd.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-a-tdd.js","sourceRoot":"","sources":["../../../src/observability/checks/lens-a-tdd.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAIxC,MAAM,MAAM,GAAG,OAAO,CAAA;AAEtB,SAAS,aAAa,CAAC,KAAe;IACpC,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAA;AACjF,CAAC;AAED,MAAM,CAAC,MAAM,QAAQ,GAAW,KAAK,EAAE,KAAK,EAAE,EAAE;IAC9C,MAAM,QAAQ,GAAc,EAAE,CAAA;IAC9B,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAA;IAEpC,gEAAgE;IAChE,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;QAC/B,IAAI,IAAI,CAAC,WAAW,KAAK,MAAM;YAAE,SAAQ;QAEzC,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,YAAY,IAAI,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,CAAA;QACnF,MAAM,IAAI,GAAG,MAAM,EAAE,IAAI,CAAA;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAA;QACjG,MAAM,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;QAC/E,MAAM,QAAQ,GAAG,KAAK,EAAE,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA;QAEzD,QAAQ,CAAC,IAAI,CAAC;YACZ,EAAE,EAAE,aAAa,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC9D,OAAO,EAAE,MAAM;YACf,QAAQ;YACR,KAAK,EAAE,iBAAiB,IAAI,CAAC,IAAI,EAAE;YACnC,WAAW,EAAE,SAAS,IAAI,CAAC,IAAI,MAAM,IAAI,CAAC,SAAS,eAAe;YAClE,UAAU,EAAE,uBAAuB;YACnC,QAAQ,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,OAAO,EAAE,aAAa,EAAE,IAAI,EAAE,QAAQ,IAAI,CAAC,SAAS,EAAE,EAAE;YAC5F,UAAU,EAAE,MAAM;YAClB,UAAU,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG;YAC/B,MAAM,EAAE,MAAM;YACd,QAAQ,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE,mBAAmB,IAAI,CAAC,IAAI,IAAI,EAAE;SACjG,CAAC,CAAA;IACJ,CAAC;IAED,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=lens-a-tdd.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-a-tdd.test.d.ts","sourceRoot":"","sources":["../../../src/observability/checks/lens-a-tdd.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,62 @@
1
+ import { describe, it, expect, beforeEach, afterEach } from 'vitest';
2
+ import { mkdtempSync, rmSync, writeFileSync, mkdirSync } from 'node:fs';
3
+ import { tmpdir } from 'node:os';
4
+ import { join } from 'node:path';
5
+ import { lensATdd } from './lens-a-tdd.js';
6
+ import { buildDocGraph } from '../engine/doc-graph/index.js';
7
+ const stubAvailability = {
8
+ git: { status: 'available' }, gh: { status: 'unavailable' },
9
+ pipeline_docs: { status: 'available' }, tests: { status: 'available' },
10
+ state: { status: 'available' }, beads: { status: 'unavailable' },
11
+ mmr: { status: 'available' }, audit_history: { status: 'unavailable' },
12
+ ledger: { events_read: 0, malformed_lines: 0, sources: [] },
13
+ };
14
+ describe('lensATdd', () => {
15
+ let dir;
16
+ beforeEach(() => { dir = mkdtempSync(join(tmpdir(), 'observe-lensA-')); });
17
+ afterEach(() => { rmSync(dir, { recursive: true, force: true }); });
18
+ it('emits P0 for skipped tests on a "must" priority story', async () => {
19
+ mkdirSync(join(dir, 'docs'), { recursive: true });
20
+ mkdirSync(join(dir, 'src'), { recursive: true });
21
+ writeFileSync(join(dir, 'package.json'), JSON.stringify({ scripts: { test: 'vitest run' } }));
22
+ writeFileSync(join(dir, 'docs/plan.md'), '# PRD\n\n## Features\n\n### User Auth [priority: must]\n');
23
+ writeFileSync(join(dir, 'docs/user-stories.md'), `## Story user-auth-1: Sign in [priority: must]
24
+
25
+ ### AC 1: signs in
26
+ Given valid credentials.
27
+ `);
28
+ writeFileSync(join(dir, 'src/auth.test.ts'), 'import { it } from \'vitest\'\nit.skip(\'AC 1: signs in\', () => {})\n');
29
+ writeFileSync(join(dir, 'docs/tdd-standards.md'), '# TDD\n\n## Tests-first policy.');
30
+ const graph = await buildDocGraph(dir);
31
+ const findings = await lensATdd(graph, { events: [] }, stubAvailability, [], new Set(['A-tdd']));
32
+ expect(findings.length).toBeGreaterThan(0);
33
+ const skipFinding = findings.find((f) => /skip/i.test(f.title));
34
+ expect(skipFinding?.severity).toBe('P0');
35
+ });
36
+ it('emits P1 for skipped tests on lower-priority stories', async () => {
37
+ mkdirSync(join(dir, 'docs'), { recursive: true });
38
+ mkdirSync(join(dir, 'src'), { recursive: true });
39
+ writeFileSync(join(dir, 'package.json'), JSON.stringify({ scripts: { test: 'vitest run' } }));
40
+ writeFileSync(join(dir, 'docs/plan.md'), '# PRD\n## Features\n### F [priority: should]\n');
41
+ writeFileSync(join(dir, 'docs/user-stories.md'), '## Story s-1: T [priority: should]\n\n### AC 1: t\n');
42
+ writeFileSync(join(dir, 'src/foo.test.ts'), 'it.skip(\'something\', () => {})\n');
43
+ writeFileSync(join(dir, 'docs/tdd-standards.md'), '# TDD\n');
44
+ const graph = await buildDocGraph(dir);
45
+ const findings = await lensATdd(graph, { events: [] }, stubAvailability, [], new Set(['A-tdd']));
46
+ const skipFinding = findings.find((f) => /skip/i.test(f.title));
47
+ expect(skipFinding?.severity).toBe('P1');
48
+ });
49
+ it('emits no findings on a clean tree', async () => {
50
+ mkdirSync(join(dir, 'docs'), { recursive: true });
51
+ mkdirSync(join(dir, 'src'), { recursive: true });
52
+ writeFileSync(join(dir, 'package.json'), JSON.stringify({ scripts: { test: 'vitest run' } }));
53
+ writeFileSync(join(dir, 'docs/plan.md'), '# PRD\n## Features\n### F [priority: must]\n');
54
+ writeFileSync(join(dir, 'docs/user-stories.md'), '## Story s-1: T [priority: must]\n\n### AC 1: t\nGiven X.\n');
55
+ writeFileSync(join(dir, 'src/foo.test.ts'), 'import { it, expect } from \'vitest\'\nit(\'AC 1: t\', () => { expect(1).toBe(1) })\n');
56
+ writeFileSync(join(dir, 'docs/tdd-standards.md'), '# TDD\n');
57
+ const graph = await buildDocGraph(dir);
58
+ const findings = await lensATdd(graph, { events: [] }, stubAvailability, [], new Set(['A-tdd']));
59
+ expect(findings).toEqual([]);
60
+ });
61
+ });
62
+ //# sourceMappingURL=lens-a-tdd.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-a-tdd.test.js","sourceRoot":"","sources":["../../../src/observability/checks/lens-a-tdd.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { LensFn } from '../engine/checks/runner.js';
2
+ export declare const lensBAcCoverage: LensFn;
3
+ //# sourceMappingURL=lens-b-ac-coverage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-b-ac-coverage.d.ts","sourceRoot":"","sources":["../../../src/observability/checks/lens-b-ac-coverage.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AAQxD,eAAO,MAAM,eAAe,EAAE,MAuD7B,CAAA"}
@@ -0,0 +1,63 @@
1
+ import { createHash } from 'node:crypto';
2
+ const lensId = 'B-ac-coverage';
3
+ function makeFindingId(parts) {
4
+ return createHash('sha256').update(parts.join('::')).digest('hex').slice(0, 16);
5
+ }
6
+ export const lensBAcCoverage = async (graph, _ledger, availability) => {
7
+ const findings = [];
8
+ const now = new Date().toISOString();
9
+ const testsAvailable = availability.tests.status === 'available';
10
+ const testById = new Map(graph.tests.map((t) => [t.id, t]));
11
+ // Structural sub-check: AC without ac_to_test edge → P1 (always)
12
+ for (const ac of graph.acceptance_criteria) {
13
+ const hasTest = graph.edges.some((e) => e.kind === 'ac_to_test' && e.from === ac.id);
14
+ if (hasTest)
15
+ continue;
16
+ findings.push({
17
+ id: makeFindingId([lensId, 'no-edge', ac.id]),
18
+ lens_id: lensId, severity: 'P1',
19
+ title: `AC has no ac_to_test edge: ${ac.id}`,
20
+ description: `Acceptance criterion ${ac.id} (story ${ac.story_id}) has no linked test.`,
21
+ source_doc: ac.source_anchor,
22
+ evidence: { kind: 'ac_not_covered', story_id: ac.story_id, ac_id: ac.id, missing_tests: [] },
23
+ confidence: 'high',
24
+ first_seen: now, last_seen: now,
25
+ status: 'open',
26
+ fix_hint: { kind: 'add_test', target: 'tests/', prompt: `Add a test exercising AC ${ac.id}.` },
27
+ });
28
+ }
29
+ // Test-execution sub-check: only when tests adapter is available
30
+ if (testsAvailable) {
31
+ for (const e of graph.edges) {
32
+ if (e.kind !== 'ac_to_test')
33
+ continue;
34
+ const t = testById.get(e.to);
35
+ if (!t)
36
+ continue;
37
+ if (t.last_status === 'fail') {
38
+ findings.push({
39
+ id: makeFindingId([lensId, 'failing', e.from, t.id]),
40
+ lens_id: lensId, severity: 'P0',
41
+ title: `AC test failing: ${e.from}`,
42
+ description: `Test "${t.name}" (${t.file_path}) for AC ${e.from} is currently failing.`,
43
+ source_doc: '',
44
+ evidence: { kind: 'rule_violation', rule_id: 'ac-test-failing', file: `file:${t.file_path}` },
45
+ confidence: 'high', first_seen: now, last_seen: now, status: 'open',
46
+ });
47
+ }
48
+ else if (t.last_status === 'unknown') {
49
+ findings.push({
50
+ id: makeFindingId([lensId, 'unknown', e.from, t.id]),
51
+ lens_id: lensId, severity: 'P1',
52
+ title: `AC test status unknown: ${e.from}`,
53
+ description: `Test "${t.name}" (${t.file_path}) exists but has not run in the audit window.`,
54
+ source_doc: '',
55
+ evidence: { kind: 'rule_violation', rule_id: 'ac-test-unknown', file: `file:${t.file_path}` },
56
+ confidence: 'medium', first_seen: now, last_seen: now, status: 'open',
57
+ });
58
+ }
59
+ }
60
+ }
61
+ return findings;
62
+ };
63
+ //# sourceMappingURL=lens-b-ac-coverage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-b-ac-coverage.js","sourceRoot":"","sources":["../../../src/observability/checks/lens-b-ac-coverage.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=lens-b-ac-coverage.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-b-ac-coverage.test.d.ts","sourceRoot":"","sources":["../../../src/observability/checks/lens-b-ac-coverage.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,59 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { lensBAcCoverage } from './lens-b-ac-coverage.js';
3
+ function graphOf(input) {
4
+ return {
5
+ cwd: '',
6
+ features: [], stories: input.stories,
7
+ acceptance_criteria: input.acs,
8
+ plan_tasks: [], playbook_tasks: [],
9
+ tests: input.tests, pull_requests: [], files: [],
10
+ rules: [], components: [], tokens: [], decisions: [],
11
+ edges: input.edges, provenance: {}, unresolved_globs: [],
12
+ };
13
+ }
14
+ function makeAvail(testsStatus) {
15
+ return {
16
+ git: { status: 'available' }, gh: { status: 'unavailable' },
17
+ pipeline_docs: { status: 'available' }, tests: { status: testsStatus },
18
+ state: { status: 'available' }, beads: { status: 'unavailable' },
19
+ mmr: { status: 'available' }, audit_history: { status: 'unavailable' },
20
+ ledger: { events_read: 0, malformed_lines: 0, sources: [] },
21
+ };
22
+ }
23
+ const story = { id: 'story:s-1', title: 'Sign in', priority: 'must', source_anchor: '' };
24
+ const ac = { id: 'ac:s-1.1', story_id: 'story:s-1', text: 'AC', source_anchor: '' };
25
+ const test = {
26
+ id: 'test:src/x.test.ts::abc123', name: 'AC 1', file_path: 'src/x.test.ts', framework: 'vitest', last_status: 'fail',
27
+ };
28
+ describe('lensBAcCoverage', () => {
29
+ it('emits P1 for AC without ac_to_test edge (structural)', async () => {
30
+ const graph = graphOf({ stories: [story], acs: [ac], tests: [], edges: [] });
31
+ const findings = await lensBAcCoverage(graph, { events: [] }, makeAvail('unavailable'), [], new Set(['B-ac-coverage']));
32
+ const f = findings.find((x) => x.evidence.kind === 'ac_not_covered');
33
+ expect(f?.severity).toBe('P1');
34
+ });
35
+ it('emits P0 for AC with failing test when tests adapter is available', async () => {
36
+ const edges = [{ kind: 'ac_to_test', from: ac.id, to: test.id }];
37
+ const graph = graphOf({ stories: [story], acs: [ac], tests: [test], edges });
38
+ const findings = await lensBAcCoverage(graph, { events: [] }, makeAvail('available'), [], new Set(['B-ac-coverage']));
39
+ const f = findings.find((x) => /failing/i.test(x.title));
40
+ expect(f?.severity).toBe('P0');
41
+ });
42
+ it('does NOT emit failing-test findings when tests adapter is unavailable', async () => {
43
+ const edges = [{ kind: 'ac_to_test', from: ac.id, to: test.id }];
44
+ const graph = graphOf({ stories: [story], acs: [ac], tests: [test], edges });
45
+ const findings = await lensBAcCoverage(graph, { events: [] }, makeAvail('unavailable'), [], new Set(['B-ac-coverage']));
46
+ const failingFinding = findings.find((x) => /failing/i.test(x.title));
47
+ expect(failingFinding).toBeUndefined();
48
+ });
49
+ it('emits no findings when ACs have passing tests and tests adapter is available', async () => {
50
+ const passingTest = { ...test, last_status: 'pass' };
51
+ const graph = graphOf({
52
+ stories: [story], acs: [ac], tests: [passingTest],
53
+ edges: [{ kind: 'ac_to_test', from: ac.id, to: passingTest.id }],
54
+ });
55
+ const findings = await lensBAcCoverage(graph, { events: [] }, makeAvail('available'), [], new Set(['B-ac-coverage']));
56
+ expect(findings).toEqual([]);
57
+ });
58
+ });
59
+ //# sourceMappingURL=lens-b-ac-coverage.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-b-ac-coverage.test.js","sourceRoot":"","sources":["../../../src/observability/checks/lens-b-ac-coverage.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { LensFn } from '../engine/checks/runner.js';
2
+ export declare const lensCStandards: LensFn;
3
+ //# sourceMappingURL=lens-c-standards.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-c-standards.d.ts","sourceRoot":"","sources":["../../../src/observability/checks/lens-c-standards.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AA6CxD,eAAO,MAAM,cAAc,EAAE,MAiD5B,CAAA"}
@@ -0,0 +1,104 @@
1
+ import { readFileSync } from 'node:fs';
2
+ import { join } from 'node:path';
3
+ import { createHash } from 'node:crypto';
4
+ import { minimatch } from 'minimatch';
5
+ import { loadObservabilityConfig } from '../engine/checks/observability-config.js';
6
+ const lensId = 'C-standards';
7
+ const DEFAULT_ESCALATION_THRESHOLD = 5;
8
+ function makeFindingId(parts) {
9
+ return createHash('sha256').update(parts.join('::')).digest('hex').slice(0, 16);
10
+ }
11
+ function findPatternViolations(rule, file, content) {
12
+ const out = [];
13
+ if (rule.pattern) {
14
+ let re;
15
+ try {
16
+ re = new RegExp(rule.pattern);
17
+ }
18
+ catch {
19
+ return out;
20
+ }
21
+ const lines = content.split('\n');
22
+ for (let i = 0; i < lines.length; i++) {
23
+ if (re.test(lines[i])) {
24
+ out.push({ rule, file, lineStart: i + 1, lineEnd: i + 1 });
25
+ }
26
+ }
27
+ }
28
+ if (rule.forbidden) {
29
+ const lines = content.split('\n');
30
+ for (const sym of rule.forbidden) {
31
+ const escaped = sym.replace(/[.*+?^${}()|[\]\\]/g, '\\$&').replace(/\s+/g, '\\s+');
32
+ const symRe = new RegExp(`\\b${escaped}\\b`);
33
+ for (let i = 0; i < lines.length; i++) {
34
+ if (symRe.test(lines[i]))
35
+ out.push({ rule, file, lineStart: i + 1, lineEnd: i + 1 });
36
+ }
37
+ }
38
+ }
39
+ return out;
40
+ }
41
+ function severityFor(rule, totalCount, escalationThreshold, override) {
42
+ if (override)
43
+ return override;
44
+ const VALID = ['P0', 'P1', 'P2', 'P3'];
45
+ if (rule.severity && VALID.includes(rule.severity))
46
+ return rule.severity;
47
+ if (totalCount > escalationThreshold)
48
+ return 'P1';
49
+ return 'P2';
50
+ }
51
+ export const lensCStandards = async (graph) => {
52
+ const findings = [];
53
+ const now = new Date().toISOString();
54
+ const cwd = graph.cwd;
55
+ const config = loadObservabilityConfig(cwd);
56
+ const overrides = config.lenses['C-standards']?.rule_overrides ?? {};
57
+ const escalationThreshold = config.lenses['C-standards']?.escalation_threshold ?? DEFAULT_ESCALATION_THRESHOLD;
58
+ const fileContents = new Map();
59
+ for (const f of graph.files) {
60
+ try {
61
+ fileContents.set(f.path, readFileSync(join(cwd, f.path), 'utf8'));
62
+ }
63
+ catch { /* skip unreadable */ }
64
+ }
65
+ const violationsByRule = new Map();
66
+ for (const rule of graph.rules) {
67
+ const matches = (file) => !rule.match || minimatch(file, rule.match);
68
+ for (const f of graph.files) {
69
+ if (!matches(f.path))
70
+ continue;
71
+ const content = fileContents.get(f.path);
72
+ if (content === undefined)
73
+ continue;
74
+ const vs = findPatternViolations(rule, f.path, content);
75
+ if (vs.length === 0)
76
+ continue;
77
+ const list = violationsByRule.get(rule.id) ?? [];
78
+ list.push(...vs);
79
+ violationsByRule.set(rule.id, list);
80
+ }
81
+ }
82
+ for (const [ruleId, vs] of violationsByRule) {
83
+ const rule = graph.rules.find((r) => r.id === ruleId);
84
+ if (!rule)
85
+ continue;
86
+ const ruleKey = rule.id.replace(/^rule:/, '');
87
+ const override = overrides[ruleKey];
88
+ const severity = severityFor(rule, vs.length, escalationThreshold, override);
89
+ for (const v of vs) {
90
+ findings.push({
91
+ id: makeFindingId([lensId, ruleId, v.file, String(v.lineStart)]),
92
+ lens_id: lensId, severity,
93
+ title: `${rule.description ?? ruleId} (${v.file}:${v.lineStart})`,
94
+ description: `Rule ${ruleId} violated at ${v.file}:${v.lineStart}.`,
95
+ source_doc: 'docs/coding-standards.md',
96
+ evidence: { kind: 'rule_violation', rule_id: ruleId, file: `file:${v.file}`, lines: [v.lineStart, v.lineEnd] },
97
+ confidence: 'high', first_seen: now, last_seen: now, status: 'open',
98
+ fix_hint: { kind: 'edit_doc', target: v.file, prompt: `Address rule ${ruleId} at ${v.file}:${v.lineStart}.` },
99
+ });
100
+ }
101
+ }
102
+ return findings;
103
+ };
104
+ //# sourceMappingURL=lens-c-standards.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-c-standards.js","sourceRoot":"","sources":["../../../src/observability/checks/lens-c-standards.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=lens-c-standards.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lens-c-standards.test.d.ts","sourceRoot":"","sources":["../../../src/observability/checks/lens-c-standards.test.ts"],"names":[],"mappings":""}