akm-cli 0.7.0 → 0.7.1

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 (327) hide show
  1. package/package.json +8 -8
  2. package/dist/tests/add-website-source.test.js +0 -119
  3. package/dist/tests/agent/agent-config-loader.test.js +0 -70
  4. package/dist/tests/agent/agent-config.test.js +0 -221
  5. package/dist/tests/agent/agent-detect.test.js +0 -100
  6. package/dist/tests/agent/agent-spawn.test.js +0 -234
  7. package/dist/tests/agent-output.test.js +0 -186
  8. package/dist/tests/architecture/agent-no-llm-sdk-guard.test.js +0 -103
  9. package/dist/tests/architecture/agent-spawn-seam.test.js +0 -193
  10. package/dist/tests/architecture/llm-stateless-seam.test.js +0 -112
  11. package/dist/tests/asset-ref.test.js +0 -192
  12. package/dist/tests/asset-registry.test.js +0 -103
  13. package/dist/tests/asset-spec.test.js +0 -241
  14. package/dist/tests/bench/attribution.test.js +0 -996
  15. package/dist/tests/bench/cleanup-sigint.test.js +0 -83
  16. package/dist/tests/bench/cleanup.js +0 -234
  17. package/dist/tests/bench/cleanup.test.js +0 -166
  18. package/dist/tests/bench/cli.js +0 -1018
  19. package/dist/tests/bench/cli.test.js +0 -445
  20. package/dist/tests/bench/compare.test.js +0 -556
  21. package/dist/tests/bench/corpus.js +0 -317
  22. package/dist/tests/bench/corpus.test.js +0 -258
  23. package/dist/tests/bench/doctor.js +0 -525
  24. package/dist/tests/bench/driver.js +0 -401
  25. package/dist/tests/bench/driver.test.js +0 -584
  26. package/dist/tests/bench/environment.js +0 -233
  27. package/dist/tests/bench/environment.test.js +0 -199
  28. package/dist/tests/bench/evolve-metrics.js +0 -179
  29. package/dist/tests/bench/evolve-metrics.test.js +0 -187
  30. package/dist/tests/bench/evolve.js +0 -647
  31. package/dist/tests/bench/evolve.test.js +0 -624
  32. package/dist/tests/bench/failure-modes.test.js +0 -349
  33. package/dist/tests/bench/feedback-integrity.test.js +0 -457
  34. package/dist/tests/bench/leakage.test.js +0 -228
  35. package/dist/tests/bench/learning-curve.test.js +0 -134
  36. package/dist/tests/bench/metrics.js +0 -2395
  37. package/dist/tests/bench/metrics.test.js +0 -1150
  38. package/dist/tests/bench/no-os-tmpdir-invariant.test.js +0 -43
  39. package/dist/tests/bench/opencode-config.js +0 -194
  40. package/dist/tests/bench/opencode-config.test.js +0 -370
  41. package/dist/tests/bench/report.js +0 -1885
  42. package/dist/tests/bench/report.test.js +0 -1038
  43. package/dist/tests/bench/run-config.js +0 -355
  44. package/dist/tests/bench/run-config.test.js +0 -298
  45. package/dist/tests/bench/run-curate-test.js +0 -32
  46. package/dist/tests/bench/run-failing-tasks.js +0 -56
  47. package/dist/tests/bench/run-full-bench.js +0 -51
  48. package/dist/tests/bench/run-items36-targeted.js +0 -69
  49. package/dist/tests/bench/run-nano-quick.js +0 -42
  50. package/dist/tests/bench/run-waveg-targeted.js +0 -62
  51. package/dist/tests/bench/runner.js +0 -699
  52. package/dist/tests/bench/runner.test.js +0 -958
  53. package/dist/tests/bench/search-bridge.test.js +0 -331
  54. package/dist/tests/bench/tmp.js +0 -131
  55. package/dist/tests/bench/trajectory.js +0 -116
  56. package/dist/tests/bench/trajectory.test.js +0 -127
  57. package/dist/tests/bench/verifier.js +0 -114
  58. package/dist/tests/bench/verifier.test.js +0 -118
  59. package/dist/tests/bench/workflow-evaluator.js +0 -557
  60. package/dist/tests/bench/workflow-evaluator.test.js +0 -421
  61. package/dist/tests/bench/workflow-spec.js +0 -345
  62. package/dist/tests/bench/workflow-spec.test.js +0 -363
  63. package/dist/tests/bench/workflow-trace.js +0 -472
  64. package/dist/tests/bench/workflow-trace.test.js +0 -254
  65. package/dist/tests/benchmark-search-quality.js +0 -536
  66. package/dist/tests/benchmark-suite.js +0 -1441
  67. package/dist/tests/capture-cli.test.js +0 -112
  68. package/dist/tests/cli-errors.test.js +0 -204
  69. package/dist/tests/commands/events.test.js +0 -370
  70. package/dist/tests/commands/history.test.js +0 -418
  71. package/dist/tests/commands/import.test.js +0 -103
  72. package/dist/tests/commands/proposal-cli.test.js +0 -209
  73. package/dist/tests/commands/reflect-propose-cli.test.js +0 -333
  74. package/dist/tests/commands/remember.test.js +0 -97
  75. package/dist/tests/commands/scope-flags.test.js +0 -300
  76. package/dist/tests/commands/search.test.js +0 -537
  77. package/dist/tests/commands/show-indexer-parity.test.js +0 -117
  78. package/dist/tests/commands/show.test.js +0 -294
  79. package/dist/tests/common.test.js +0 -266
  80. package/dist/tests/completions.test.js +0 -142
  81. package/dist/tests/config-cli.test.js +0 -193
  82. package/dist/tests/config-llm-features.test.js +0 -139
  83. package/dist/tests/config.test.js +0 -569
  84. package/dist/tests/contracts/migration-baseline.test.js +0 -43
  85. package/dist/tests/contracts/reflect-propose-envelope.test.js +0 -139
  86. package/dist/tests/contracts/spec-helpers.js +0 -46
  87. package/dist/tests/contracts/v1-spec-section-11-proposal-queue.test.js +0 -228
  88. package/dist/tests/contracts/v1-spec-section-12-agent-config.test.js +0 -56
  89. package/dist/tests/contracts/v1-spec-section-13-lesson-type.test.js +0 -34
  90. package/dist/tests/contracts/v1-spec-section-14-llm-features.test.js +0 -94
  91. package/dist/tests/contracts/v1-spec-section-4-1-asset-types.test.js +0 -39
  92. package/dist/tests/contracts/v1-spec-section-4-2-quality-rules.test.js +0 -44
  93. package/dist/tests/contracts/v1-spec-section-5-configuration.test.js +0 -47
  94. package/dist/tests/contracts/v1-spec-section-6-orchestration.test.js +0 -40
  95. package/dist/tests/contracts/v1-spec-section-7-module-layout.test.js +0 -58
  96. package/dist/tests/contracts/v1-spec-section-8-extension-points.test.js +0 -34
  97. package/dist/tests/contracts/v1-spec-section-9-4-cli-surface.test.js +0 -75
  98. package/dist/tests/contracts/v1-spec-section-9-7-llm-agent-boundary.test.js +0 -36
  99. package/dist/tests/core/write-source.test.js +0 -366
  100. package/dist/tests/curate-command.test.js +0 -87
  101. package/dist/tests/db-scoring.test.js +0 -201
  102. package/dist/tests/db.test.js +0 -654
  103. package/dist/tests/distill-cli-flag.test.js +0 -208
  104. package/dist/tests/distill.test.js +0 -515
  105. package/dist/tests/docker-install.test.js +0 -120
  106. package/dist/tests/e2e.test.js +0 -1419
  107. package/dist/tests/embedder.test.js +0 -340
  108. package/dist/tests/embedding-model-config.test.js +0 -379
  109. package/dist/tests/feedback-command.test.js +0 -172
  110. package/dist/tests/file-context.test.js +0 -552
  111. package/dist/tests/fixtures/scripts/git/summarize-diff.js +0 -9
  112. package/dist/tests/fixtures/scripts/lint/eslint-check.js +0 -7
  113. package/dist/tests/fixtures/stashes/load.js +0 -166
  114. package/dist/tests/fixtures/stashes/load.test.js +0 -97
  115. package/dist/tests/fixtures/stashes/ranking-baseline/scripts/mem0-search.js +0 -12
  116. package/dist/tests/frontmatter.test.js +0 -190
  117. package/dist/tests/fts-field-weighting.test.js +0 -254
  118. package/dist/tests/fuzzy-search.test.js +0 -230
  119. package/dist/tests/git-provider-clone.test.js +0 -45
  120. package/dist/tests/github.test.js +0 -161
  121. package/dist/tests/graph-boost-ranking.test.js +0 -305
  122. package/dist/tests/graph-extraction.test.js +0 -282
  123. package/dist/tests/helpers/usage-events.js +0 -8
  124. package/dist/tests/index-pass-llm.test.js +0 -161
  125. package/dist/tests/indexer.test.js +0 -570
  126. package/dist/tests/info-command.test.js +0 -166
  127. package/dist/tests/init.test.js +0 -69
  128. package/dist/tests/install-script.test.js +0 -246
  129. package/dist/tests/integration/agent-real-profile.test.js +0 -94
  130. package/dist/tests/issue-36-repro.test.js +0 -304
  131. package/dist/tests/issues-191-194.test.js +0 -160
  132. package/dist/tests/lesson-lint.test.js +0 -111
  133. package/dist/tests/llm-client.test.js +0 -115
  134. package/dist/tests/llm-feature-gate.test.js +0 -151
  135. package/dist/tests/llm.test.js +0 -139
  136. package/dist/tests/lockfile.test.js +0 -216
  137. package/dist/tests/manifest.test.js +0 -205
  138. package/dist/tests/markdown.test.js +0 -126
  139. package/dist/tests/matchers-unit.test.js +0 -189
  140. package/dist/tests/memory-inference.test.js +0 -299
  141. package/dist/tests/merge-scoring.test.js +0 -136
  142. package/dist/tests/metadata.test.js +0 -313
  143. package/dist/tests/migration-help.test.js +0 -89
  144. package/dist/tests/origin-resolve.test.js +0 -124
  145. package/dist/tests/output-baseline.test.js +0 -218
  146. package/dist/tests/output-shapes-unit.test.js +0 -478
  147. package/dist/tests/parallel-search.test.js +0 -272
  148. package/dist/tests/parameter-metadata.test.js +0 -365
  149. package/dist/tests/paths.test.js +0 -177
  150. package/dist/tests/progressive-disclosure.test.js +0 -280
  151. package/dist/tests/proposals.test.js +0 -279
  152. package/dist/tests/proposed-quality.test.js +0 -271
  153. package/dist/tests/provider-registry.test.js +0 -32
  154. package/dist/tests/ranking-regression.test.js +0 -548
  155. package/dist/tests/reflect-propose.test.js +0 -455
  156. package/dist/tests/registry-build-index.test.js +0 -394
  157. package/dist/tests/registry-cli.test.js +0 -290
  158. package/dist/tests/registry-index-v2.test.js +0 -430
  159. package/dist/tests/registry-install.test.js +0 -728
  160. package/dist/tests/registry-providers/parity.test.js +0 -189
  161. package/dist/tests/registry-providers/skills-sh.test.js +0 -309
  162. package/dist/tests/registry-providers/static-index.test.js +0 -238
  163. package/dist/tests/registry-resolve.test.js +0 -126
  164. package/dist/tests/registry-search.test.js +0 -923
  165. package/dist/tests/remember-frontmatter.test.js +0 -378
  166. package/dist/tests/remember-unit.test.js +0 -123
  167. package/dist/tests/ripgrep-install.test.js +0 -251
  168. package/dist/tests/ripgrep-resolve.test.js +0 -108
  169. package/dist/tests/ripgrep.test.js +0 -163
  170. package/dist/tests/save-command.test.js +0 -94
  171. package/dist/tests/save-trust-qa-fixes.test.js +0 -270
  172. package/dist/tests/scoring-pipeline.test.js +0 -648
  173. package/dist/tests/search-include-proposed-cli.test.js +0 -118
  174. package/dist/tests/self-update.test.js +0 -442
  175. package/dist/tests/semantic-search-e2e.test.js +0 -512
  176. package/dist/tests/semantic-status.test.js +0 -471
  177. package/dist/tests/setup-run.integration.js +0 -877
  178. package/dist/tests/setup-wizard.test.js +0 -198
  179. package/dist/tests/setup.test.js +0 -131
  180. package/dist/tests/source-add.test.js +0 -11
  181. package/dist/tests/source-clone.test.js +0 -254
  182. package/dist/tests/source-manage.test.js +0 -366
  183. package/dist/tests/source-providers/filesystem.test.js +0 -82
  184. package/dist/tests/source-providers/git.test.js +0 -252
  185. package/dist/tests/source-providers/website.test.js +0 -128
  186. package/dist/tests/source-qa-fixes.test.js +0 -286
  187. package/dist/tests/source-registry.test.js +0 -350
  188. package/dist/tests/source-resolve.test.js +0 -100
  189. package/dist/tests/source-source.test.js +0 -281
  190. package/dist/tests/source.test.js +0 -533
  191. package/dist/tests/tar-utils-scan.test.js +0 -73
  192. package/dist/tests/toggle-components.test.js +0 -73
  193. package/dist/tests/usage-telemetry.test.js +0 -265
  194. package/dist/tests/utility-scoring.test.js +0 -558
  195. package/dist/tests/vault-load-error.test.js +0 -78
  196. package/dist/tests/vault-qa-fixes.test.js +0 -194
  197. package/dist/tests/vault.test.js +0 -429
  198. package/dist/tests/vector-search.test.js +0 -608
  199. package/dist/tests/walker.test.js +0 -252
  200. package/dist/tests/wave2-cluster-bc.test.js +0 -228
  201. package/dist/tests/wave2-cluster-d.test.js +0 -180
  202. package/dist/tests/wave2-cluster-e.test.js +0 -179
  203. package/dist/tests/wiki-qa-fixes.test.js +0 -270
  204. package/dist/tests/wiki.test.js +0 -529
  205. package/dist/tests/workflow-cli.test.js +0 -271
  206. package/dist/tests/workflow-markdown.test.js +0 -171
  207. package/dist/tests/workflow-path-escape.test.js +0 -132
  208. package/dist/tests/workflow-qa-fixes.test.js +0 -395
  209. package/dist/tests/workflows/indexer-rejection.test.js +0 -213
  210. /package/dist/{src/cli.js → cli.js} +0 -0
  211. /package/dist/{src/commands → commands}/completions.js +0 -0
  212. /package/dist/{src/commands → commands}/config-cli.js +0 -0
  213. /package/dist/{src/commands → commands}/curate.js +0 -0
  214. /package/dist/{src/commands → commands}/distill.js +0 -0
  215. /package/dist/{src/commands → commands}/events.js +0 -0
  216. /package/dist/{src/commands → commands}/history.js +0 -0
  217. /package/dist/{src/commands → commands}/info.js +0 -0
  218. /package/dist/{src/commands → commands}/init.js +0 -0
  219. /package/dist/{src/commands → commands}/install-audit.js +0 -0
  220. /package/dist/{src/commands → commands}/installed-stashes.js +0 -0
  221. /package/dist/{src/commands → commands}/migration-help.js +0 -0
  222. /package/dist/{src/commands → commands}/proposal.js +0 -0
  223. /package/dist/{src/commands → commands}/propose.js +0 -0
  224. /package/dist/{src/commands → commands}/reflect.js +0 -0
  225. /package/dist/{src/commands → commands}/registry-search.js +0 -0
  226. /package/dist/{src/commands → commands}/remember.js +0 -0
  227. /package/dist/{src/commands → commands}/search.js +0 -0
  228. /package/dist/{src/commands → commands}/self-update.js +0 -0
  229. /package/dist/{src/commands → commands}/show.js +0 -0
  230. /package/dist/{src/commands → commands}/source-add.js +0 -0
  231. /package/dist/{src/commands → commands}/source-clone.js +0 -0
  232. /package/dist/{src/commands → commands}/source-manage.js +0 -0
  233. /package/dist/{src/commands → commands}/vault.js +0 -0
  234. /package/dist/{src/core → core}/asset-ref.js +0 -0
  235. /package/dist/{src/core → core}/asset-registry.js +0 -0
  236. /package/dist/{src/core → core}/asset-spec.js +0 -0
  237. /package/dist/{src/core → core}/common.js +0 -0
  238. /package/dist/{src/core → core}/config.js +0 -0
  239. /package/dist/{src/core → core}/errors.js +0 -0
  240. /package/dist/{src/core → core}/events.js +0 -0
  241. /package/dist/{src/core → core}/frontmatter.js +0 -0
  242. /package/dist/{src/core → core}/lesson-lint.js +0 -0
  243. /package/dist/{src/core → core}/markdown.js +0 -0
  244. /package/dist/{src/core → core}/paths.js +0 -0
  245. /package/dist/{src/core → core}/proposals.js +0 -0
  246. /package/dist/{src/core → core}/warn.js +0 -0
  247. /package/dist/{src/core → core}/write-source.js +0 -0
  248. /package/dist/{src/indexer → indexer}/db-search.js +0 -0
  249. /package/dist/{src/indexer → indexer}/db.js +0 -0
  250. /package/dist/{src/indexer → indexer}/file-context.js +0 -0
  251. /package/dist/{src/indexer → indexer}/graph-boost.js +0 -0
  252. /package/dist/{src/indexer → indexer}/graph-extraction.js +0 -0
  253. /package/dist/{src/indexer → indexer}/indexer.js +0 -0
  254. /package/dist/{src/indexer → indexer}/manifest.js +0 -0
  255. /package/dist/{src/indexer → indexer}/matchers.js +0 -0
  256. /package/dist/{src/indexer → indexer}/memory-inference.js +0 -0
  257. /package/dist/{src/indexer → indexer}/metadata.js +0 -0
  258. /package/dist/{src/indexer → indexer}/search-fields.js +0 -0
  259. /package/dist/{src/indexer → indexer}/search-source.js +0 -0
  260. /package/dist/{src/indexer → indexer}/semantic-status.js +0 -0
  261. /package/dist/{src/indexer → indexer}/usage-events.js +0 -0
  262. /package/dist/{src/indexer → indexer}/walker.js +0 -0
  263. /package/dist/{src/integrations → integrations}/agent/config.js +0 -0
  264. /package/dist/{src/integrations → integrations}/agent/detect.js +0 -0
  265. /package/dist/{src/integrations → integrations}/agent/index.js +0 -0
  266. /package/dist/{src/integrations → integrations}/agent/profiles.js +0 -0
  267. /package/dist/{src/integrations → integrations}/agent/prompts.js +0 -0
  268. /package/dist/{src/integrations → integrations}/agent/spawn.js +0 -0
  269. /package/dist/{src/integrations → integrations}/github.js +0 -0
  270. /package/dist/{src/integrations → integrations}/lockfile.js +0 -0
  271. /package/dist/{src/llm → llm}/client.js +0 -0
  272. /package/dist/{src/llm → llm}/embedder.js +0 -0
  273. /package/dist/{src/llm → llm}/embedders/cache.js +0 -0
  274. /package/dist/{src/llm → llm}/embedders/local.js +0 -0
  275. /package/dist/{src/llm → llm}/embedders/remote.js +0 -0
  276. /package/dist/{src/llm → llm}/embedders/types.js +0 -0
  277. /package/dist/{src/llm → llm}/feature-gate.js +0 -0
  278. /package/dist/{src/llm → llm}/graph-extract.js +0 -0
  279. /package/dist/{src/llm → llm}/index-passes.js +0 -0
  280. /package/dist/{src/llm → llm}/memory-infer.js +0 -0
  281. /package/dist/{src/llm → llm}/metadata-enhance.js +0 -0
  282. /package/dist/{src/output → output}/cli-hints.js +0 -0
  283. /package/dist/{src/output → output}/context.js +0 -0
  284. /package/dist/{src/output → output}/renderers.js +0 -0
  285. /package/dist/{src/output → output}/shapes.js +0 -0
  286. /package/dist/{src/output → output}/text.js +0 -0
  287. /package/dist/{src/registry → registry}/build-index.js +0 -0
  288. /package/dist/{src/registry → registry}/create-provider-registry.js +0 -0
  289. /package/dist/{src/registry → registry}/factory.js +0 -0
  290. /package/dist/{src/registry → registry}/origin-resolve.js +0 -0
  291. /package/dist/{src/registry → registry}/providers/index.js +0 -0
  292. /package/dist/{src/registry → registry}/providers/skills-sh.js +0 -0
  293. /package/dist/{src/registry → registry}/providers/static-index.js +0 -0
  294. /package/dist/{src/registry → registry}/providers/types.js +0 -0
  295. /package/dist/{src/registry → registry}/resolve.js +0 -0
  296. /package/dist/{src/registry → registry}/types.js +0 -0
  297. /package/dist/{src/setup → setup}/detect.js +0 -0
  298. /package/dist/{src/setup → setup}/ripgrep-install.js +0 -0
  299. /package/dist/{src/setup → setup}/ripgrep-resolve.js +0 -0
  300. /package/dist/{src/setup → setup}/setup.js +0 -0
  301. /package/dist/{src/setup → setup}/steps.js +0 -0
  302. /package/dist/{src/sources → sources}/include.js +0 -0
  303. /package/dist/{src/sources → sources}/provider-factory.js +0 -0
  304. /package/dist/{src/sources → sources}/provider.js +0 -0
  305. /package/dist/{src/sources → sources}/providers/filesystem.js +0 -0
  306. /package/dist/{src/sources → sources}/providers/git.js +0 -0
  307. /package/dist/{src/sources → sources}/providers/index.js +0 -0
  308. /package/dist/{src/sources → sources}/providers/install-types.js +0 -0
  309. /package/dist/{src/sources → sources}/providers/npm.js +0 -0
  310. /package/dist/{src/sources → sources}/providers/provider-utils.js +0 -0
  311. /package/dist/{src/sources → sources}/providers/sync-from-ref.js +0 -0
  312. /package/dist/{src/sources → sources}/providers/tar-utils.js +0 -0
  313. /package/dist/{src/sources → sources}/providers/website.js +0 -0
  314. /package/dist/{src/sources → sources}/resolve.js +0 -0
  315. /package/dist/{src/sources → sources}/types.js +0 -0
  316. /package/dist/{src/templates → templates}/wiki-templates.js +0 -0
  317. /package/dist/{src/version.js → version.js} +0 -0
  318. /package/dist/{src/wiki → wiki}/wiki.js +0 -0
  319. /package/dist/{src/workflows → workflows}/authoring.js +0 -0
  320. /package/dist/{src/workflows → workflows}/cli.js +0 -0
  321. /package/dist/{src/workflows → workflows}/db.js +0 -0
  322. /package/dist/{src/workflows → workflows}/document-cache.js +0 -0
  323. /package/dist/{src/workflows → workflows}/parser.js +0 -0
  324. /package/dist/{src/workflows → workflows}/renderer.js +0 -0
  325. /package/dist/{src/workflows → workflows}/runs.js +0 -0
  326. /package/dist/{src/workflows → workflows}/schema.js +0 -0
  327. /package/dist/{src/workflows → workflows}/validator.js +0 -0
@@ -1,189 +0,0 @@
1
- /**
2
- * Phase 6 (v1 architecture refactor) — parity test.
3
- *
4
- * Both built-in registry providers (`static-index`, `skills-sh`) must respond
5
- * to the same `RegistryProvider` interface methods uniformly. This test fans
6
- * out the same query through each provider and asserts the call surface is
7
- * equivalent — never the per-provider scoring or upstream-data shape.
8
- *
9
- * If you add a third built-in registry provider, register it here.
10
- */
11
- import { afterAll, afterEach, beforeEach, describe, expect, test } from "bun:test";
12
- import fs from "node:fs";
13
- import os from "node:os";
14
- import path from "node:path";
15
- import { resolveProviderFactory } from "../../src/registry/factory";
16
- // Trigger self-registration of every built-in provider
17
- import "../../src/registry/providers/index";
18
- // ── Fixtures ────────────────────────────────────────────────────────────────
19
- const STATIC_INDEX_FIXTURE = {
20
- version: 3,
21
- updatedAt: "2026-04-25T00:00:00Z",
22
- stashes: [
23
- {
24
- id: "github:acme/widgets",
25
- name: "widgets",
26
- description: "Widget skills",
27
- ref: "acme/widgets",
28
- source: "github",
29
- tags: ["widget"],
30
- assetTypes: ["skill"],
31
- assets: [{ type: "skill", name: "widget-deploy" }],
32
- },
33
- ],
34
- };
35
- const SKILLS_SH_FIXTURE = {
36
- skills: [
37
- {
38
- id: "acme/widgets/widget-deploy",
39
- name: "widget-deploy",
40
- installs: 100,
41
- source: "acme/widgets",
42
- },
43
- ],
44
- };
45
- // ── Helpers ─────────────────────────────────────────────────────────────────
46
- const createdTmpDirs = [];
47
- const servers = [];
48
- function createTmpDir(prefix = "akm-parity-") {
49
- const dir = fs.mkdtempSync(path.join(os.tmpdir(), prefix));
50
- createdTmpDirs.push(dir);
51
- return dir;
52
- }
53
- function serveJson(body) {
54
- const server = Bun.serve({
55
- port: 0,
56
- fetch() {
57
- return new Response(JSON.stringify(body), {
58
- headers: { "Content-Type": "application/json" },
59
- });
60
- },
61
- });
62
- servers.push(server);
63
- return {
64
- url: `http://localhost:${server.port}`,
65
- close: () => server.stop(true),
66
- };
67
- }
68
- const originalXdgCacheHome = process.env.XDG_CACHE_HOME;
69
- beforeEach(() => {
70
- process.env.XDG_CACHE_HOME = createTmpDir("akm-parity-cache-");
71
- });
72
- afterEach(() => {
73
- for (const s of servers) {
74
- try {
75
- s.stop(true);
76
- }
77
- catch {
78
- /* already stopped */
79
- }
80
- }
81
- servers.length = 0;
82
- if (originalXdgCacheHome === undefined) {
83
- delete process.env.XDG_CACHE_HOME;
84
- }
85
- else {
86
- process.env.XDG_CACHE_HOME = originalXdgCacheHome;
87
- }
88
- });
89
- afterAll(() => {
90
- for (const dir of createdTmpDirs) {
91
- fs.rmSync(dir, { recursive: true, force: true });
92
- }
93
- });
94
- function buildHarnesses() {
95
- return [
96
- {
97
- type: "static-index",
98
- build: () => {
99
- const srv = serveJson(STATIC_INDEX_FIXTURE);
100
- const factory = resolveProviderFactory("static-index");
101
- if (!factory)
102
- throw new Error("static-index not registered");
103
- return factory({ url: `${srv.url}/index.json`, name: "official" });
104
- },
105
- },
106
- {
107
- type: "skills-sh",
108
- build: () => {
109
- const srv = serveJson(SKILLS_SH_FIXTURE);
110
- const factory = resolveProviderFactory("skills-sh");
111
- if (!factory)
112
- throw new Error("skills-sh not registered");
113
- return factory({ url: srv.url, name: "skills.sh" });
114
- },
115
- },
116
- ];
117
- }
118
- // ── Tests ───────────────────────────────────────────────────────────────────
119
- describe("RegistryProvider parity (built-in providers)", () => {
120
- for (const harness of buildHarnesses()) {
121
- describe(harness.type, () => {
122
- test("exposes the v1-spec interface methods", () => {
123
- const provider = harness.build();
124
- expect(typeof provider.search).toBe("function");
125
- expect(typeof provider.searchKits).toBe("function");
126
- expect(typeof provider.getKit).toBe("function");
127
- expect(typeof provider.canHandle).toBe("function");
128
- // searchAssets is optional, but both built-ins implement it
129
- expect(typeof provider.searchAssets).toBe("function");
130
- });
131
- test("searchKits returns KitResult-shaped entries", async () => {
132
- const provider = harness.build();
133
- const kits = await provider.searchKits({ text: "widget", limit: 10 });
134
- expect(Array.isArray(kits)).toBe(true);
135
- for (const kit of kits) {
136
- expect(typeof kit.id).toBe("string");
137
- expect(typeof kit.title).toBe("string");
138
- expect(typeof kit.installRef).toBe("string");
139
- }
140
- });
141
- test("canHandle accepts a github ref without throwing", () => {
142
- const provider = harness.build();
143
- const ref = {
144
- source: "github",
145
- ref: "acme/widgets",
146
- id: "github:acme/widgets",
147
- owner: "acme",
148
- repo: "widgets",
149
- };
150
- // Result is provider-specific; we only assert the call shape.
151
- const handled = provider.canHandle(ref);
152
- expect(typeof handled).toBe("boolean");
153
- });
154
- test("getKit returns a manifest or null without throwing", async () => {
155
- const provider = harness.build();
156
- const result = await provider.getKit("github:acme/widgets");
157
- if (result !== null) {
158
- expect(typeof result.id).toBe("string");
159
- expect(typeof result.installRef).toBe("string");
160
- }
161
- });
162
- });
163
- }
164
- test("first provider whose canHandle matches owns the install ref", () => {
165
- // Smoke test for the orchestrator pattern in commands/add.ts (post-Phase 6).
166
- // The order of factory registration (static-index → skills-sh) means
167
- // static-index claims github refs first as the catch-all.
168
- const types = ["static-index", "skills-sh"];
169
- const ref = {
170
- source: "github",
171
- ref: "acme/widgets",
172
- id: "github:acme/widgets",
173
- owner: "acme",
174
- repo: "widgets",
175
- };
176
- let owner;
177
- for (const type of types) {
178
- const factory = resolveProviderFactory(type);
179
- expect(factory).not.toBeNull();
180
- // Use a dummy URL — canHandle is pure dispatch on ref shape, not network.
181
- const provider = factory?.({ url: "http://localhost:0/none", name: type });
182
- if (provider?.canHandle(ref)) {
183
- owner = provider.type;
184
- break;
185
- }
186
- }
187
- expect(owner).toBeDefined();
188
- });
189
- });
@@ -1,309 +0,0 @@
1
- import { afterAll, afterEach, beforeEach, describe, expect, test } from "bun:test";
2
- import fs from "node:fs";
3
- import os from "node:os";
4
- import path from "node:path";
5
- import { resolveProviderFactory } from "../../src/registry/factory";
6
- // Trigger self-registration
7
- import "../../src/registry/providers/skills-sh";
8
- // ── Fixtures ────────────────────────────────────────────────────────────────
9
- const FIXTURE_RESPONSE = {
10
- skills: [
11
- {
12
- id: "vercel-labs/agent-skills/react-best-practices",
13
- name: "react-best-practices",
14
- installs: 22475,
15
- source: "vercel-labs/agent-skills",
16
- },
17
- { id: "some-org/web-skills/css-layout", name: "css-layout", installs: 5000, source: "some-org/web-skills" },
18
- { id: "solo-dev/my-skills/deploy-helper", name: "deploy-helper", installs: 100, source: "solo-dev/my-skills" },
19
- ],
20
- };
21
- // ── Helpers ─────────────────────────────────────────────────────────────────
22
- const createdTmpDirs = [];
23
- const servers = [];
24
- function createTmpDir(prefix = "akm-skills-sh-") {
25
- const dir = fs.mkdtempSync(path.join(os.tmpdir(), prefix));
26
- createdTmpDirs.push(dir);
27
- return dir;
28
- }
29
- function serveJson(body) {
30
- const server = Bun.serve({
31
- port: 0,
32
- fetch() {
33
- return new Response(JSON.stringify(body), {
34
- headers: { "Content-Type": "application/json" },
35
- });
36
- },
37
- });
38
- servers.push(server);
39
- return {
40
- url: `http://localhost:${server.port}`,
41
- close: () => server.stop(true),
42
- };
43
- }
44
- function serveError(status) {
45
- const server = Bun.serve({
46
- port: 0,
47
- fetch() {
48
- return new Response("error", { status });
49
- },
50
- });
51
- servers.push(server);
52
- return {
53
- url: `http://localhost:${server.port}`,
54
- close: () => server.stop(true),
55
- };
56
- }
57
- function serveText(text) {
58
- const server = Bun.serve({
59
- port: 0,
60
- fetch() {
61
- return new Response(text, {
62
- headers: { "Content-Type": "application/json" },
63
- });
64
- },
65
- });
66
- servers.push(server);
67
- return {
68
- url: `http://localhost:${server.port}`,
69
- close: () => server.stop(true),
70
- };
71
- }
72
- function makeProvider(url, name = "skills.sh") {
73
- const factory = resolveProviderFactory("skills-sh");
74
- if (!factory)
75
- throw new Error("skills-sh provider not registered");
76
- return factory({ url, name });
77
- }
78
- const originalXdgCacheHome = process.env.XDG_CACHE_HOME;
79
- beforeEach(() => {
80
- process.env.XDG_CACHE_HOME = createTmpDir("akm-skills-cache-");
81
- });
82
- afterEach(() => {
83
- for (const s of servers) {
84
- try {
85
- s.stop(true);
86
- }
87
- catch {
88
- /* already stopped */
89
- }
90
- }
91
- servers.length = 0;
92
- if (originalXdgCacheHome === undefined) {
93
- delete process.env.XDG_CACHE_HOME;
94
- }
95
- else {
96
- process.env.XDG_CACHE_HOME = originalXdgCacheHome;
97
- }
98
- });
99
- afterAll(() => {
100
- for (const dir of createdTmpDirs) {
101
- fs.rmSync(dir, { recursive: true, force: true });
102
- }
103
- });
104
- // ── Tests ───────────────────────────────────────────────────────────────────
105
- describe("SkillsShProvider", () => {
106
- test("factory is registered", () => {
107
- const factory = resolveProviderFactory("skills-sh");
108
- expect(factory).not.toBeNull();
109
- });
110
- describe("happy path", () => {
111
- test("returns correct number of hits", async () => {
112
- const srv = serveJson(FIXTURE_RESPONSE);
113
- const provider = makeProvider(srv.url);
114
- const result = await provider.search({ query: "react", limit: 10 });
115
- expect(result.hits).toHaveLength(3);
116
- });
117
- test("hit IDs are prefixed with skills-sh:", async () => {
118
- const srv = serveJson(FIXTURE_RESPONSE);
119
- const provider = makeProvider(srv.url);
120
- const result = await provider.search({ query: "react", limit: 10 });
121
- for (const hit of result.hits) {
122
- expect(hit.id).toStartWith("skills-sh:");
123
- }
124
- });
125
- test("hit source is github", async () => {
126
- const srv = serveJson(FIXTURE_RESPONSE);
127
- const provider = makeProvider(srv.url);
128
- const result = await provider.search({ query: "react", limit: 10 });
129
- for (const hit of result.hits) {
130
- expect(hit.source).toBe("github");
131
- }
132
- });
133
- test("hit ref matches entry source", async () => {
134
- const srv = serveJson(FIXTURE_RESPONSE);
135
- const provider = makeProvider(srv.url);
136
- const result = await provider.search({ query: "react", limit: 10 });
137
- expect(result.hits[0].ref).toBe("vercel-labs/agent-skills");
138
- expect(result.hits[1].ref).toBe("some-org/web-skills");
139
- expect(result.hits[2].ref).toBe("solo-dev/my-skills");
140
- });
141
- test("hit homepage derives from config URL", async () => {
142
- const srv = serveJson(FIXTURE_RESPONSE);
143
- const provider = makeProvider(srv.url);
144
- const result = await provider.search({ query: "react", limit: 10 });
145
- expect(result.hits[0].homepage).toBe(`${srv.url}/vercel-labs/agent-skills/react-best-practices`);
146
- });
147
- test("registryName is set from config", async () => {
148
- const srv = serveJson(FIXTURE_RESPONSE);
149
- const provider = makeProvider(srv.url, "my-skills-registry");
150
- const result = await provider.search({ query: "react", limit: 10 });
151
- for (const hit of result.hits) {
152
- expect(hit.registryName).toBe("my-skills-registry");
153
- }
154
- });
155
- test("metadata includes installs and author", async () => {
156
- const srv = serveJson(FIXTURE_RESPONSE);
157
- const provider = makeProvider(srv.url);
158
- const result = await provider.search({ query: "react", limit: 10 });
159
- expect(result.hits[0].metadata?.installs).toBe("22475");
160
- expect(result.hits[0].metadata?.author).toBe("vercel-labs");
161
- });
162
- test("registryName defaults to skills.sh when config has no name", async () => {
163
- const srv = serveJson(FIXTURE_RESPONSE);
164
- const factory = resolveProviderFactory("skills-sh");
165
- expect(factory).not.toBeNull();
166
- const provider = factory?.({ url: srv.url });
167
- const result = await provider?.search({ query: "react", limit: 10 });
168
- for (const hit of result?.hits ?? []) {
169
- expect(hit.registryName).toBe("skills.sh");
170
- }
171
- });
172
- test("limit is enforced client-side", async () => {
173
- const srv = serveJson(FIXTURE_RESPONSE);
174
- const provider = makeProvider(srv.url);
175
- const result = await provider.search({ query: "react", limit: 1 });
176
- expect(result.hits).toHaveLength(1);
177
- });
178
- test("no warnings on success", async () => {
179
- const srv = serveJson(FIXTURE_RESPONSE);
180
- const provider = makeProvider(srv.url);
181
- const result = await provider.search({ query: "react", limit: 10 });
182
- expect(result.warnings).toBeUndefined();
183
- });
184
- });
185
- describe("empty results", () => {
186
- test("empty skills array returns empty hits and no warnings", async () => {
187
- const srv = serveJson({ skills: [] });
188
- const provider = makeProvider(srv.url);
189
- const result = await provider.search({ query: "nonexistent", limit: 10 });
190
- expect(result.hits).toEqual([]);
191
- expect(result.warnings).toBeUndefined();
192
- });
193
- });
194
- describe("error handling", () => {
195
- test("404 returns empty hits with warning", async () => {
196
- const srv = serveError(404);
197
- const provider = makeProvider(srv.url);
198
- const result = await provider.search({ query: "test", limit: 10 });
199
- expect(result.hits).toEqual([]);
200
- expect(result.warnings).toHaveLength(1);
201
- expect(result.warnings?.[0]).toContain("skills.sh");
202
- });
203
- test("500 returns empty hits with warning", async () => {
204
- const srv = serveError(500);
205
- const provider = makeProvider(srv.url);
206
- const result = await provider.search({ query: "test", limit: 10 });
207
- expect(result.hits).toEqual([]);
208
- expect(result.warnings?.[0]).toContain("HTTP 500");
209
- });
210
- test("unreachable server returns warning", async () => {
211
- const provider = makeProvider("http://127.0.0.1:1");
212
- const result = await provider.search({ query: "test", limit: 10 });
213
- expect(result.hits).toEqual([]);
214
- expect(result.warnings).toHaveLength(1);
215
- });
216
- });
217
- describe("malformed responses", () => {
218
- test("non-JSON returns empty hits with warning", async () => {
219
- const srv = serveText("not json at all");
220
- const provider = makeProvider(srv.url);
221
- const result = await provider.search({ query: "test", limit: 10 });
222
- expect(result.hits).toEqual([]);
223
- expect(result.warnings).toBeDefined();
224
- });
225
- test("missing skills array returns empty hits without warning", async () => {
226
- const srv = serveJson({ unexpected: true });
227
- const provider = makeProvider(srv.url);
228
- const result = await provider.search({ query: "test", limit: 10 });
229
- expect(result.hits).toEqual([]);
230
- // No warning because the response was valid JSON, just empty results
231
- expect(result.warnings).toBeUndefined();
232
- });
233
- test("skills with invalid entries filters them out", async () => {
234
- const srv = serveJson({
235
- skills: [
236
- { id: "valid/skill", name: "valid", installs: 100, source: "valid/repo" },
237
- { id: "missing-fields" }, // invalid
238
- "not-an-object", // invalid
239
- null, // invalid
240
- ],
241
- });
242
- const provider = makeProvider(srv.url);
243
- const result = await provider.search({ query: "test", limit: 10 });
244
- expect(result.hits).toHaveLength(1);
245
- expect(result.hits[0].title).toBe("valid");
246
- });
247
- });
248
- describe("score normalization", () => {
249
- test("scores are in 0-1 range", async () => {
250
- const srv = serveJson(FIXTURE_RESPONSE);
251
- const provider = makeProvider(srv.url);
252
- const result = await provider.search({ query: "react", limit: 10 });
253
- for (const hit of result.hits) {
254
- expect(hit.score).toBeGreaterThanOrEqual(0);
255
- expect(hit.score).toBeLessThanOrEqual(1);
256
- }
257
- });
258
- test("highest-installs entry gets score 1.0", async () => {
259
- const srv = serveJson(FIXTURE_RESPONSE);
260
- const provider = makeProvider(srv.url);
261
- const result = await provider.search({ query: "react", limit: 10 });
262
- // vercel-labs has 22475 installs (highest)
263
- expect(result.hits[0].score).toBe(1);
264
- });
265
- });
266
- describe("asset hits", () => {
267
- test("includeAssets returns RegistryAssetSearchHit entries", async () => {
268
- const srv = serveJson(FIXTURE_RESPONSE);
269
- const provider = makeProvider(srv.url);
270
- const result = await provider.search({ query: "react", limit: 10, includeAssets: true });
271
- expect(result.assetHits).toHaveLength(3);
272
- });
273
- test("asset hits have assetType skill", async () => {
274
- const srv = serveJson(FIXTURE_RESPONSE);
275
- const provider = makeProvider(srv.url);
276
- const result = await provider.search({ query: "react", limit: 10, includeAssets: true });
277
- for (const hit of result.assetHits ?? []) {
278
- expect(hit.assetType).toBe("skill");
279
- }
280
- });
281
- test("asset hits have correct action", async () => {
282
- const srv = serveJson(FIXTURE_RESPONSE);
283
- const provider = makeProvider(srv.url);
284
- const result = await provider.search({ query: "react", limit: 10, includeAssets: true });
285
- expect(result.assetHits?.[0].action).toBe("akm add github:vercel-labs/agent-skills");
286
- });
287
- test("no asset hits when includeAssets is false", async () => {
288
- const srv = serveJson(FIXTURE_RESPONSE);
289
- const provider = makeProvider(srv.url);
290
- const result = await provider.search({ query: "react", limit: 10, includeAssets: false });
291
- expect(result.assetHits).toBeUndefined();
292
- });
293
- });
294
- describe("caching", () => {
295
- test("second call uses cache after server is killed", async () => {
296
- const srv = serveJson(FIXTURE_RESPONSE);
297
- const provider = makeProvider(srv.url);
298
- // First call — fetches from server
299
- const result1 = await provider.search({ query: "react", limit: 10 });
300
- expect(result1.hits).toHaveLength(3);
301
- // Kill the server
302
- srv.close();
303
- // Second call — should use cache
304
- const result2 = await provider.search({ query: "react", limit: 10 });
305
- expect(result2.hits).toHaveLength(3);
306
- expect(result2.hits[0].id).toBe(result1.hits[0].id);
307
- });
308
- });
309
- });