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.
- package/package.json +8 -8
- package/dist/tests/add-website-source.test.js +0 -119
- package/dist/tests/agent/agent-config-loader.test.js +0 -70
- package/dist/tests/agent/agent-config.test.js +0 -221
- package/dist/tests/agent/agent-detect.test.js +0 -100
- package/dist/tests/agent/agent-spawn.test.js +0 -234
- package/dist/tests/agent-output.test.js +0 -186
- package/dist/tests/architecture/agent-no-llm-sdk-guard.test.js +0 -103
- package/dist/tests/architecture/agent-spawn-seam.test.js +0 -193
- package/dist/tests/architecture/llm-stateless-seam.test.js +0 -112
- package/dist/tests/asset-ref.test.js +0 -192
- package/dist/tests/asset-registry.test.js +0 -103
- package/dist/tests/asset-spec.test.js +0 -241
- package/dist/tests/bench/attribution.test.js +0 -996
- package/dist/tests/bench/cleanup-sigint.test.js +0 -83
- package/dist/tests/bench/cleanup.js +0 -234
- package/dist/tests/bench/cleanup.test.js +0 -166
- package/dist/tests/bench/cli.js +0 -1018
- package/dist/tests/bench/cli.test.js +0 -445
- package/dist/tests/bench/compare.test.js +0 -556
- package/dist/tests/bench/corpus.js +0 -317
- package/dist/tests/bench/corpus.test.js +0 -258
- package/dist/tests/bench/doctor.js +0 -525
- package/dist/tests/bench/driver.js +0 -401
- package/dist/tests/bench/driver.test.js +0 -584
- package/dist/tests/bench/environment.js +0 -233
- package/dist/tests/bench/environment.test.js +0 -199
- package/dist/tests/bench/evolve-metrics.js +0 -179
- package/dist/tests/bench/evolve-metrics.test.js +0 -187
- package/dist/tests/bench/evolve.js +0 -647
- package/dist/tests/bench/evolve.test.js +0 -624
- package/dist/tests/bench/failure-modes.test.js +0 -349
- package/dist/tests/bench/feedback-integrity.test.js +0 -457
- package/dist/tests/bench/leakage.test.js +0 -228
- package/dist/tests/bench/learning-curve.test.js +0 -134
- package/dist/tests/bench/metrics.js +0 -2395
- package/dist/tests/bench/metrics.test.js +0 -1150
- package/dist/tests/bench/no-os-tmpdir-invariant.test.js +0 -43
- package/dist/tests/bench/opencode-config.js +0 -194
- package/dist/tests/bench/opencode-config.test.js +0 -370
- package/dist/tests/bench/report.js +0 -1885
- package/dist/tests/bench/report.test.js +0 -1038
- package/dist/tests/bench/run-config.js +0 -355
- package/dist/tests/bench/run-config.test.js +0 -298
- package/dist/tests/bench/run-curate-test.js +0 -32
- package/dist/tests/bench/run-failing-tasks.js +0 -56
- package/dist/tests/bench/run-full-bench.js +0 -51
- package/dist/tests/bench/run-items36-targeted.js +0 -69
- package/dist/tests/bench/run-nano-quick.js +0 -42
- package/dist/tests/bench/run-waveg-targeted.js +0 -62
- package/dist/tests/bench/runner.js +0 -699
- package/dist/tests/bench/runner.test.js +0 -958
- package/dist/tests/bench/search-bridge.test.js +0 -331
- package/dist/tests/bench/tmp.js +0 -131
- package/dist/tests/bench/trajectory.js +0 -116
- package/dist/tests/bench/trajectory.test.js +0 -127
- package/dist/tests/bench/verifier.js +0 -114
- package/dist/tests/bench/verifier.test.js +0 -118
- package/dist/tests/bench/workflow-evaluator.js +0 -557
- package/dist/tests/bench/workflow-evaluator.test.js +0 -421
- package/dist/tests/bench/workflow-spec.js +0 -345
- package/dist/tests/bench/workflow-spec.test.js +0 -363
- package/dist/tests/bench/workflow-trace.js +0 -472
- package/dist/tests/bench/workflow-trace.test.js +0 -254
- package/dist/tests/benchmark-search-quality.js +0 -536
- package/dist/tests/benchmark-suite.js +0 -1441
- package/dist/tests/capture-cli.test.js +0 -112
- package/dist/tests/cli-errors.test.js +0 -204
- package/dist/tests/commands/events.test.js +0 -370
- package/dist/tests/commands/history.test.js +0 -418
- package/dist/tests/commands/import.test.js +0 -103
- package/dist/tests/commands/proposal-cli.test.js +0 -209
- package/dist/tests/commands/reflect-propose-cli.test.js +0 -333
- package/dist/tests/commands/remember.test.js +0 -97
- package/dist/tests/commands/scope-flags.test.js +0 -300
- package/dist/tests/commands/search.test.js +0 -537
- package/dist/tests/commands/show-indexer-parity.test.js +0 -117
- package/dist/tests/commands/show.test.js +0 -294
- package/dist/tests/common.test.js +0 -266
- package/dist/tests/completions.test.js +0 -142
- package/dist/tests/config-cli.test.js +0 -193
- package/dist/tests/config-llm-features.test.js +0 -139
- package/dist/tests/config.test.js +0 -569
- package/dist/tests/contracts/migration-baseline.test.js +0 -43
- package/dist/tests/contracts/reflect-propose-envelope.test.js +0 -139
- package/dist/tests/contracts/spec-helpers.js +0 -46
- package/dist/tests/contracts/v1-spec-section-11-proposal-queue.test.js +0 -228
- package/dist/tests/contracts/v1-spec-section-12-agent-config.test.js +0 -56
- package/dist/tests/contracts/v1-spec-section-13-lesson-type.test.js +0 -34
- package/dist/tests/contracts/v1-spec-section-14-llm-features.test.js +0 -94
- package/dist/tests/contracts/v1-spec-section-4-1-asset-types.test.js +0 -39
- package/dist/tests/contracts/v1-spec-section-4-2-quality-rules.test.js +0 -44
- package/dist/tests/contracts/v1-spec-section-5-configuration.test.js +0 -47
- package/dist/tests/contracts/v1-spec-section-6-orchestration.test.js +0 -40
- package/dist/tests/contracts/v1-spec-section-7-module-layout.test.js +0 -58
- package/dist/tests/contracts/v1-spec-section-8-extension-points.test.js +0 -34
- package/dist/tests/contracts/v1-spec-section-9-4-cli-surface.test.js +0 -75
- package/dist/tests/contracts/v1-spec-section-9-7-llm-agent-boundary.test.js +0 -36
- package/dist/tests/core/write-source.test.js +0 -366
- package/dist/tests/curate-command.test.js +0 -87
- package/dist/tests/db-scoring.test.js +0 -201
- package/dist/tests/db.test.js +0 -654
- package/dist/tests/distill-cli-flag.test.js +0 -208
- package/dist/tests/distill.test.js +0 -515
- package/dist/tests/docker-install.test.js +0 -120
- package/dist/tests/e2e.test.js +0 -1419
- package/dist/tests/embedder.test.js +0 -340
- package/dist/tests/embedding-model-config.test.js +0 -379
- package/dist/tests/feedback-command.test.js +0 -172
- package/dist/tests/file-context.test.js +0 -552
- package/dist/tests/fixtures/scripts/git/summarize-diff.js +0 -9
- package/dist/tests/fixtures/scripts/lint/eslint-check.js +0 -7
- package/dist/tests/fixtures/stashes/load.js +0 -166
- package/dist/tests/fixtures/stashes/load.test.js +0 -97
- package/dist/tests/fixtures/stashes/ranking-baseline/scripts/mem0-search.js +0 -12
- package/dist/tests/frontmatter.test.js +0 -190
- package/dist/tests/fts-field-weighting.test.js +0 -254
- package/dist/tests/fuzzy-search.test.js +0 -230
- package/dist/tests/git-provider-clone.test.js +0 -45
- package/dist/tests/github.test.js +0 -161
- package/dist/tests/graph-boost-ranking.test.js +0 -305
- package/dist/tests/graph-extraction.test.js +0 -282
- package/dist/tests/helpers/usage-events.js +0 -8
- package/dist/tests/index-pass-llm.test.js +0 -161
- package/dist/tests/indexer.test.js +0 -570
- package/dist/tests/info-command.test.js +0 -166
- package/dist/tests/init.test.js +0 -69
- package/dist/tests/install-script.test.js +0 -246
- package/dist/tests/integration/agent-real-profile.test.js +0 -94
- package/dist/tests/issue-36-repro.test.js +0 -304
- package/dist/tests/issues-191-194.test.js +0 -160
- package/dist/tests/lesson-lint.test.js +0 -111
- package/dist/tests/llm-client.test.js +0 -115
- package/dist/tests/llm-feature-gate.test.js +0 -151
- package/dist/tests/llm.test.js +0 -139
- package/dist/tests/lockfile.test.js +0 -216
- package/dist/tests/manifest.test.js +0 -205
- package/dist/tests/markdown.test.js +0 -126
- package/dist/tests/matchers-unit.test.js +0 -189
- package/dist/tests/memory-inference.test.js +0 -299
- package/dist/tests/merge-scoring.test.js +0 -136
- package/dist/tests/metadata.test.js +0 -313
- package/dist/tests/migration-help.test.js +0 -89
- package/dist/tests/origin-resolve.test.js +0 -124
- package/dist/tests/output-baseline.test.js +0 -218
- package/dist/tests/output-shapes-unit.test.js +0 -478
- package/dist/tests/parallel-search.test.js +0 -272
- package/dist/tests/parameter-metadata.test.js +0 -365
- package/dist/tests/paths.test.js +0 -177
- package/dist/tests/progressive-disclosure.test.js +0 -280
- package/dist/tests/proposals.test.js +0 -279
- package/dist/tests/proposed-quality.test.js +0 -271
- package/dist/tests/provider-registry.test.js +0 -32
- package/dist/tests/ranking-regression.test.js +0 -548
- package/dist/tests/reflect-propose.test.js +0 -455
- package/dist/tests/registry-build-index.test.js +0 -394
- package/dist/tests/registry-cli.test.js +0 -290
- package/dist/tests/registry-index-v2.test.js +0 -430
- package/dist/tests/registry-install.test.js +0 -728
- package/dist/tests/registry-providers/parity.test.js +0 -189
- package/dist/tests/registry-providers/skills-sh.test.js +0 -309
- package/dist/tests/registry-providers/static-index.test.js +0 -238
- package/dist/tests/registry-resolve.test.js +0 -126
- package/dist/tests/registry-search.test.js +0 -923
- package/dist/tests/remember-frontmatter.test.js +0 -378
- package/dist/tests/remember-unit.test.js +0 -123
- package/dist/tests/ripgrep-install.test.js +0 -251
- package/dist/tests/ripgrep-resolve.test.js +0 -108
- package/dist/tests/ripgrep.test.js +0 -163
- package/dist/tests/save-command.test.js +0 -94
- package/dist/tests/save-trust-qa-fixes.test.js +0 -270
- package/dist/tests/scoring-pipeline.test.js +0 -648
- package/dist/tests/search-include-proposed-cli.test.js +0 -118
- package/dist/tests/self-update.test.js +0 -442
- package/dist/tests/semantic-search-e2e.test.js +0 -512
- package/dist/tests/semantic-status.test.js +0 -471
- package/dist/tests/setup-run.integration.js +0 -877
- package/dist/tests/setup-wizard.test.js +0 -198
- package/dist/tests/setup.test.js +0 -131
- package/dist/tests/source-add.test.js +0 -11
- package/dist/tests/source-clone.test.js +0 -254
- package/dist/tests/source-manage.test.js +0 -366
- package/dist/tests/source-providers/filesystem.test.js +0 -82
- package/dist/tests/source-providers/git.test.js +0 -252
- package/dist/tests/source-providers/website.test.js +0 -128
- package/dist/tests/source-qa-fixes.test.js +0 -286
- package/dist/tests/source-registry.test.js +0 -350
- package/dist/tests/source-resolve.test.js +0 -100
- package/dist/tests/source-source.test.js +0 -281
- package/dist/tests/source.test.js +0 -533
- package/dist/tests/tar-utils-scan.test.js +0 -73
- package/dist/tests/toggle-components.test.js +0 -73
- package/dist/tests/usage-telemetry.test.js +0 -265
- package/dist/tests/utility-scoring.test.js +0 -558
- package/dist/tests/vault-load-error.test.js +0 -78
- package/dist/tests/vault-qa-fixes.test.js +0 -194
- package/dist/tests/vault.test.js +0 -429
- package/dist/tests/vector-search.test.js +0 -608
- package/dist/tests/walker.test.js +0 -252
- package/dist/tests/wave2-cluster-bc.test.js +0 -228
- package/dist/tests/wave2-cluster-d.test.js +0 -180
- package/dist/tests/wave2-cluster-e.test.js +0 -179
- package/dist/tests/wiki-qa-fixes.test.js +0 -270
- package/dist/tests/wiki.test.js +0 -529
- package/dist/tests/workflow-cli.test.js +0 -271
- package/dist/tests/workflow-markdown.test.js +0 -171
- package/dist/tests/workflow-path-escape.test.js +0 -132
- package/dist/tests/workflow-qa-fixes.test.js +0 -395
- package/dist/tests/workflows/indexer-rejection.test.js +0 -213
- /package/dist/{src/cli.js → cli.js} +0 -0
- /package/dist/{src/commands → commands}/completions.js +0 -0
- /package/dist/{src/commands → commands}/config-cli.js +0 -0
- /package/dist/{src/commands → commands}/curate.js +0 -0
- /package/dist/{src/commands → commands}/distill.js +0 -0
- /package/dist/{src/commands → commands}/events.js +0 -0
- /package/dist/{src/commands → commands}/history.js +0 -0
- /package/dist/{src/commands → commands}/info.js +0 -0
- /package/dist/{src/commands → commands}/init.js +0 -0
- /package/dist/{src/commands → commands}/install-audit.js +0 -0
- /package/dist/{src/commands → commands}/installed-stashes.js +0 -0
- /package/dist/{src/commands → commands}/migration-help.js +0 -0
- /package/dist/{src/commands → commands}/proposal.js +0 -0
- /package/dist/{src/commands → commands}/propose.js +0 -0
- /package/dist/{src/commands → commands}/reflect.js +0 -0
- /package/dist/{src/commands → commands}/registry-search.js +0 -0
- /package/dist/{src/commands → commands}/remember.js +0 -0
- /package/dist/{src/commands → commands}/search.js +0 -0
- /package/dist/{src/commands → commands}/self-update.js +0 -0
- /package/dist/{src/commands → commands}/show.js +0 -0
- /package/dist/{src/commands → commands}/source-add.js +0 -0
- /package/dist/{src/commands → commands}/source-clone.js +0 -0
- /package/dist/{src/commands → commands}/source-manage.js +0 -0
- /package/dist/{src/commands → commands}/vault.js +0 -0
- /package/dist/{src/core → core}/asset-ref.js +0 -0
- /package/dist/{src/core → core}/asset-registry.js +0 -0
- /package/dist/{src/core → core}/asset-spec.js +0 -0
- /package/dist/{src/core → core}/common.js +0 -0
- /package/dist/{src/core → core}/config.js +0 -0
- /package/dist/{src/core → core}/errors.js +0 -0
- /package/dist/{src/core → core}/events.js +0 -0
- /package/dist/{src/core → core}/frontmatter.js +0 -0
- /package/dist/{src/core → core}/lesson-lint.js +0 -0
- /package/dist/{src/core → core}/markdown.js +0 -0
- /package/dist/{src/core → core}/paths.js +0 -0
- /package/dist/{src/core → core}/proposals.js +0 -0
- /package/dist/{src/core → core}/warn.js +0 -0
- /package/dist/{src/core → core}/write-source.js +0 -0
- /package/dist/{src/indexer → indexer}/db-search.js +0 -0
- /package/dist/{src/indexer → indexer}/db.js +0 -0
- /package/dist/{src/indexer → indexer}/file-context.js +0 -0
- /package/dist/{src/indexer → indexer}/graph-boost.js +0 -0
- /package/dist/{src/indexer → indexer}/graph-extraction.js +0 -0
- /package/dist/{src/indexer → indexer}/indexer.js +0 -0
- /package/dist/{src/indexer → indexer}/manifest.js +0 -0
- /package/dist/{src/indexer → indexer}/matchers.js +0 -0
- /package/dist/{src/indexer → indexer}/memory-inference.js +0 -0
- /package/dist/{src/indexer → indexer}/metadata.js +0 -0
- /package/dist/{src/indexer → indexer}/search-fields.js +0 -0
- /package/dist/{src/indexer → indexer}/search-source.js +0 -0
- /package/dist/{src/indexer → indexer}/semantic-status.js +0 -0
- /package/dist/{src/indexer → indexer}/usage-events.js +0 -0
- /package/dist/{src/indexer → indexer}/walker.js +0 -0
- /package/dist/{src/integrations → integrations}/agent/config.js +0 -0
- /package/dist/{src/integrations → integrations}/agent/detect.js +0 -0
- /package/dist/{src/integrations → integrations}/agent/index.js +0 -0
- /package/dist/{src/integrations → integrations}/agent/profiles.js +0 -0
- /package/dist/{src/integrations → integrations}/agent/prompts.js +0 -0
- /package/dist/{src/integrations → integrations}/agent/spawn.js +0 -0
- /package/dist/{src/integrations → integrations}/github.js +0 -0
- /package/dist/{src/integrations → integrations}/lockfile.js +0 -0
- /package/dist/{src/llm → llm}/client.js +0 -0
- /package/dist/{src/llm → llm}/embedder.js +0 -0
- /package/dist/{src/llm → llm}/embedders/cache.js +0 -0
- /package/dist/{src/llm → llm}/embedders/local.js +0 -0
- /package/dist/{src/llm → llm}/embedders/remote.js +0 -0
- /package/dist/{src/llm → llm}/embedders/types.js +0 -0
- /package/dist/{src/llm → llm}/feature-gate.js +0 -0
- /package/dist/{src/llm → llm}/graph-extract.js +0 -0
- /package/dist/{src/llm → llm}/index-passes.js +0 -0
- /package/dist/{src/llm → llm}/memory-infer.js +0 -0
- /package/dist/{src/llm → llm}/metadata-enhance.js +0 -0
- /package/dist/{src/output → output}/cli-hints.js +0 -0
- /package/dist/{src/output → output}/context.js +0 -0
- /package/dist/{src/output → output}/renderers.js +0 -0
- /package/dist/{src/output → output}/shapes.js +0 -0
- /package/dist/{src/output → output}/text.js +0 -0
- /package/dist/{src/registry → registry}/build-index.js +0 -0
- /package/dist/{src/registry → registry}/create-provider-registry.js +0 -0
- /package/dist/{src/registry → registry}/factory.js +0 -0
- /package/dist/{src/registry → registry}/origin-resolve.js +0 -0
- /package/dist/{src/registry → registry}/providers/index.js +0 -0
- /package/dist/{src/registry → registry}/providers/skills-sh.js +0 -0
- /package/dist/{src/registry → registry}/providers/static-index.js +0 -0
- /package/dist/{src/registry → registry}/providers/types.js +0 -0
- /package/dist/{src/registry → registry}/resolve.js +0 -0
- /package/dist/{src/registry → registry}/types.js +0 -0
- /package/dist/{src/setup → setup}/detect.js +0 -0
- /package/dist/{src/setup → setup}/ripgrep-install.js +0 -0
- /package/dist/{src/setup → setup}/ripgrep-resolve.js +0 -0
- /package/dist/{src/setup → setup}/setup.js +0 -0
- /package/dist/{src/setup → setup}/steps.js +0 -0
- /package/dist/{src/sources → sources}/include.js +0 -0
- /package/dist/{src/sources → sources}/provider-factory.js +0 -0
- /package/dist/{src/sources → sources}/provider.js +0 -0
- /package/dist/{src/sources → sources}/providers/filesystem.js +0 -0
- /package/dist/{src/sources → sources}/providers/git.js +0 -0
- /package/dist/{src/sources → sources}/providers/index.js +0 -0
- /package/dist/{src/sources → sources}/providers/install-types.js +0 -0
- /package/dist/{src/sources → sources}/providers/npm.js +0 -0
- /package/dist/{src/sources → sources}/providers/provider-utils.js +0 -0
- /package/dist/{src/sources → sources}/providers/sync-from-ref.js +0 -0
- /package/dist/{src/sources → sources}/providers/tar-utils.js +0 -0
- /package/dist/{src/sources → sources}/providers/website.js +0 -0
- /package/dist/{src/sources → sources}/resolve.js +0 -0
- /package/dist/{src/sources → sources}/types.js +0 -0
- /package/dist/{src/templates → templates}/wiki-templates.js +0 -0
- /package/dist/{src/version.js → version.js} +0 -0
- /package/dist/{src/wiki → wiki}/wiki.js +0 -0
- /package/dist/{src/workflows → workflows}/authoring.js +0 -0
- /package/dist/{src/workflows → workflows}/cli.js +0 -0
- /package/dist/{src/workflows → workflows}/db.js +0 -0
- /package/dist/{src/workflows → workflows}/document-cache.js +0 -0
- /package/dist/{src/workflows → workflows}/parser.js +0 -0
- /package/dist/{src/workflows → workflows}/renderer.js +0 -0
- /package/dist/{src/workflows → workflows}/runs.js +0 -0
- /package/dist/{src/workflows → workflows}/schema.js +0 -0
- /package/dist/{src/workflows → workflows}/validator.js +0 -0
|
@@ -1,112 +0,0 @@
|
|
|
1
|
-
import { afterEach, describe, expect, test } from "bun:test";
|
|
2
|
-
import { spawnSync } from "node:child_process";
|
|
3
|
-
import fs from "node:fs";
|
|
4
|
-
import os from "node:os";
|
|
5
|
-
import path from "node:path";
|
|
6
|
-
const CLI = path.join(__dirname, "..", "src", "cli.ts");
|
|
7
|
-
const tempDirs = [];
|
|
8
|
-
function makeTempDir(prefix) {
|
|
9
|
-
const dir = fs.mkdtempSync(path.join(os.tmpdir(), prefix));
|
|
10
|
-
tempDirs.push(dir);
|
|
11
|
-
return dir;
|
|
12
|
-
}
|
|
13
|
-
function runCli(args, options) {
|
|
14
|
-
const stashDir = options?.stashDir ?? makeTempDir("akm-capture-stash-");
|
|
15
|
-
const xdgCache = makeTempDir("akm-capture-cache-");
|
|
16
|
-
const xdgConfig = makeTempDir("akm-capture-config-");
|
|
17
|
-
const result = spawnSync("bun", [CLI, ...args], {
|
|
18
|
-
encoding: "utf8",
|
|
19
|
-
timeout: 30_000,
|
|
20
|
-
input: options?.input,
|
|
21
|
-
env: {
|
|
22
|
-
...process.env,
|
|
23
|
-
AKM_STASH_DIR: stashDir,
|
|
24
|
-
XDG_CACHE_HOME: xdgCache,
|
|
25
|
-
XDG_CONFIG_HOME: xdgConfig,
|
|
26
|
-
...options?.env,
|
|
27
|
-
},
|
|
28
|
-
});
|
|
29
|
-
return { stashDir, result };
|
|
30
|
-
}
|
|
31
|
-
afterEach(() => {
|
|
32
|
-
for (const dir of tempDirs.splice(0)) {
|
|
33
|
-
fs.rmSync(dir, { recursive: true, force: true });
|
|
34
|
-
}
|
|
35
|
-
});
|
|
36
|
-
describe("capture commands", () => {
|
|
37
|
-
function expectInitFlagUsesCustomDir(flag) {
|
|
38
|
-
const parentDir = makeTempDir("akm-init-parent-");
|
|
39
|
-
const customDir = path.join(parentDir, "custom-stash");
|
|
40
|
-
const homeDir = makeTempDir("akm-init-home-");
|
|
41
|
-
const { result } = runCli(["init", flag, customDir], { env: { HOME: homeDir } });
|
|
42
|
-
expect(result.status).toBe(0);
|
|
43
|
-
const json = JSON.parse(result.stdout);
|
|
44
|
-
expect(json.created).toBe(true);
|
|
45
|
-
expect(json.stashDir).toBe(path.resolve(customDir));
|
|
46
|
-
expect(fs.existsSync(path.join(customDir, "knowledge"))).toBe(true);
|
|
47
|
-
expect(fs.existsSync(path.join(homeDir, "akm"))).toBe(false);
|
|
48
|
-
const config = JSON.parse(fs.readFileSync(json.configPath, "utf8"));
|
|
49
|
-
expect(config.stashDir).toBe(path.resolve(customDir));
|
|
50
|
-
}
|
|
51
|
-
test("init honors --dir for a custom stash path", () => {
|
|
52
|
-
expectInitFlagUsesCustomDir("--dir");
|
|
53
|
-
});
|
|
54
|
-
test("init honors legacy --stashDir as an alias for --dir", () => {
|
|
55
|
-
expectInitFlagUsesCustomDir("--stashDir");
|
|
56
|
-
});
|
|
57
|
-
test("remember stores a memory in the stash and returns its ref", () => {
|
|
58
|
-
const { stashDir, result } = runCli(["remember", "Deployment needs VPN access"]);
|
|
59
|
-
expect(result.status).toBe(0);
|
|
60
|
-
const json = JSON.parse(result.stdout);
|
|
61
|
-
expect(json.ok).toBe(true);
|
|
62
|
-
expect(json.ref).toBe("memory:deployment-needs-vpn-access");
|
|
63
|
-
expect(fs.existsSync(path.join(stashDir, "memories", "deployment-needs-vpn-access.md"))).toBe(true);
|
|
64
|
-
const show = runCli(["show", json.ref], { stashDir }).result;
|
|
65
|
-
expect(show.status).toBe(0);
|
|
66
|
-
expect(show.stdout).toContain("Deployment needs VPN access");
|
|
67
|
-
});
|
|
68
|
-
test("remember prints a helpful error when no content is provided", () => {
|
|
69
|
-
const { result } = runCli(["remember"]);
|
|
70
|
-
expect(result.status).toBe(2);
|
|
71
|
-
const json = JSON.parse(result.stderr);
|
|
72
|
-
expect(json.error).toContain("Memory content is required");
|
|
73
|
-
});
|
|
74
|
-
test("remember rejects names with parent-directory traversal", () => {
|
|
75
|
-
const { result } = runCli(["remember", "Sensitive note", "--name", "../../etc/passwd"]);
|
|
76
|
-
expect(result.status).toBe(2);
|
|
77
|
-
const json = JSON.parse(result.stderr);
|
|
78
|
-
expect(json.error).toContain("relative path without '.' or '..' segments");
|
|
79
|
-
});
|
|
80
|
-
test("import stores a knowledge document using the source filename by default", () => {
|
|
81
|
-
const sourceDir = makeTempDir("akm-capture-source-");
|
|
82
|
-
const sourcePath = path.join(sourceDir, "release-notes.md");
|
|
83
|
-
fs.writeFileSync(sourcePath, "# Release Notes\n\nShip it.\n", "utf8");
|
|
84
|
-
const { stashDir, result } = runCli(["import", sourcePath]);
|
|
85
|
-
expect(result.status).toBe(0);
|
|
86
|
-
const json = JSON.parse(result.stdout);
|
|
87
|
-
expect(json.ok).toBe(true);
|
|
88
|
-
expect(json.ref).toBe("knowledge:release-notes");
|
|
89
|
-
expect(fs.existsSync(path.join(stashDir, "knowledge", "release-notes.md"))).toBe(true);
|
|
90
|
-
const show = runCli(["show", json.ref], { stashDir }).result;
|
|
91
|
-
expect(show.status).toBe(0);
|
|
92
|
-
expect(show.stdout).toContain("# Release Notes");
|
|
93
|
-
});
|
|
94
|
-
test("import accepts stdin when source is '-'", () => {
|
|
95
|
-
const { stashDir, result } = runCli(["import", "-", "--name", "scratch-notes"], {
|
|
96
|
-
input: "# Scratch Notes\n\nRemember the rollout freeze.\n",
|
|
97
|
-
});
|
|
98
|
-
expect(result.status).toBe(0);
|
|
99
|
-
const json = JSON.parse(result.stdout);
|
|
100
|
-
expect(json.ref).toBe("knowledge:scratch-notes");
|
|
101
|
-
expect(fs.existsSync(path.join(stashDir, "knowledge", "scratch-notes.md"))).toBe(true);
|
|
102
|
-
});
|
|
103
|
-
test("import rejects an empty normalized knowledge name", () => {
|
|
104
|
-
const sourceDir = makeTempDir("akm-capture-source-");
|
|
105
|
-
const sourcePath = path.join(sourceDir, "notes.md");
|
|
106
|
-
fs.writeFileSync(sourcePath, "# Notes\n", "utf8");
|
|
107
|
-
const { result } = runCli(["import", sourcePath, "--name", ".md"]);
|
|
108
|
-
expect(result.status).toBe(2);
|
|
109
|
-
const json = JSON.parse(result.stderr);
|
|
110
|
-
expect(json.error).toContain("Asset name cannot be empty");
|
|
111
|
-
});
|
|
112
|
-
});
|
|
@@ -1,204 +0,0 @@
|
|
|
1
|
-
import { afterAll, describe, expect, test } from "bun:test";
|
|
2
|
-
import { spawnSync } from "node:child_process";
|
|
3
|
-
import fs from "node:fs";
|
|
4
|
-
import os from "node:os";
|
|
5
|
-
import path from "node:path";
|
|
6
|
-
import { ConfigError, NotFoundError, UsageError } from "../src/core/errors";
|
|
7
|
-
// ── Helpers ─────────────────────────────────────────────────────────────────
|
|
8
|
-
const tempDirs = [];
|
|
9
|
-
function makeTempDir() {
|
|
10
|
-
const dir = fs.mkdtempSync(path.join(os.tmpdir(), "akm-cli-err-"));
|
|
11
|
-
tempDirs.push(dir);
|
|
12
|
-
return dir;
|
|
13
|
-
}
|
|
14
|
-
afterAll(() => {
|
|
15
|
-
for (const dir of tempDirs) {
|
|
16
|
-
fs.rmSync(dir, { recursive: true, force: true });
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
/** Isolated temp dirs so the CLI never touches real user config/cache/home. */
|
|
20
|
-
const xdgCache = makeTempDir();
|
|
21
|
-
const xdgConfig = makeTempDir();
|
|
22
|
-
const isolatedHome = makeTempDir();
|
|
23
|
-
const repoRoot = path.resolve(import.meta.dir, "..");
|
|
24
|
-
const cliPath = path.join(repoRoot, "src", "cli.ts");
|
|
25
|
-
function runCliWithOptions(args, options) {
|
|
26
|
-
const result = spawnSync("bun", [cliPath, ...args], {
|
|
27
|
-
encoding: "utf8",
|
|
28
|
-
timeout: 10_000,
|
|
29
|
-
cwd: options?.cwd ?? repoRoot,
|
|
30
|
-
env: {
|
|
31
|
-
...process.env,
|
|
32
|
-
AKM_STASH_DIR: undefined,
|
|
33
|
-
HOME: isolatedHome,
|
|
34
|
-
XDG_CACHE_HOME: xdgCache,
|
|
35
|
-
XDG_CONFIG_HOME: xdgConfig,
|
|
36
|
-
...options?.env,
|
|
37
|
-
},
|
|
38
|
-
});
|
|
39
|
-
return {
|
|
40
|
-
stdout: result.stdout ?? "",
|
|
41
|
-
stderr: result.stderr ?? "",
|
|
42
|
-
status: result.status ?? 1,
|
|
43
|
-
};
|
|
44
|
-
}
|
|
45
|
-
function runCli(...args) {
|
|
46
|
-
return runCliWithOptions(args);
|
|
47
|
-
}
|
|
48
|
-
// ── Tests ───────────────────────────────────────────────────────────────────
|
|
49
|
-
describe("CLI error handling", () => {
|
|
50
|
-
test("search without stash dir prints JSON error with hint", () => {
|
|
51
|
-
const { stderr, status } = runCli("search", "test");
|
|
52
|
-
expect(status).not.toBe(0);
|
|
53
|
-
expect(stderr).toContain("No stash directory found");
|
|
54
|
-
expect(stderr).toContain("hint");
|
|
55
|
-
});
|
|
56
|
-
test("show with invalid ref prints JSON error", () => {
|
|
57
|
-
const { stderr, status } = runCli("show", "invalid-ref-no-colon");
|
|
58
|
-
expect(status).not.toBe(0);
|
|
59
|
-
const parsed = JSON.parse(stderr.trim());
|
|
60
|
-
expect(parsed.ok).toBe(false);
|
|
61
|
-
expect(typeof parsed.error).toBe("string");
|
|
62
|
-
expect(parsed.code).toBe("INVALID_FLAG_VALUE");
|
|
63
|
-
});
|
|
64
|
-
test("search --source invalid prints hint about source", () => {
|
|
65
|
-
const { stderr, status } = runCli("search", "test", "--source", "invalid");
|
|
66
|
-
expect(status).not.toBe(0);
|
|
67
|
-
expect(stderr).toContain("Invalid value for --source");
|
|
68
|
-
expect(stderr).toContain("hint");
|
|
69
|
-
});
|
|
70
|
-
test("search --detail invalid prints hint about detail", () => {
|
|
71
|
-
const stashDir = makeTempDir();
|
|
72
|
-
for (const sub of ["scripts", "skills", "commands", "agents", "knowledge"]) {
|
|
73
|
-
fs.mkdirSync(path.join(stashDir, sub), { recursive: true });
|
|
74
|
-
}
|
|
75
|
-
const result = spawnSync("bun", ["./src/cli.ts", "search", "test", "--detail", "invalid"], {
|
|
76
|
-
encoding: "utf8",
|
|
77
|
-
timeout: 10_000,
|
|
78
|
-
cwd: path.resolve(import.meta.dir, ".."),
|
|
79
|
-
env: {
|
|
80
|
-
...process.env,
|
|
81
|
-
AKM_STASH_DIR: stashDir,
|
|
82
|
-
HOME: isolatedHome,
|
|
83
|
-
XDG_CACHE_HOME: xdgCache,
|
|
84
|
-
XDG_CONFIG_HOME: xdgConfig,
|
|
85
|
-
},
|
|
86
|
-
});
|
|
87
|
-
const stderr = result.stderr ?? "";
|
|
88
|
-
const status = result.status ?? 1;
|
|
89
|
-
expect(status).not.toBe(0);
|
|
90
|
-
expect(stderr).toContain("Invalid value for --detail");
|
|
91
|
-
expect(stderr).toContain("hint");
|
|
92
|
-
});
|
|
93
|
-
test("error output is valid JSON", () => {
|
|
94
|
-
const { stderr } = runCli("show", "invalid-ref-no-colon");
|
|
95
|
-
const trimmed = stderr.trim();
|
|
96
|
-
const parsed = JSON.parse(trimmed);
|
|
97
|
-
expect(parsed.ok).toBe(false);
|
|
98
|
-
expect(typeof parsed.error).toBe("string");
|
|
99
|
-
});
|
|
100
|
-
test("config set with invalid JSON prints hint about quoting", () => {
|
|
101
|
-
const { stderr, status } = runCli("config", "set", "embedding", "not-valid-json");
|
|
102
|
-
expect(status).not.toBe(0);
|
|
103
|
-
const parsed = JSON.parse(stderr.trim());
|
|
104
|
-
expect(parsed.ok).toBe(false);
|
|
105
|
-
expect(parsed.hint).toContain("Quote JSON values");
|
|
106
|
-
});
|
|
107
|
-
test("CLI hint comes from the error instance, not a regex over the message", () => {
|
|
108
|
-
// Reproduces the failure path: search without a stash dir throws ConfigError
|
|
109
|
-
// with code STASH_DIR_NOT_FOUND. The CLI surfaces error.hint(), not a regex
|
|
110
|
-
// against the message string.
|
|
111
|
-
const { stderr, status } = runCli("search", "test");
|
|
112
|
-
expect(status).not.toBe(0);
|
|
113
|
-
const parsed = JSON.parse(stderr.trim());
|
|
114
|
-
expect(parsed.ok).toBe(false);
|
|
115
|
-
expect(parsed.code).toBe("STASH_DIR_NOT_FOUND");
|
|
116
|
-
expect(parsed.hint).toBe(new ConfigError("x", "STASH_DIR_NOT_FOUND").hint());
|
|
117
|
-
expect(parsed.hint).toContain("akm init");
|
|
118
|
-
});
|
|
119
|
-
});
|
|
120
|
-
describe("error class hints", () => {
|
|
121
|
-
test("ConfigError derives hint from code by default", () => {
|
|
122
|
-
expect(new ConfigError("missing stash", "STASH_DIR_NOT_FOUND").hint()).toContain("akm init");
|
|
123
|
-
expect(new ConfigError("not a dir", "STASH_DIR_NOT_A_DIRECTORY").hint()).toContain("directory");
|
|
124
|
-
expect(new ConfigError("unreadable", "STASH_DIR_UNREADABLE").hint()).toContain("permission");
|
|
125
|
-
expect(new ConfigError("no embedding", "EMBEDDING_NOT_CONFIGURED").hint()).toContain("akm config set embedding");
|
|
126
|
-
expect(new ConfigError("no llm", "LLM_NOT_CONFIGURED").hint()).toContain("akm config set llm");
|
|
127
|
-
});
|
|
128
|
-
test("ConfigError without a code-mapped hint returns undefined", () => {
|
|
129
|
-
expect(new ConfigError("bad config", "INVALID_CONFIG_FILE").hint()).toBeUndefined();
|
|
130
|
-
expect(new ConfigError("can't resolve", "CONFIG_DIR_UNRESOLVABLE").hint()).toBeUndefined();
|
|
131
|
-
});
|
|
132
|
-
test("UsageError derives hint from code by default", () => {
|
|
133
|
-
expect(new UsageError("bad source", "INVALID_SOURCE_VALUE").hint()).toBe("Pick one of: stash, registry, both.");
|
|
134
|
-
expect(new UsageError("bad format", "INVALID_FORMAT_VALUE").hint()).toBe("Pick one of: json, jsonl, text, yaml.");
|
|
135
|
-
expect(new UsageError("bad detail", "INVALID_DETAIL_VALUE").hint()).toBe("Pick one of: brief, normal, full, summary, agent.");
|
|
136
|
-
expect(new UsageError("bad json", "INVALID_JSON_CONFIG_VALUE").hint()).toContain("Quote JSON values");
|
|
137
|
-
expect(new UsageError("bad target", "MISSING_OR_AMBIGUOUS_TARGET").hint()).toContain("akm update --all");
|
|
138
|
-
expect(new UsageError("not updatable", "TARGET_NOT_UPDATABLE").hint()).toContain("akm list");
|
|
139
|
-
});
|
|
140
|
-
test("UsageError without a code-mapped hint returns undefined", () => {
|
|
141
|
-
// INVALID_FLAG_VALUE is intentionally a generic fallback — points at --help.
|
|
142
|
-
expect(new UsageError("bad flag", "INVALID_FLAG_VALUE").hint()).toContain("akm <command> --help");
|
|
143
|
-
expect(new UsageError("unknown key", "UNKNOWN_CONFIG_KEY").hint()).toBeUndefined();
|
|
144
|
-
expect(new UsageError("bad json arg", "INVALID_JSON_ARGUMENT").hint()).toBeUndefined();
|
|
145
|
-
});
|
|
146
|
-
test("NotFoundError derives hint from code by default", () => {
|
|
147
|
-
// Wave C #284 added canned hints for the remaining codes.
|
|
148
|
-
expect(new NotFoundError("missing source", "SOURCE_NOT_FOUND").hint()).toContain("akm list");
|
|
149
|
-
expect(new NotFoundError("missing asset", "ASSET_NOT_FOUND").hint()).toContain("akm search");
|
|
150
|
-
expect(new NotFoundError("missing wf", "WORKFLOW_NOT_FOUND").hint()).toContain("akm workflow list");
|
|
151
|
-
expect(new NotFoundError("missing file", "FILE_NOT_FOUND").hint()).toContain("path exists");
|
|
152
|
-
});
|
|
153
|
-
test("explicit hint at construction overrides the code-derived default", () => {
|
|
154
|
-
const explicit = new UsageError("oops", "INVALID_FLAG_VALUE", "do this instead");
|
|
155
|
-
expect(explicit.hint()).toBe("do this instead");
|
|
156
|
-
const overrideMapped = new UsageError("oops", "INVALID_SOURCE_VALUE", "custom");
|
|
157
|
-
expect(overrideMapped.hint()).toBe("custom");
|
|
158
|
-
const cfg = new ConfigError("oops", "STASH_DIR_NOT_FOUND", "custom config hint");
|
|
159
|
-
expect(cfg.hint()).toBe("custom config hint");
|
|
160
|
-
const nf = new NotFoundError("oops", "ASSET_NOT_FOUND", "find it here");
|
|
161
|
-
expect(nf.hint()).toBe("find it here");
|
|
162
|
-
});
|
|
163
|
-
});
|
|
164
|
-
describe("config path subcommand", () => {
|
|
165
|
-
test("config path prints the config file path", () => {
|
|
166
|
-
const { stdout, status } = runCli("config", "path");
|
|
167
|
-
expect(status).toBe(0);
|
|
168
|
-
expect(stdout.trim()).toContain("config.json");
|
|
169
|
-
});
|
|
170
|
-
test("config path --all returns all path keys", () => {
|
|
171
|
-
const { stdout, status } = runCli("config", "path", "--all", "--format=json");
|
|
172
|
-
expect(status).toBe(0);
|
|
173
|
-
const parsed = JSON.parse(stdout.trim());
|
|
174
|
-
expect(parsed).toHaveProperty("config");
|
|
175
|
-
expect(parsed).toHaveProperty("stash");
|
|
176
|
-
expect(parsed).toHaveProperty("cache");
|
|
177
|
-
expect(parsed).toHaveProperty("index");
|
|
178
|
-
});
|
|
179
|
-
});
|
|
180
|
-
describe("registry remove", () => {
|
|
181
|
-
test("does not persist project registries into user config", () => {
|
|
182
|
-
const projectDir = makeTempDir();
|
|
183
|
-
const userConfigPath = path.join(xdgConfig, "akm", "config.json");
|
|
184
|
-
const projectConfigPath = path.join(projectDir, ".akm", "config.json");
|
|
185
|
-
fs.mkdirSync(path.dirname(userConfigPath), { recursive: true });
|
|
186
|
-
fs.writeFileSync(userConfigPath, `${JSON.stringify({
|
|
187
|
-
registries: [{ url: "https://user.example/index.json", name: "user" }],
|
|
188
|
-
}, null, 2)}\n`);
|
|
189
|
-
fs.mkdirSync(path.dirname(projectConfigPath), { recursive: true });
|
|
190
|
-
fs.writeFileSync(projectConfigPath, `${JSON.stringify({
|
|
191
|
-
registries: [{ url: "https://project.example/index.json", name: "project" }],
|
|
192
|
-
}, null, 2)}\n`);
|
|
193
|
-
const { status } = runCliWithOptions(["registry", "remove", "user", "--format=json"], {
|
|
194
|
-
cwd: projectDir,
|
|
195
|
-
});
|
|
196
|
-
expect(status).toBe(0);
|
|
197
|
-
const savedUserConfig = JSON.parse(fs.readFileSync(userConfigPath, "utf8"));
|
|
198
|
-
expect(savedUserConfig.registries).toEqual([]);
|
|
199
|
-
expect(savedUserConfig.registries).not.toContainEqual({
|
|
200
|
-
url: "https://project.example/index.json",
|
|
201
|
-
name: "project",
|
|
202
|
-
});
|
|
203
|
-
});
|
|
204
|
-
});
|