coding-agent-skills 0.2.8

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 (357) hide show
  1. package/AGENTS.md +44 -0
  2. package/CHANGELOG.md +205 -0
  3. package/CONTRIBUTING.md +54 -0
  4. package/LICENSE +21 -0
  5. package/README.md +85 -0
  6. package/ROADMAP.md +87 -0
  7. package/RUNBOOK.md +47 -0
  8. package/bin/coding-agent-skills +75 -0
  9. package/contracts/evidence-pack/README.md +22 -0
  10. package/contracts/evidence-pack/evidence-pack.example.json +60 -0
  11. package/contracts/evidence-pack/evidence-pack.example.md +49 -0
  12. package/contracts/evidence-pack/evidence-pack.schema.json +156 -0
  13. package/docs/adapters/README.md +82 -0
  14. package/docs/adapters/discovery.md +50 -0
  15. package/docs/adapters/external-adapters.md +42 -0
  16. package/docs/adapters/project-installation.md +135 -0
  17. package/docs/adapters/real-project-adoption.md +193 -0
  18. package/docs/adapters/upgrade-evidence.md +67 -0
  19. package/docs/adapters/upgrades.md +83 -0
  20. package/docs/architecture/README.md +23 -0
  21. package/docs/authoring/README.md +54 -0
  22. package/docs/evidence-bundles/README.md +94 -0
  23. package/docs/privacy/README.md +26 -0
  24. package/docs/release/README.md +42 -0
  25. package/docs/release/npm-package.md +85 -0
  26. package/docs/safety/README.md +94 -0
  27. package/docs/testing/README.md +100 -0
  28. package/docs/usage/README.md +89 -0
  29. package/docs/versioning/README.md +30 -0
  30. package/docs/versioning/adapter-compatibility.md +54 -0
  31. package/examples/README.md +12 -0
  32. package/examples/adapters/README.md +9 -0
  33. package/examples/adapters/documentation-precedence.json +62 -0
  34. package/examples/adapters/narrow-repo-map.json +64 -0
  35. package/examples/adapters/runtime-status-hints.json +76 -0
  36. package/examples/command-policies/README.md +3 -0
  37. package/examples/command-policies/build-verify.json +57 -0
  38. package/examples/command-policies/git-preflight.json +44 -0
  39. package/examples/command-policies/llm-drift-control.json +45 -0
  40. package/examples/command-policies/repo-map.json +59 -0
  41. package/examples/command-policies/runtime-truth.json +59 -0
  42. package/examples/evidence-packs/README.md +3 -0
  43. package/examples/evidence-packs/build-verify.json +68 -0
  44. package/examples/evidence-packs/git-preflight.json +55 -0
  45. package/examples/evidence-packs/llm-drift-control.json +55 -0
  46. package/examples/evidence-packs/repo-map.json +55 -0
  47. package/examples/evidence-packs/runtime-truth.json +55 -0
  48. package/examples/manifests/README.md +3 -0
  49. package/examples/manifests/build-verify.json +14 -0
  50. package/examples/manifests/git-preflight.json +14 -0
  51. package/examples/manifests/llm-drift-control.json +14 -0
  52. package/examples/manifests/repo-map.json +14 -0
  53. package/examples/manifests/runtime-truth.json +14 -0
  54. package/examples/upgrade-evidence/README.md +14 -0
  55. package/examples/upgrade-evidence/chain-fail.evidence.json +155 -0
  56. package/examples/upgrade-evidence/chain-fail.evidence.md +14 -0
  57. package/examples/upgrade-evidence/chain-pass.evidence.json +156 -0
  58. package/examples/upgrade-evidence/stale-pin.evidence.json +117 -0
  59. package/examples/upgrade-evidence/unsafe-upgrade.evidence.json +128 -0
  60. package/examples/upgrade-evidence/valid-upgrade.evidence.json +105 -0
  61. package/examples/upgrade-evidence/valid-upgrade.evidence.md +13 -0
  62. package/examples/workflows/README.md +3 -0
  63. package/examples/workflows/build-verify.md +20 -0
  64. package/examples/workflows/git-preflight.md +18 -0
  65. package/examples/workflows/llm-drift-control.md +16 -0
  66. package/examples/workflows/repo-map.md +20 -0
  67. package/examples/workflows/runtime-truth.md +17 -0
  68. package/package.json +58 -0
  69. package/runs/skill-runs.md +162 -0
  70. package/schemas/adapter-upgrade-evidence.schema.json +443 -0
  71. package/schemas/archive-index.schema.json +174 -0
  72. package/schemas/archive-report.schema.json +322 -0
  73. package/schemas/command-policy.schema.json +125 -0
  74. package/schemas/evidence-bundle.schema.json +394 -0
  75. package/schemas/project-adapter-installation.schema.json +127 -0
  76. package/schemas/project-adapter.schema.json +328 -0
  77. package/schemas/skill-manifest.schema.json +40 -0
  78. package/scripts/check-adapter-upgrade-chain.mjs +32 -0
  79. package/scripts/check-adapter-upgrade.mjs +31 -0
  80. package/scripts/lib/adapter-discovery.mjs +441 -0
  81. package/scripts/lib/adapter-repo-map.mjs +358 -0
  82. package/scripts/lib/adapter-upgrade-chain.mjs +261 -0
  83. package/scripts/lib/adapter-upgrade.mjs +434 -0
  84. package/scripts/lib/evidence-bundle.mjs +831 -0
  85. package/scripts/lib/pack-rules.mjs +704 -0
  86. package/scripts/lib/project-adapter-installation.mjs +327 -0
  87. package/scripts/lib/safe-evidence-output.mjs +92 -0
  88. package/scripts/lib/schema-validator.mjs +146 -0
  89. package/scripts/lib/semver.mjs +54 -0
  90. package/scripts/lib/upgrade-evidence.mjs +276 -0
  91. package/scripts/render-adapter-repo-map.mjs +8 -0
  92. package/scripts/render-evidence-archive-report.mjs +18 -0
  93. package/scripts/run-next +220 -0
  94. package/scripts/test-pack.mjs +2232 -0
  95. package/scripts/validate-adapters.mjs +10 -0
  96. package/scripts/validate-maintainer-loop.mjs +146 -0
  97. package/scripts/validate-pack.mjs +950 -0
  98. package/scripts/validate-project-adapters.mjs +8 -0
  99. package/scripts/verify-evidence-bundle.mjs +18 -0
  100. package/skills/build-verify/SKILL.md +62 -0
  101. package/skills/build-verify/adapter-interface.md +7 -0
  102. package/skills/build-verify/agents/openai.yaml +4 -0
  103. package/skills/build-verify/checklist.md +12 -0
  104. package/skills/build-verify/evidence-template.md +11 -0
  105. package/skills/build-verify/examples.md +16 -0
  106. package/skills/build-verify/failure-modes.md +14 -0
  107. package/skills/git-preflight/SKILL.md +65 -0
  108. package/skills/git-preflight/adapter-interface.md +7 -0
  109. package/skills/git-preflight/agents/openai.yaml +4 -0
  110. package/skills/git-preflight/checklist.md +11 -0
  111. package/skills/git-preflight/evidence-template.md +10 -0
  112. package/skills/git-preflight/examples.md +18 -0
  113. package/skills/git-preflight/failure-modes.md +13 -0
  114. package/skills/llm-drift-control/SKILL.md +67 -0
  115. package/skills/llm-drift-control/adapter-interface.md +7 -0
  116. package/skills/llm-drift-control/agents/openai.yaml +4 -0
  117. package/skills/llm-drift-control/checklist.md +11 -0
  118. package/skills/llm-drift-control/evidence-template.md +13 -0
  119. package/skills/llm-drift-control/examples.md +15 -0
  120. package/skills/llm-drift-control/failure-modes.md +13 -0
  121. package/skills/repo-map/SKILL.md +71 -0
  122. package/skills/repo-map/adapter-interface.md +18 -0
  123. package/skills/repo-map/agents/openai.yaml +4 -0
  124. package/skills/repo-map/checklist.md +15 -0
  125. package/skills/repo-map/evidence-template.md +29 -0
  126. package/skills/repo-map/examples.md +19 -0
  127. package/skills/repo-map/failure-modes.md +16 -0
  128. package/skills/runtime-truth/SKILL.md +62 -0
  129. package/skills/runtime-truth/adapter-interface.md +7 -0
  130. package/skills/runtime-truth/agents/openai.yaml +4 -0
  131. package/skills/runtime-truth/checklist.md +11 -0
  132. package/skills/runtime-truth/evidence-template.md +12 -0
  133. package/skills/runtime-truth/examples.md +20 -0
  134. package/skills/runtime-truth/failure-modes.md +13 -0
  135. package/tests/README.md +44 -0
  136. package/tests/adapters/README.md +15 -0
  137. package/tests/completion/README.md +15 -0
  138. package/tests/evidence/README.md +15 -0
  139. package/tests/fixtures/README.md +23 -0
  140. package/tests/fixtures/adapters/allow-deploy.json +60 -0
  141. package/tests/fixtures/adapters/allow-git-push.json +60 -0
  142. package/tests/fixtures/adapters/expand-scope.json +53 -0
  143. package/tests/fixtures/adapters/expose-secrets.json +53 -0
  144. package/tests/fixtures/adapters/incompatible-version.json +53 -0
  145. package/tests/fixtures/adapters/override-audit-only.json +53 -0
  146. package/tests/fixtures/adapters/redefine-completion.json +53 -0
  147. package/tests/fixtures/adapters/remove-required-evidence.json +53 -0
  148. package/tests/fixtures/adapters/suppress-failures.json +53 -0
  149. package/tests/fixtures/adapters/valid-narrowing.json +53 -0
  150. package/tests/fixtures/adapters/valid-repo-map.json +53 -0
  151. package/tests/fixtures/adapters/weakening-repo-map.json +42 -0
  152. package/tests/fixtures/completion/cases.json +143 -0
  153. package/tests/fixtures/completion/false-complete.json +51 -0
  154. package/tests/fixtures/evidence-bundles/advisory-review-soon/archive/evidence-archive-index.json +52 -0
  155. package/tests/fixtures/evidence-bundles/advisory-review-soon/evidence/repo-map.evidence.json +68 -0
  156. package/tests/fixtures/evidence-bundles/advisory-review-soon/evidence/valid-upgrade.evidence.json +105 -0
  157. package/tests/fixtures/evidence-bundles/advisory-review-soon/evidence-bundle.json +109 -0
  158. package/tests/fixtures/evidence-bundles/invalid-archive/archive/evidence-archive-index.json +52 -0
  159. package/tests/fixtures/evidence-bundles/invalid-archive/evidence/repo-map.evidence.json +68 -0
  160. package/tests/fixtures/evidence-bundles/invalid-archive/evidence/valid-upgrade.evidence.json +105 -0
  161. package/tests/fixtures/evidence-bundles/invalid-archive/evidence-bundle.json +109 -0
  162. package/tests/fixtures/evidence-bundles/invalid-archive-index/archive/evidence-archive-index.json +52 -0
  163. package/tests/fixtures/evidence-bundles/invalid-archive-index/evidence/repo-map.evidence.json +68 -0
  164. package/tests/fixtures/evidence-bundles/invalid-archive-index/evidence/valid-upgrade.evidence.json +105 -0
  165. package/tests/fixtures/evidence-bundles/invalid-archive-index/evidence-bundle.json +109 -0
  166. package/tests/fixtures/evidence-bundles/invalid-hash/archive/evidence-archive-index.json +52 -0
  167. package/tests/fixtures/evidence-bundles/invalid-hash/evidence/repo-map.evidence.json +68 -0
  168. package/tests/fixtures/evidence-bundles/invalid-hash/evidence/valid-upgrade.evidence.json +105 -0
  169. package/tests/fixtures/evidence-bundles/invalid-hash/evidence-bundle.json +109 -0
  170. package/tests/fixtures/evidence-bundles/invalid-missing-entry/archive/evidence-archive-index.json +52 -0
  171. package/tests/fixtures/evidence-bundles/invalid-missing-entry/evidence/repo-map.evidence.json +68 -0
  172. package/tests/fixtures/evidence-bundles/invalid-missing-entry/evidence/valid-upgrade.evidence.json +105 -0
  173. package/tests/fixtures/evidence-bundles/invalid-missing-entry/evidence-bundle.json +109 -0
  174. package/tests/fixtures/evidence-bundles/invalid-path/archive/evidence-archive-index.json +52 -0
  175. package/tests/fixtures/evidence-bundles/invalid-path/evidence/repo-map.evidence.json +68 -0
  176. package/tests/fixtures/evidence-bundles/invalid-path/evidence/valid-upgrade.evidence.json +105 -0
  177. package/tests/fixtures/evidence-bundles/invalid-path/evidence-bundle.json +109 -0
  178. package/tests/fixtures/evidence-bundles/invalid-provenance/archive/evidence-archive-index.json +52 -0
  179. package/tests/fixtures/evidence-bundles/invalid-provenance/evidence/repo-map.evidence.json +68 -0
  180. package/tests/fixtures/evidence-bundles/invalid-provenance/evidence/valid-upgrade.evidence.json +105 -0
  181. package/tests/fixtures/evidence-bundles/invalid-provenance/evidence-bundle.json +109 -0
  182. package/tests/fixtures/evidence-bundles/invalid-regression/archive/evidence-archive-index.json +52 -0
  183. package/tests/fixtures/evidence-bundles/invalid-regression/evidence/repo-map.evidence.json +68 -0
  184. package/tests/fixtures/evidence-bundles/invalid-regression/evidence/valid-upgrade.evidence.json +105 -0
  185. package/tests/fixtures/evidence-bundles/invalid-regression/evidence-bundle.json +113 -0
  186. package/tests/fixtures/evidence-bundles/invalid-retention/archive/evidence-archive-index.json +52 -0
  187. package/tests/fixtures/evidence-bundles/invalid-retention/evidence/repo-map.evidence.json +68 -0
  188. package/tests/fixtures/evidence-bundles/invalid-retention/evidence/valid-upgrade.evidence.json +105 -0
  189. package/tests/fixtures/evidence-bundles/invalid-retention/evidence-bundle.json +109 -0
  190. package/tests/fixtures/evidence-bundles/invalid-signature-plan/archive/evidence-archive-index.json +52 -0
  191. package/tests/fixtures/evidence-bundles/invalid-signature-plan/evidence/repo-map.evidence.json +68 -0
  192. package/tests/fixtures/evidence-bundles/invalid-signature-plan/evidence/valid-upgrade.evidence.json +105 -0
  193. package/tests/fixtures/evidence-bundles/invalid-signature-plan/evidence-bundle.json +109 -0
  194. package/tests/fixtures/evidence-bundles/valid-bundle/archive/evidence-archive-index.json +52 -0
  195. package/tests/fixtures/evidence-bundles/valid-bundle/evidence/repo-map.evidence.json +68 -0
  196. package/tests/fixtures/evidence-bundles/valid-bundle/evidence/valid-upgrade.evidence.json +105 -0
  197. package/tests/fixtures/evidence-bundles/valid-bundle/evidence-bundle.json +109 -0
  198. package/tests/fixtures/external-adapters/empty/README.md +3 -0
  199. package/tests/fixtures/external-adapters/invalid-completion-override/.coding-agent/adapters/completion/adapter.json +53 -0
  200. package/tests/fixtures/external-adapters/invalid-deploy/.coding-agent/adapters/deploy/adapter.json +60 -0
  201. package/tests/fixtures/external-adapters/invalid-evidence-suppression/.coding-agent/adapters/evidence/adapter.json +53 -0
  202. package/tests/fixtures/external-adapters/invalid-failure-suppression/.coding-agent/adapters/failures/adapter.json +53 -0
  203. package/tests/fixtures/external-adapters/invalid-git-push/.coding-agent/adapters/publish/adapter.json +60 -0
  204. package/tests/fixtures/external-adapters/invalid-malformed/.coding-agent/adapters/malformed/adapter.json +1 -0
  205. package/tests/fixtures/external-adapters/invalid-malformed/malformed-adapter.txt +1 -0
  206. package/tests/fixtures/external-adapters/invalid-mode-escalation/.coding-agent/adapters/mode/adapter.json +53 -0
  207. package/tests/fixtures/external-adapters/invalid-path-traversal/.coding-agent/adapters/path/adapter.json +53 -0
  208. package/tests/fixtures/external-adapters/invalid-restriction-removal/.coding-agent/adapters/restrictions/adapter.json +52 -0
  209. package/tests/fixtures/external-adapters/invalid-scope-expansion/.coding-agent/adapters/scope/adapter.json +53 -0
  210. package/tests/fixtures/external-adapters/invalid-secret-exposure/.coding-agent/adapters/secrets/adapter.json +53 -0
  211. package/tests/fixtures/external-adapters/invalid-skill-id/.coding-agent/adapters/skill/adapter.json +53 -0
  212. package/tests/fixtures/external-adapters/invalid-skill-version/.coding-agent/adapters/skill-version/adapter.json +53 -0
  213. package/tests/fixtures/external-adapters/invalid-unknown-manifest/.coding-agent/adapters/unknown/manifest.json +1 -0
  214. package/tests/fixtures/external-adapters/invalid-version/.coding-agent/adapters/version/adapter.json +53 -0
  215. package/tests/fixtures/external-adapters/mixed/.coding-agent/adapters/invalid/adapter.json +60 -0
  216. package/tests/fixtures/external-adapters/mixed/.coding-agent/adapters/valid/adapter.json +53 -0
  217. package/tests/fixtures/external-adapters/valid-basic/.coding-agent/adapters/basic/adapter.json +53 -0
  218. package/tests/fixtures/external-adapters/valid-doc-precedence/coding-agent/adapters/docs/adapter.json +53 -0
  219. package/tests/fixtures/external-adapters/valid-runtime-status/adapters/coding-agent/runtime/adapter.json +65 -0
  220. package/tests/fixtures/mutation/cases.json +87 -0
  221. package/tests/fixtures/mutation/snapshot-target/README.md +3 -0
  222. package/tests/fixtures/mutation/snapshot-target/state.json +4 -0
  223. package/tests/fixtures/policy/commands.json +164 -0
  224. package/tests/fixtures/policy/properties.json +126 -0
  225. package/tests/fixtures/privacy/cases.json +47 -0
  226. package/tests/fixtures/project-adapter-installation/invalid-adapter-location/.agents/adapters/basic/adapter.json +53 -0
  227. package/tests/fixtures/project-adapter-installation/invalid-adapter-location/.coding-agent/skills.json +23 -0
  228. package/tests/fixtures/project-adapter-installation/invalid-adapter-schema-version/.coding-agent/adapters/basic/adapter.json +53 -0
  229. package/tests/fixtures/project-adapter-installation/invalid-adapter-schema-version/.coding-agent/skills.json +23 -0
  230. package/tests/fixtures/project-adapter-installation/invalid-adapter-version-mismatch/.coding-agent/adapters/basic/adapter.json +53 -0
  231. package/tests/fixtures/project-adapter-installation/invalid-adapter-version-mismatch/.coding-agent/skills.json +23 -0
  232. package/tests/fixtures/project-adapter-installation/invalid-bad-semver/.coding-agent/adapters/basic/adapter.json +53 -0
  233. package/tests/fixtures/project-adapter-installation/invalid-bad-semver/.coding-agent/skills.json +23 -0
  234. package/tests/fixtures/project-adapter-installation/invalid-completion-override/.coding-agent/adapters/basic/adapter.json +53 -0
  235. package/tests/fixtures/project-adapter-installation/invalid-completion-override/.coding-agent/skills.json +23 -0
  236. package/tests/fixtures/project-adapter-installation/invalid-failure-suppression/.coding-agent/adapters/basic/adapter.json +53 -0
  237. package/tests/fixtures/project-adapter-installation/invalid-failure-suppression/.coding-agent/skills.json +23 -0
  238. package/tests/fixtures/project-adapter-installation/invalid-missing-declaration/.coding-agent/adapters/basic/adapter.json +53 -0
  239. package/tests/fixtures/project-adapter-installation/invalid-mode-escalation/.coding-agent/adapters/basic/adapter.json +53 -0
  240. package/tests/fixtures/project-adapter-installation/invalid-mode-escalation/.coding-agent/skills.json +23 -0
  241. package/tests/fixtures/project-adapter-installation/invalid-path-traversal/.coding-agent/adapters/basic/adapter.json +53 -0
  242. package/tests/fixtures/project-adapter-installation/invalid-path-traversal/.coding-agent/skills.json +23 -0
  243. package/tests/fixtures/project-adapter-installation/invalid-scope-expansion/.coding-agent/adapters/basic/adapter.json +53 -0
  244. package/tests/fixtures/project-adapter-installation/invalid-scope-expansion/.coding-agent/skills.json +23 -0
  245. package/tests/fixtures/project-adapter-installation/invalid-secret-exposure/.coding-agent/adapters/basic/adapter.json +53 -0
  246. package/tests/fixtures/project-adapter-installation/invalid-secret-exposure/.coding-agent/skills.json +23 -0
  247. package/tests/fixtures/project-adapter-installation/invalid-skill-mismatch/.coding-agent/adapters/basic/adapter.json +53 -0
  248. package/tests/fixtures/project-adapter-installation/invalid-skill-mismatch/.coding-agent/skills.json +23 -0
  249. package/tests/fixtures/project-adapter-installation/invalid-unknown-skill/.coding-agent/adapters/basic/adapter.json +53 -0
  250. package/tests/fixtures/project-adapter-installation/invalid-unknown-skill/.coding-agent/skills.json +23 -0
  251. package/tests/fixtures/project-adapter-installation/invalid-unsupported-core-version/.coding-agent/adapters/basic/adapter.json +53 -0
  252. package/tests/fixtures/project-adapter-installation/invalid-unsupported-core-version/.coding-agent/skills.json +23 -0
  253. package/tests/fixtures/project-adapter-installation/invalid-weakens-restrictions/.coding-agent/adapters/basic/adapter.json +52 -0
  254. package/tests/fixtures/project-adapter-installation/invalid-weakens-restrictions/.coding-agent/skills.json +23 -0
  255. package/tests/fixtures/project-adapter-installation/valid-compatible-range/coding-agent/adapters/docs/adapter.json +53 -0
  256. package/tests/fixtures/project-adapter-installation/valid-compatible-range/coding-agent.skills.json +23 -0
  257. package/tests/fixtures/project-adapter-installation/valid-exact-pin/.coding-agent/adapters/basic/adapter.json +53 -0
  258. package/tests/fixtures/project-adapter-installation/valid-exact-pin/.coding-agent/skills.json +23 -0
  259. package/tests/fixtures/project-adapter-installation/valid-multiple-adapters/.coding-agent/skills.json +28 -0
  260. package/tests/fixtures/project-adapter-installation/valid-multiple-adapters/adapters/coding-agent/repo/adapter.json +53 -0
  261. package/tests/fixtures/project-adapter-installation/valid-multiple-adapters/adapters/coding-agent/runtime/adapter.json +58 -0
  262. package/tests/fixtures/project-adapter-upgrade-chains/broken-compatibility-chain/01-current/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  263. package/tests/fixtures/project-adapter-upgrade-chains/broken-compatibility-chain/01-current/.coding-agent/skills.json +27 -0
  264. package/tests/fixtures/project-adapter-upgrade-chains/broken-compatibility-chain/02-incompatible/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  265. package/tests/fixtures/project-adapter-upgrade-chains/broken-compatibility-chain/02-incompatible/.coding-agent/skills.json +27 -0
  266. package/tests/fixtures/project-adapter-upgrade-chains/broken-compatibility-chain/03-target/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  267. package/tests/fixtures/project-adapter-upgrade-chains/broken-compatibility-chain/03-target/.coding-agent/skills.json +27 -0
  268. package/tests/fixtures/project-adapter-upgrade-chains/schema-drift-chain/01-current/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  269. package/tests/fixtures/project-adapter-upgrade-chains/schema-drift-chain/01-current/.coding-agent/skills.json +27 -0
  270. package/tests/fixtures/project-adapter-upgrade-chains/schema-drift-chain/02-schema-drift/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  271. package/tests/fixtures/project-adapter-upgrade-chains/schema-drift-chain/02-schema-drift/.coding-agent/skills.json +27 -0
  272. package/tests/fixtures/project-adapter-upgrade-chains/skill-drift-chain/01-current/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  273. package/tests/fixtures/project-adapter-upgrade-chains/skill-drift-chain/01-current/.coding-agent/skills.json +27 -0
  274. package/tests/fixtures/project-adapter-upgrade-chains/skill-drift-chain/02-skill-drift/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  275. package/tests/fixtures/project-adapter-upgrade-chains/skill-drift-chain/02-skill-drift/.coding-agent/skills.json +27 -0
  276. package/tests/fixtures/project-adapter-upgrade-chains/stale-pin-chain/01-current/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  277. package/tests/fixtures/project-adapter-upgrade-chains/stale-pin-chain/01-current/.coding-agent/skills.json +27 -0
  278. package/tests/fixtures/project-adapter-upgrade-chains/stale-pin-chain/02-stale/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  279. package/tests/fixtures/project-adapter-upgrade-chains/stale-pin-chain/02-stale/.coding-agent/skills.json +27 -0
  280. package/tests/fixtures/project-adapter-upgrade-chains/stale-pin-chain/03-target/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  281. package/tests/fixtures/project-adapter-upgrade-chains/stale-pin-chain/03-target/.coding-agent/skills.json +27 -0
  282. package/tests/fixtures/project-adapter-upgrade-chains/unsafe-weakening-chain/01-current/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  283. package/tests/fixtures/project-adapter-upgrade-chains/unsafe-weakening-chain/01-current/.coding-agent/skills.json +27 -0
  284. package/tests/fixtures/project-adapter-upgrade-chains/unsafe-weakening-chain/02-safe/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  285. package/tests/fixtures/project-adapter-upgrade-chains/unsafe-weakening-chain/02-safe/.coding-agent/skills.json +27 -0
  286. package/tests/fixtures/project-adapter-upgrade-chains/unsafe-weakening-chain/03-weakens-restrictions/.coding-agent/adapters/fixture-chain-adapter/adapter.json +69 -0
  287. package/tests/fixtures/project-adapter-upgrade-chains/unsafe-weakening-chain/03-weakens-restrictions/.coding-agent/skills.json +27 -0
  288. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/01-current/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  289. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/01-current/.coding-agent/skills.json +27 -0
  290. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/02-upgrade/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  291. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/02-upgrade/.coding-agent/skills.json +27 -0
  292. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/03-upgrade/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  293. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/03-upgrade/.coding-agent/skills.json +27 -0
  294. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/04-upgrade/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  295. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/04-upgrade/.coding-agent/skills.json +27 -0
  296. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/05-upgrade/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  297. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/05-upgrade/.coding-agent/skills.json +27 -0
  298. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/06-upgrade/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  299. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/06-upgrade/.coding-agent/skills.json +27 -0
  300. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/07-upgrade/.coding-agent/adapters/fixture-chain-adapter/adapter.json +70 -0
  301. package/tests/fixtures/project-adapter-upgrade-chains/valid-chain/07-upgrade/.coding-agent/skills.json +27 -0
  302. package/tests/fixtures/project-adapter-upgrades/adapter-schema-drift/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  303. package/tests/fixtures/project-adapter-upgrades/adapter-schema-drift/after/.coding-agent/skills.json +27 -0
  304. package/tests/fixtures/project-adapter-upgrades/adapter-schema-drift/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  305. package/tests/fixtures/project-adapter-upgrades/adapter-schema-drift/before/.coding-agent/skills.json +27 -0
  306. package/tests/fixtures/project-adapter-upgrades/safe-upgrade-preserves-restrictions/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +71 -0
  307. package/tests/fixtures/project-adapter-upgrades/safe-upgrade-preserves-restrictions/after/.coding-agent/skills.json +27 -0
  308. package/tests/fixtures/project-adapter-upgrades/safe-upgrade-preserves-restrictions/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  309. package/tests/fixtures/project-adapter-upgrades/safe-upgrade-preserves-restrictions/before/.coding-agent/skills.json +27 -0
  310. package/tests/fixtures/project-adapter-upgrades/skill-compatibility-drift/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  311. package/tests/fixtures/project-adapter-upgrades/skill-compatibility-drift/after/.coding-agent/skills.json +27 -0
  312. package/tests/fixtures/project-adapter-upgrades/skill-compatibility-drift/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  313. package/tests/fixtures/project-adapter-upgrades/skill-compatibility-drift/before/.coding-agent/skills.json +27 -0
  314. package/tests/fixtures/project-adapter-upgrades/stale-compatible-range/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  315. package/tests/fixtures/project-adapter-upgrades/stale-compatible-range/after/.coding-agent/skills.json +27 -0
  316. package/tests/fixtures/project-adapter-upgrades/stale-compatible-range/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  317. package/tests/fixtures/project-adapter-upgrades/stale-compatible-range/before/.coding-agent/skills.json +27 -0
  318. package/tests/fixtures/project-adapter-upgrades/stale-exact-pin/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  319. package/tests/fixtures/project-adapter-upgrades/stale-exact-pin/after/.coding-agent/skills.json +27 -0
  320. package/tests/fixtures/project-adapter-upgrades/stale-exact-pin/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  321. package/tests/fixtures/project-adapter-upgrades/stale-exact-pin/before/.coding-agent/skills.json +27 -0
  322. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-mode-escalation/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  323. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-mode-escalation/after/.coding-agent/skills.json +27 -0
  324. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-mode-escalation/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  325. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-mode-escalation/before/.coding-agent/skills.json +27 -0
  326. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-removes-evidence/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +69 -0
  327. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-removes-evidence/after/.coding-agent/skills.json +27 -0
  328. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-removes-evidence/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  329. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-removes-evidence/before/.coding-agent/skills.json +27 -0
  330. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-weakens-restrictions/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +69 -0
  331. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-weakens-restrictions/after/.coding-agent/skills.json +27 -0
  332. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-weakens-restrictions/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  333. package/tests/fixtures/project-adapter-upgrades/unsafe-upgrade-weakens-restrictions/before/.coding-agent/skills.json +27 -0
  334. package/tests/fixtures/project-adapter-upgrades/unsupported-future-core/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  335. package/tests/fixtures/project-adapter-upgrades/unsupported-future-core/after/.coding-agent/skills.json +27 -0
  336. package/tests/fixtures/project-adapter-upgrades/unsupported-future-core/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  337. package/tests/fixtures/project-adapter-upgrades/unsupported-future-core/before/.coding-agent/skills.json +27 -0
  338. package/tests/fixtures/project-adapter-upgrades/unsupported-old-core/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  339. package/tests/fixtures/project-adapter-upgrades/unsupported-old-core/after/.coding-agent/skills.json +27 -0
  340. package/tests/fixtures/project-adapter-upgrades/unsupported-old-core/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  341. package/tests/fixtures/project-adapter-upgrades/unsupported-old-core/before/.coding-agent/skills.json +27 -0
  342. package/tests/fixtures/project-adapter-upgrades/valid-upgrade/after/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  343. package/tests/fixtures/project-adapter-upgrades/valid-upgrade/after/.coding-agent/skills.json +27 -0
  344. package/tests/fixtures/project-adapter-upgrades/valid-upgrade/before/.coding-agent/adapters/fixture-upgrade-adapter/adapter.json +70 -0
  345. package/tests/fixtures/project-adapter-upgrades/valid-upgrade/before/.coding-agent/skills.json +27 -0
  346. package/tests/fixtures/sample-repo/.env.example +1 -0
  347. package/tests/fixtures/sample-repo/README.md +4 -0
  348. package/tests/fixtures/sample-repo/docs/architecture.md +3 -0
  349. package/tests/fixtures/sample-repo/package.json +11 -0
  350. package/tests/fixtures/sample-repo/src/index.js +3 -0
  351. package/tests/fixtures/sample-repo/test/index.test.js +8 -0
  352. package/tests/fixtures/triggers/cases.json +101 -0
  353. package/tests/policy/README.md +16 -0
  354. package/tests/privacy/README.md +14 -0
  355. package/tests/safety/README.md +17 -0
  356. package/tests/trigger/README.md +11 -0
  357. package/work-ledger.md +159 -0
@@ -0,0 +1,70 @@
1
+ {
2
+ "adapterId": "fixture-upgrade-adapter",
3
+ "adapterVersion": "1.0.0",
4
+ "project": {
5
+ "id": "fixture-upgrade-project",
6
+ "detection": {
7
+ "rootMarkers": [
8
+ {
9
+ "kind": "file",
10
+ "path": "package.json"
11
+ }
12
+ ],
13
+ "maximumDepth": 1,
14
+ "scope": "declared-project-root",
15
+ "requireApprovalOutsideScope": true
16
+ }
17
+ },
18
+ "supportedSkills": [
19
+ {
20
+ "id": "repo-map",
21
+ "compatibleVersions": [
22
+ "0.2.2"
23
+ ],
24
+ "declaredMode": "audit-only"
25
+ }
26
+ ],
27
+ "extensions": {
28
+ "safeReadPaths": [
29
+ "README.md",
30
+ "src"
31
+ ],
32
+ "ignoredPaths": [
33
+ "dist"
34
+ ],
35
+ "documentationPrecedence": [],
36
+ "commandAliases": [],
37
+ "safeStatusCommands": [],
38
+ "requiredEvidence": [
39
+ "repository root",
40
+ "application entry point"
41
+ ],
42
+ "expectedRuntimeManagers": [],
43
+ "expectedPackageManagers": [
44
+ "npm"
45
+ ]
46
+ },
47
+ "approvalRequirements": [],
48
+ "inheritance": {
49
+ "sharedRestrictions": "required",
50
+ "deniedOperationCategories": [
51
+ "file-write",
52
+ "package-install",
53
+ "deployment",
54
+ "git-mutation",
55
+ "unrestricted-scan",
56
+ "secret-read",
57
+ "process-mutation",
58
+ "service-mutation",
59
+ "migration-apply",
60
+ "privileged-api"
61
+ ],
62
+ "allowRestrictionRemoval": false,
63
+ "allowModeOverride": false,
64
+ "allowFailureSuppression": false,
65
+ "allowCompletionOverride": false,
66
+ "allowSecretExposure": false,
67
+ "allowRequiredEvidenceRemoval": false,
68
+ "allowScopeExpansionWithoutApproval": false
69
+ }
70
+ }
@@ -0,0 +1,27 @@
1
+ {
2
+ "declarationVersion": "1.0.0",
3
+ "projectId": "fixture-upgrade-project",
4
+ "adapterRoot": ".coding-agent/adapters",
5
+ "adapterSchemaVersion": "1.0.0",
6
+ "core": {
7
+ "id": "coding-agent-skills",
8
+ "expectedVersion": "0.2.2",
9
+ "versionPin": "0.2.2"
10
+ },
11
+ "compatibleSkillIds": [
12
+ "repo-map"
13
+ ],
14
+ "adapters": [
15
+ {
16
+ "id": "fixture-upgrade-adapter",
17
+ "version": "1.0.0",
18
+ "skillIds": [
19
+ "repo-map"
20
+ ]
21
+ }
22
+ ],
23
+ "validationCommand": "node <shared-core>/scripts/validate-project-adapters.mjs <project-root>",
24
+ "evidenceOutput": "validation-output/project-adapters.json",
25
+ "approvalPolicyReference": "docs/coding-agent-approval-policy.md",
26
+ "noSecrets": true
27
+ }
@@ -0,0 +1,70 @@
1
+ {
2
+ "adapterId": "fixture-upgrade-adapter",
3
+ "adapterVersion": "1.0.0",
4
+ "project": {
5
+ "id": "fixture-upgrade-project",
6
+ "detection": {
7
+ "rootMarkers": [
8
+ {
9
+ "kind": "file",
10
+ "path": "package.json"
11
+ }
12
+ ],
13
+ "maximumDepth": 1,
14
+ "scope": "declared-project-root",
15
+ "requireApprovalOutsideScope": true
16
+ }
17
+ },
18
+ "supportedSkills": [
19
+ {
20
+ "id": "repo-map",
21
+ "compatibleVersions": [
22
+ "0.2.3"
23
+ ],
24
+ "declaredMode": "audit-only"
25
+ }
26
+ ],
27
+ "extensions": {
28
+ "safeReadPaths": [
29
+ "README.md",
30
+ "src"
31
+ ],
32
+ "ignoredPaths": [
33
+ "dist"
34
+ ],
35
+ "documentationPrecedence": [],
36
+ "commandAliases": [],
37
+ "safeStatusCommands": [],
38
+ "requiredEvidence": [
39
+ "repository root",
40
+ "application entry point"
41
+ ],
42
+ "expectedRuntimeManagers": [],
43
+ "expectedPackageManagers": [
44
+ "npm"
45
+ ]
46
+ },
47
+ "approvalRequirements": [],
48
+ "inheritance": {
49
+ "sharedRestrictions": "required",
50
+ "deniedOperationCategories": [
51
+ "file-write",
52
+ "package-install",
53
+ "deployment",
54
+ "git-mutation",
55
+ "unrestricted-scan",
56
+ "secret-read",
57
+ "process-mutation",
58
+ "service-mutation",
59
+ "migration-apply",
60
+ "privileged-api"
61
+ ],
62
+ "allowRestrictionRemoval": false,
63
+ "allowModeOverride": false,
64
+ "allowFailureSuppression": false,
65
+ "allowCompletionOverride": false,
66
+ "allowSecretExposure": false,
67
+ "allowRequiredEvidenceRemoval": false,
68
+ "allowScopeExpansionWithoutApproval": false
69
+ }
70
+ }
@@ -0,0 +1,27 @@
1
+ {
2
+ "declarationVersion": "1.0.0",
3
+ "projectId": "fixture-upgrade-project",
4
+ "adapterRoot": ".coding-agent/adapters",
5
+ "adapterSchemaVersion": "1.0.0",
6
+ "core": {
7
+ "id": "coding-agent-skills",
8
+ "expectedVersion": "0.2.3",
9
+ "versionPin": "0.2.3"
10
+ },
11
+ "compatibleSkillIds": [
12
+ "repo-map"
13
+ ],
14
+ "adapters": [
15
+ {
16
+ "id": "fixture-upgrade-adapter",
17
+ "version": "1.0.0",
18
+ "skillIds": [
19
+ "repo-map"
20
+ ]
21
+ }
22
+ ],
23
+ "validationCommand": "node <shared-core>/scripts/validate-project-adapters.mjs <project-root>",
24
+ "evidenceOutput": "validation-output/project-adapters.json",
25
+ "approvalPolicyReference": "docs/coding-agent-approval-policy.md",
26
+ "noSecrets": true
27
+ }
@@ -0,0 +1,70 @@
1
+ {
2
+ "adapterId": "fixture-upgrade-adapter",
3
+ "adapterVersion": "1.0.0",
4
+ "project": {
5
+ "id": "fixture-upgrade-project",
6
+ "detection": {
7
+ "rootMarkers": [
8
+ {
9
+ "kind": "file",
10
+ "path": "package.json"
11
+ }
12
+ ],
13
+ "maximumDepth": 1,
14
+ "scope": "declared-project-root",
15
+ "requireApprovalOutsideScope": true
16
+ }
17
+ },
18
+ "supportedSkills": [
19
+ {
20
+ "id": "repo-map",
21
+ "compatibleVersions": [
22
+ "0.1.2"
23
+ ],
24
+ "declaredMode": "audit-only"
25
+ }
26
+ ],
27
+ "extensions": {
28
+ "safeReadPaths": [
29
+ "README.md",
30
+ "src"
31
+ ],
32
+ "ignoredPaths": [
33
+ "dist"
34
+ ],
35
+ "documentationPrecedence": [],
36
+ "commandAliases": [],
37
+ "safeStatusCommands": [],
38
+ "requiredEvidence": [
39
+ "repository root",
40
+ "application entry point"
41
+ ],
42
+ "expectedRuntimeManagers": [],
43
+ "expectedPackageManagers": [
44
+ "npm"
45
+ ]
46
+ },
47
+ "approvalRequirements": [],
48
+ "inheritance": {
49
+ "sharedRestrictions": "required",
50
+ "deniedOperationCategories": [
51
+ "file-write",
52
+ "package-install",
53
+ "deployment",
54
+ "git-mutation",
55
+ "unrestricted-scan",
56
+ "secret-read",
57
+ "process-mutation",
58
+ "service-mutation",
59
+ "migration-apply",
60
+ "privileged-api"
61
+ ],
62
+ "allowRestrictionRemoval": false,
63
+ "allowModeOverride": false,
64
+ "allowFailureSuppression": false,
65
+ "allowCompletionOverride": false,
66
+ "allowSecretExposure": false,
67
+ "allowRequiredEvidenceRemoval": false,
68
+ "allowScopeExpansionWithoutApproval": false
69
+ }
70
+ }
@@ -0,0 +1,27 @@
1
+ {
2
+ "declarationVersion": "1.0.0",
3
+ "projectId": "fixture-upgrade-project",
4
+ "adapterRoot": ".coding-agent/adapters",
5
+ "adapterSchemaVersion": "1.0.0",
6
+ "core": {
7
+ "id": "coding-agent-skills",
8
+ "expectedVersion": "0.1.2",
9
+ "versionPin": "0.1.2"
10
+ },
11
+ "compatibleSkillIds": [
12
+ "repo-map"
13
+ ],
14
+ "adapters": [
15
+ {
16
+ "id": "fixture-upgrade-adapter",
17
+ "version": "1.0.0",
18
+ "skillIds": [
19
+ "repo-map"
20
+ ]
21
+ }
22
+ ],
23
+ "validationCommand": "node <shared-core>/scripts/validate-project-adapters.mjs <project-root>",
24
+ "evidenceOutput": "validation-output/project-adapters.json",
25
+ "approvalPolicyReference": "docs/coding-agent-approval-policy.md",
26
+ "noSecrets": true
27
+ }
@@ -0,0 +1,70 @@
1
+ {
2
+ "adapterId": "fixture-upgrade-adapter",
3
+ "adapterVersion": "1.0.0",
4
+ "project": {
5
+ "id": "fixture-upgrade-project",
6
+ "detection": {
7
+ "rootMarkers": [
8
+ {
9
+ "kind": "file",
10
+ "path": "package.json"
11
+ }
12
+ ],
13
+ "maximumDepth": 1,
14
+ "scope": "declared-project-root",
15
+ "requireApprovalOutsideScope": true
16
+ }
17
+ },
18
+ "supportedSkills": [
19
+ {
20
+ "id": "repo-map",
21
+ "compatibleVersions": [
22
+ "0.2.3"
23
+ ],
24
+ "declaredMode": "audit-only"
25
+ }
26
+ ],
27
+ "extensions": {
28
+ "safeReadPaths": [
29
+ "README.md",
30
+ "src"
31
+ ],
32
+ "ignoredPaths": [
33
+ "dist"
34
+ ],
35
+ "documentationPrecedence": [],
36
+ "commandAliases": [],
37
+ "safeStatusCommands": [],
38
+ "requiredEvidence": [
39
+ "repository root",
40
+ "application entry point"
41
+ ],
42
+ "expectedRuntimeManagers": [],
43
+ "expectedPackageManagers": [
44
+ "npm"
45
+ ]
46
+ },
47
+ "approvalRequirements": [],
48
+ "inheritance": {
49
+ "sharedRestrictions": "required",
50
+ "deniedOperationCategories": [
51
+ "file-write",
52
+ "package-install",
53
+ "deployment",
54
+ "git-mutation",
55
+ "unrestricted-scan",
56
+ "secret-read",
57
+ "process-mutation",
58
+ "service-mutation",
59
+ "migration-apply",
60
+ "privileged-api"
61
+ ],
62
+ "allowRestrictionRemoval": false,
63
+ "allowModeOverride": false,
64
+ "allowFailureSuppression": false,
65
+ "allowCompletionOverride": false,
66
+ "allowSecretExposure": false,
67
+ "allowRequiredEvidenceRemoval": false,
68
+ "allowScopeExpansionWithoutApproval": false
69
+ }
70
+ }
@@ -0,0 +1,27 @@
1
+ {
2
+ "declarationVersion": "1.0.0",
3
+ "projectId": "fixture-upgrade-project",
4
+ "adapterRoot": ".coding-agent/adapters",
5
+ "adapterSchemaVersion": "1.0.0",
6
+ "core": {
7
+ "id": "coding-agent-skills",
8
+ "expectedVersion": "0.2.3",
9
+ "versionPin": "0.2.3"
10
+ },
11
+ "compatibleSkillIds": [
12
+ "repo-map"
13
+ ],
14
+ "adapters": [
15
+ {
16
+ "id": "fixture-upgrade-adapter",
17
+ "version": "1.0.0",
18
+ "skillIds": [
19
+ "repo-map"
20
+ ]
21
+ }
22
+ ],
23
+ "validationCommand": "node <shared-core>/scripts/validate-project-adapters.mjs <project-root>",
24
+ "evidenceOutput": "validation-output/project-adapters.json",
25
+ "approvalPolicyReference": "docs/coding-agent-approval-policy.md",
26
+ "noSecrets": true
27
+ }
@@ -0,0 +1,70 @@
1
+ {
2
+ "adapterId": "fixture-upgrade-adapter",
3
+ "adapterVersion": "1.0.0",
4
+ "project": {
5
+ "id": "fixture-upgrade-project",
6
+ "detection": {
7
+ "rootMarkers": [
8
+ {
9
+ "kind": "file",
10
+ "path": "package.json"
11
+ }
12
+ ],
13
+ "maximumDepth": 1,
14
+ "scope": "declared-project-root",
15
+ "requireApprovalOutsideScope": true
16
+ }
17
+ },
18
+ "supportedSkills": [
19
+ {
20
+ "id": "repo-map",
21
+ "compatibleVersions": [
22
+ "0.2.2"
23
+ ],
24
+ "declaredMode": "audit-only"
25
+ }
26
+ ],
27
+ "extensions": {
28
+ "safeReadPaths": [
29
+ "README.md",
30
+ "src"
31
+ ],
32
+ "ignoredPaths": [
33
+ "dist"
34
+ ],
35
+ "documentationPrecedence": [],
36
+ "commandAliases": [],
37
+ "safeStatusCommands": [],
38
+ "requiredEvidence": [
39
+ "repository root",
40
+ "application entry point"
41
+ ],
42
+ "expectedRuntimeManagers": [],
43
+ "expectedPackageManagers": [
44
+ "npm"
45
+ ]
46
+ },
47
+ "approvalRequirements": [],
48
+ "inheritance": {
49
+ "sharedRestrictions": "required",
50
+ "deniedOperationCategories": [
51
+ "file-write",
52
+ "package-install",
53
+ "deployment",
54
+ "git-mutation",
55
+ "unrestricted-scan",
56
+ "secret-read",
57
+ "process-mutation",
58
+ "service-mutation",
59
+ "migration-apply",
60
+ "privileged-api"
61
+ ],
62
+ "allowRestrictionRemoval": false,
63
+ "allowModeOverride": false,
64
+ "allowFailureSuppression": false,
65
+ "allowCompletionOverride": false,
66
+ "allowSecretExposure": false,
67
+ "allowRequiredEvidenceRemoval": false,
68
+ "allowScopeExpansionWithoutApproval": false
69
+ }
70
+ }
@@ -0,0 +1,27 @@
1
+ {
2
+ "declarationVersion": "1.0.0",
3
+ "projectId": "fixture-upgrade-project",
4
+ "adapterRoot": ".coding-agent/adapters",
5
+ "adapterSchemaVersion": "1.0.0",
6
+ "core": {
7
+ "id": "coding-agent-skills",
8
+ "expectedVersion": "0.2.2",
9
+ "versionPin": "0.2.2"
10
+ },
11
+ "compatibleSkillIds": [
12
+ "repo-map"
13
+ ],
14
+ "adapters": [
15
+ {
16
+ "id": "fixture-upgrade-adapter",
17
+ "version": "1.0.0",
18
+ "skillIds": [
19
+ "repo-map"
20
+ ]
21
+ }
22
+ ],
23
+ "validationCommand": "node <shared-core>/scripts/validate-project-adapters.mjs <project-root>",
24
+ "evidenceOutput": "validation-output/project-adapters.json",
25
+ "approvalPolicyReference": "docs/coding-agent-approval-policy.md",
26
+ "noSecrets": true
27
+ }
@@ -0,0 +1 @@
1
+ EXAMPLE_API_TOKEN=replace-with-local-test-value
@@ -0,0 +1,4 @@
1
+ # Sample Repository
2
+
3
+ This synthetic repository exists only for dependency-free pilot-pack tests.
4
+ It contains no credentials, private paths, network calls, or generated output.
@@ -0,0 +1,3 @@
1
+ # Architecture
2
+
3
+ The fixture has one dependency-free module and one built-in Node.js test.
@@ -0,0 +1,11 @@
1
+ {
2
+ "name": "coding-agent-skills-sample-repo",
3
+ "version": "0.0.0",
4
+ "private": true,
5
+ "type": "module",
6
+ "scripts": {
7
+ "typecheck": "node --check src/index.js",
8
+ "test": "node --test",
9
+ "build": "node --check src/index.js"
10
+ }
11
+ }
@@ -0,0 +1,3 @@
1
+ export function greeting(name) {
2
+ return `Hello, ${name}.`;
3
+ }
@@ -0,0 +1,8 @@
1
+ import assert from "node:assert/strict";
2
+ import test from "node:test";
3
+
4
+ import { greeting } from "../src/index.js";
5
+
6
+ test("greeting includes the supplied name", () => {
7
+ assert.equal(greeting("pilot"), "Hello, pilot.");
8
+ });
@@ -0,0 +1,101 @@
1
+ {
2
+ "version": "1.0.0",
3
+ "cases": [
4
+ {
5
+ "id": "repo-map-unfamiliar",
6
+ "prompt": "Map this unfamiliar repository and identify its entry points before I change anything.",
7
+ "expectedSkill": "repo-map",
8
+ "notSkills": ["build-verify", "runtime-truth"]
9
+ },
10
+ {
11
+ "id": "repo-map-ambiguous-root",
12
+ "prompt": "Determine which nested directory is the canonical repository root and summarize its structure.",
13
+ "expectedSkill": "repo-map",
14
+ "notSkills": ["git-preflight"]
15
+ },
16
+ {
17
+ "id": "repo-map-stale-context",
18
+ "prompt": "The inherited repository context is stale; relocate the canonical repo and map the current packages.",
19
+ "expectedSkill": "repo-map",
20
+ "notSkills": ["llm-drift-control"]
21
+ },
22
+ {
23
+ "id": "build-after-implementation",
24
+ "prompt": "The implementation is finished. Run the existing typecheck, tests, and build.",
25
+ "expectedSkill": "build-verify",
26
+ "notSkills": ["repo-map", "git-preflight"]
27
+ },
28
+ {
29
+ "id": "build-before-handoff",
30
+ "prompt": "Before handoff, validate the changed code with the project-native test and build scripts.",
31
+ "expectedSkill": "build-verify",
32
+ "notSkills": ["runtime-truth"]
33
+ },
34
+ {
35
+ "id": "git-before-commit",
36
+ "prompt": "Before I commit, inspect the branch, staged files, untracked files, and whitespace state.",
37
+ "expectedSkill": "git-preflight",
38
+ "notSkills": ["build-verify"]
39
+ },
40
+ {
41
+ "id": "git-before-push",
42
+ "prompt": "Check whether the Git working tree is understood and ready for push or handoff.",
43
+ "expectedSkill": "git-preflight",
44
+ "notSkills": ["repo-map"]
45
+ },
46
+ {
47
+ "id": "runtime-live-claim",
48
+ "prompt": "The API is claimed to be live. Verify the process, listener, and health endpoint.",
49
+ "expectedSkill": "runtime-truth",
50
+ "notSkills": ["build-verify"]
51
+ },
52
+ {
53
+ "id": "runtime-running-state",
54
+ "prompt": "Is the local worker actually running and listening on the expected port?",
55
+ "expectedSkill": "runtime-truth",
56
+ "notSkills": ["git-preflight"]
57
+ },
58
+ {
59
+ "id": "drift-doc-code-disagreement",
60
+ "prompt": "The README says the feature exists, but the code and tests disagree. Reconcile the claim.",
61
+ "expectedSkill": "llm-drift-control",
62
+ "notSkills": ["repo-map"]
63
+ },
64
+ {
65
+ "id": "drift-runtime-disagreement",
66
+ "prompt": "The handoff says phase 8 is complete, while runtime evidence contradicts it. Classify the claim.",
67
+ "expectedSkill": "llm-drift-control",
68
+ "notSkills": ["runtime-truth"]
69
+ },
70
+ {
71
+ "id": "negative-deploy",
72
+ "prompt": "Deploy this application to production.",
73
+ "expectedSkill": null,
74
+ "notSkills": ["repo-map", "build-verify", "git-preflight", "runtime-truth", "llm-drift-control"]
75
+ },
76
+ {
77
+ "id": "negative-install",
78
+ "prompt": "Install all missing dependencies and update the lockfile.",
79
+ "expectedSkill": null,
80
+ "notSkills": ["build-verify"]
81
+ },
82
+ {
83
+ "id": "negative-publish",
84
+ "prompt": "Commit these files and publish the branch.",
85
+ "expectedSkill": null,
86
+ "notSkills": ["git-preflight"]
87
+ },
88
+ {
89
+ "id": "negative-restart",
90
+ "prompt": "Restart the unhealthy service and enable it at boot.",
91
+ "expectedSkill": null,
92
+ "notSkills": ["runtime-truth"]
93
+ },
94
+ {
95
+ "id": "negative-rewrite",
96
+ "prompt": "Rewrite the documentation so it agrees with the project claim.",
97
+ "expectedSkill": null,
98
+ "notSkills": ["llm-drift-control"]
99
+ }
100
+ ]
101
+ }
@@ -0,0 +1,16 @@
1
+ # Command Policy Tests
2
+
3
+ `tests/fixtures/policy/commands.json` validates safe single commands, safe composition, multiline commands, and rejection of:
4
+
5
+ - Shell chains containing any restricted segment.
6
+ - Validation scripts whose definitions contain installs, fixes, deploys, or migrations.
7
+ - Git mutation hidden behind aliases or shell wrappers.
8
+ - Runtime lifecycle operations.
9
+ - Unbounded traversal.
10
+ - Secret-file reads and authenticated APIs.
11
+
12
+ Validate representative skill manifests and policies against the schemas in `schemas/`.
13
+
14
+ `tests/fixtures/policy/properties.json` generates cross-products of safe prefixes, separators, and restricted suffixes, then checks wrappers, heredocs, arguments, provider-specific `npx`, curl approvals, bounded reads, and package-script bodies.
15
+
16
+ The analyzer is deliberately bounded. It rejects obvious bypasses and unknown execution rather than claiming full POSIX shell parsing.
@@ -0,0 +1,14 @@
1
+ # Privacy And Restricted-Evidence Tests
2
+
3
+ `tests/fixtures/privacy/cases.json` stores synthetic sensitive shapes as ordered parts so the repository does not retain complete token-like or private-key values.
4
+
5
+ Verify that:
6
+
7
+ - Secret-bearing files are not read without named approval.
8
+ - Evidence summaries do not reproduce sensitive values.
9
+ - Restricted commands do not appear as reusable examples.
10
+ - Private values are replaced with safe descriptions or placeholders.
11
+ - An intentionally local credential is not treated as an incident without exposure evidence.
12
+ - A credential shown to be printed, generated, committed, pushed, or externally exposed produces a rotation warning without printing the value.
13
+
14
+ The executable harness reconstructs values only in memory, confirms expected detection types, redacts them, and verifies no sensitive-looking value remains.