cognitive-core 0.2.0 → 0.2.2
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/.claude/settings.json +111 -2
- package/.sessionlog/settings.json +4 -0
- package/dist/atlas.d.ts +10 -0
- package/dist/atlas.d.ts.map +1 -1
- package/dist/atlas.js +65 -0
- package/dist/atlas.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -1
- package/dist/index.js.map +1 -1
- package/dist/learning/index.d.ts +1 -1
- package/dist/learning/index.d.ts.map +1 -1
- package/dist/learning/index.js.map +1 -1
- package/dist/learning/pipeline.d.ts +4 -31
- package/dist/learning/pipeline.d.ts.map +1 -1
- package/dist/learning/pipeline.js +12 -64
- package/dist/learning/pipeline.js.map +1 -1
- package/dist/learning/unified-pipeline.d.ts +30 -0
- package/dist/learning/unified-pipeline.d.ts.map +1 -1
- package/dist/learning/unified-pipeline.js +207 -0
- package/dist/learning/unified-pipeline.js.map +1 -1
- package/dist/memory/candidate-retrieval.d.ts.map +1 -1
- package/dist/memory/candidate-retrieval.js +3 -1
- package/dist/memory/candidate-retrieval.js.map +1 -1
- package/dist/memory/curated-loader.d.ts +21 -4
- package/dist/memory/curated-loader.d.ts.map +1 -1
- package/dist/memory/curated-loader.js +53 -16
- package/dist/memory/curated-loader.js.map +1 -1
- package/dist/memory/index.d.ts +2 -1
- package/dist/memory/index.d.ts.map +1 -1
- package/dist/memory/index.js +3 -1
- package/dist/memory/index.js.map +1 -1
- package/dist/memory/playbook.d.ts +6 -0
- package/dist/memory/playbook.d.ts.map +1 -1
- package/dist/memory/playbook.js +15 -0
- package/dist/memory/playbook.js.map +1 -1
- package/dist/memory/source-resolver.d.ts +120 -0
- package/dist/memory/source-resolver.d.ts.map +1 -0
- package/dist/memory/source-resolver.js +300 -0
- package/dist/memory/source-resolver.js.map +1 -0
- package/dist/types/config.d.ts +141 -0
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js +40 -0
- package/dist/types/config.js.map +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/utils/error-classifier.js +8 -8
- package/dist/utils/error-classifier.js.map +1 -1
- package/dist/workspace/efficacy-toolkit.d.ts +164 -0
- package/dist/workspace/efficacy-toolkit.d.ts.map +1 -0
- package/dist/workspace/efficacy-toolkit.js +281 -0
- package/dist/workspace/efficacy-toolkit.js.map +1 -0
- package/dist/workspace/index.d.ts +2 -1
- package/dist/workspace/index.d.ts.map +1 -1
- package/dist/workspace/index.js +3 -1
- package/dist/workspace/index.js.map +1 -1
- package/dist/workspace/templates/index.d.ts +3 -0
- package/dist/workspace/templates/index.d.ts.map +1 -1
- package/dist/workspace/templates/index.js +6 -0
- package/dist/workspace/templates/index.js.map +1 -1
- package/dist/workspace/templates/playbook-decay-detection.d.ts +46 -0
- package/dist/workspace/templates/playbook-decay-detection.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-decay-detection.js +197 -0
- package/dist/workspace/templates/playbook-decay-detection.js.map +1 -0
- package/dist/workspace/templates/playbook-efficacy-audit.d.ts +46 -0
- package/dist/workspace/templates/playbook-efficacy-audit.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-efficacy-audit.js +160 -0
- package/dist/workspace/templates/playbook-efficacy-audit.js.map +1 -0
- package/dist/workspace/templates/playbook-lifecycle-review.d.ts +51 -0
- package/dist/workspace/templates/playbook-lifecycle-review.d.ts.map +1 -0
- package/dist/workspace/templates/playbook-lifecycle-review.js +187 -0
- package/dist/workspace/templates/playbook-lifecycle-review.js.map +1 -0
- package/dist/workspace/types.d.ts +12 -54
- package/dist/workspace/types.d.ts.map +1 -1
- package/dist/workspace/types.js.map +1 -1
- package/package.json +8 -2
- package/playbooks/compound-engineering/adversarial-review.json +51 -0
- package/playbooks/compound-engineering/agent-native-architecture.json +59 -0
- package/playbooks/compound-engineering/agent-native-review.json +54 -0
- package/playbooks/compound-engineering/api-contract-review.json +52 -0
- package/playbooks/compound-engineering/brainstorm-requirements.json +55 -0
- package/playbooks/compound-engineering/bug-reproduction.json +62 -0
- package/playbooks/compound-engineering/confidence-calibration.json +49 -0
- package/playbooks/compound-engineering/correctness-review.json +49 -0
- package/playbooks/compound-engineering/data-migration-safety.json +59 -0
- package/playbooks/compound-engineering/deployment-verification.json +63 -0
- package/playbooks/compound-engineering/error-recovery-patterns.json +53 -0
- package/playbooks/compound-engineering/implementation-planning.json +64 -0
- package/playbooks/compound-engineering/issue-pattern-analysis.json +53 -0
- package/playbooks/compound-engineering/knowledge-compounding.json +63 -0
- package/playbooks/compound-engineering/learnings-research.json +54 -0
- package/playbooks/compound-engineering/maintainability-review.json +49 -0
- package/playbooks/compound-engineering/performance-review.json +54 -0
- package/playbooks/compound-engineering/plan-adversarial-review.json +56 -0
- package/playbooks/compound-engineering/plan-feasibility-review.json +56 -0
- package/playbooks/compound-engineering/project-standards-review.json +52 -0
- package/playbooks/compound-engineering/reliability-review.json +53 -0
- package/playbooks/compound-engineering/review-orchestration.json +64 -0
- package/playbooks/compound-engineering/security-review.json +54 -0
- package/playbooks/compound-engineering/systematic-execution.json +64 -0
- package/playbooks/compound-engineering/testing-review.json +50 -0
- package/src/atlas.ts +96 -0
- package/src/index.ts +27 -0
- package/src/learning/index.ts +1 -0
- package/src/learning/unified-pipeline.ts +271 -1
- package/src/memory/candidate-retrieval.ts +2 -1
- package/src/memory/curated-loader.ts +69 -16
- package/src/memory/index.ts +16 -0
- package/src/memory/playbook.ts +19 -0
- package/src/memory/source-resolver.ts +422 -0
- package/src/types/config.ts +46 -0
- package/src/types/index.ts +4 -0
- package/src/utils/error-classifier.ts +8 -8
- package/src/workspace/efficacy-toolkit.ts +496 -0
- package/src/workspace/index.ts +29 -0
- package/src/workspace/templates/index.ts +24 -0
- package/src/workspace/templates/playbook-decay-detection.ts +272 -0
- package/src/workspace/templates/playbook-efficacy-audit.ts +246 -0
- package/src/workspace/templates/playbook-lifecycle-review.ts +274 -0
- package/src/workspace/types.ts +22 -78
- package/tests/fixtures/behavioral-trajectories.ts +210 -0
- package/tests/integration/curated-sources-e2e.test.ts +502 -0
- package/tests/integration/pipeline-data-correctness.test.ts +794 -0
- package/tests/learning/meta-learner.test.ts +418 -0
- package/tests/learning/pipeline-memory-updates.test.ts +721 -0
- package/tests/learning/unified-pipeline-efficacy.test.ts +232 -0
- package/tests/memory/candidate-retrieval.test.ts +167 -0
- package/tests/memory/compound-engineering-seed.test.ts +338 -0
- package/tests/memory/curated-loader-extended.test.ts +225 -0
- package/tests/memory/meta.test.ts +399 -0
- package/tests/memory/playbook-quality-validation.test.ts +430 -0
- package/tests/memory/source-resolver.test.ts +700 -0
- package/tests/search/evaluator.test.ts +257 -0
- package/tests/search/verification-runner.test.ts +357 -0
- package/tests/utils/error-classifier.test.ts +149 -0
- package/tests/utils/trajectory-helpers.test.ts +163 -0
- package/tests/workspace/efficacy-toolkit.test.ts +404 -0
- package/tests/workspace/templates/playbook-efficacy.test.ts +377 -0
- package/.claude/settings.local.json +0 -11
- package/dist/learning/llm-extractor.d.ts +0 -88
- package/dist/learning/llm-extractor.d.ts.map +0 -1
- package/dist/learning/llm-extractor.js +0 -372
- package/dist/learning/llm-extractor.js.map +0 -1
- package/dist/learning/loop-coordinator.d.ts +0 -61
- package/dist/learning/loop-coordinator.d.ts.map +0 -1
- package/dist/learning/loop-coordinator.js +0 -96
- package/dist/learning/loop-coordinator.js.map +0 -1
- package/references/agent-workspace/CLAUDE.md +0 -74
- package/references/agent-workspace/README.md +0 -587
- package/references/agent-workspace/media/banner.png +0 -0
- package/references/agent-workspace/package-lock.json +0 -2061
- package/references/agent-workspace/package.json +0 -54
- package/references/agent-workspace/src/handle.ts +0 -122
- package/references/agent-workspace/src/index.ts +0 -32
- package/references/agent-workspace/src/manager.ts +0 -102
- package/references/agent-workspace/src/readers/json.ts +0 -71
- package/references/agent-workspace/src/readers/markdown.ts +0 -37
- package/references/agent-workspace/src/readers/raw.ts +0 -27
- package/references/agent-workspace/src/types.ts +0 -68
- package/references/agent-workspace/src/validation.ts +0 -93
- package/references/agent-workspace/src/writers/json.ts +0 -17
- package/references/agent-workspace/src/writers/markdown.ts +0 -27
- package/references/agent-workspace/src/writers/raw.ts +0 -22
- package/references/agent-workspace/tests/errors.test.ts +0 -652
- package/references/agent-workspace/tests/handle.test.ts +0 -144
- package/references/agent-workspace/tests/manager.test.ts +0 -124
- package/references/agent-workspace/tests/readers.test.ts +0 -205
- package/references/agent-workspace/tests/validation.test.ts +0 -196
- package/references/agent-workspace/tests/writers.test.ts +0 -108
- package/references/agent-workspace/tsconfig.json +0 -20
- package/references/agent-workspace/tsup.config.ts +0 -9
- package/references/minimem/.claude/settings.json +0 -7
- package/references/minimem/.sudocode/issues.jsonl +0 -18
- package/references/minimem/.sudocode/specs.jsonl +0 -1
- package/references/minimem/CLAUDE.md +0 -310
- package/references/minimem/README.md +0 -556
- package/references/minimem/claude-plugin/.claude-plugin/plugin.json +0 -10
- package/references/minimem/claude-plugin/.mcp.json +0 -7
- package/references/minimem/claude-plugin/README.md +0 -158
- package/references/minimem/claude-plugin/commands/recall.md +0 -47
- package/references/minimem/claude-plugin/commands/remember.md +0 -41
- package/references/minimem/claude-plugin/hooks/__tests__/hooks.test.ts +0 -272
- package/references/minimem/claude-plugin/hooks/hooks.json +0 -27
- package/references/minimem/claude-plugin/hooks/session-end.sh +0 -86
- package/references/minimem/claude-plugin/hooks/session-start.sh +0 -85
- package/references/minimem/claude-plugin/skills/memory/SKILL.md +0 -108
- package/references/minimem/package-lock.json +0 -5373
- package/references/minimem/package.json +0 -60
- package/references/minimem/scripts/postbuild.js +0 -35
- package/references/minimem/src/__tests__/edge-cases.test.ts +0 -371
- package/references/minimem/src/__tests__/errors.test.ts +0 -265
- package/references/minimem/src/__tests__/helpers.ts +0 -199
- package/references/minimem/src/__tests__/internal.test.ts +0 -407
- package/references/minimem/src/__tests__/knowledge.test.ts +0 -287
- package/references/minimem/src/__tests__/minimem.integration.test.ts +0 -1127
- package/references/minimem/src/__tests__/session.test.ts +0 -190
- package/references/minimem/src/cli/__tests__/commands.test.ts +0 -759
- package/references/minimem/src/cli/commands/__tests__/conflicts.test.ts +0 -141
- package/references/minimem/src/cli/commands/append.ts +0 -76
- package/references/minimem/src/cli/commands/config.ts +0 -262
- package/references/minimem/src/cli/commands/conflicts.ts +0 -413
- package/references/minimem/src/cli/commands/daemon.ts +0 -169
- package/references/minimem/src/cli/commands/index.ts +0 -12
- package/references/minimem/src/cli/commands/init.ts +0 -88
- package/references/minimem/src/cli/commands/mcp.ts +0 -177
- package/references/minimem/src/cli/commands/push-pull.ts +0 -213
- package/references/minimem/src/cli/commands/search.ts +0 -158
- package/references/minimem/src/cli/commands/status.ts +0 -84
- package/references/minimem/src/cli/commands/sync-init.ts +0 -290
- package/references/minimem/src/cli/commands/sync.ts +0 -70
- package/references/minimem/src/cli/commands/upsert.ts +0 -197
- package/references/minimem/src/cli/config.ts +0 -584
- package/references/minimem/src/cli/index.ts +0 -264
- package/references/minimem/src/cli/shared.ts +0 -161
- package/references/minimem/src/cli/sync/__tests__/central.test.ts +0 -152
- package/references/minimem/src/cli/sync/__tests__/conflicts.test.ts +0 -209
- package/references/minimem/src/cli/sync/__tests__/daemon.test.ts +0 -118
- package/references/minimem/src/cli/sync/__tests__/detection.test.ts +0 -207
- package/references/minimem/src/cli/sync/__tests__/integration.test.ts +0 -476
- package/references/minimem/src/cli/sync/__tests__/registry.test.ts +0 -363
- package/references/minimem/src/cli/sync/__tests__/state.test.ts +0 -255
- package/references/minimem/src/cli/sync/__tests__/validation.test.ts +0 -193
- package/references/minimem/src/cli/sync/__tests__/watcher.test.ts +0 -178
- package/references/minimem/src/cli/sync/central.ts +0 -292
- package/references/minimem/src/cli/sync/conflicts.ts +0 -204
- package/references/minimem/src/cli/sync/daemon.ts +0 -407
- package/references/minimem/src/cli/sync/detection.ts +0 -138
- package/references/minimem/src/cli/sync/index.ts +0 -107
- package/references/minimem/src/cli/sync/operations.ts +0 -373
- package/references/minimem/src/cli/sync/registry.ts +0 -279
- package/references/minimem/src/cli/sync/state.ts +0 -355
- package/references/minimem/src/cli/sync/validation.ts +0 -206
- package/references/minimem/src/cli/sync/watcher.ts +0 -234
- package/references/minimem/src/cli/version.ts +0 -34
- package/references/minimem/src/core/index.ts +0 -9
- package/references/minimem/src/core/indexer.ts +0 -628
- package/references/minimem/src/core/searcher.ts +0 -221
- package/references/minimem/src/db/schema.ts +0 -183
- package/references/minimem/src/db/sqlite-vec.ts +0 -24
- package/references/minimem/src/embeddings/__tests__/embeddings.test.ts +0 -431
- package/references/minimem/src/embeddings/batch-gemini.ts +0 -392
- package/references/minimem/src/embeddings/batch-openai.ts +0 -409
- package/references/minimem/src/embeddings/embeddings.ts +0 -434
- package/references/minimem/src/index.ts +0 -109
- package/references/minimem/src/internal.ts +0 -299
- package/references/minimem/src/minimem.ts +0 -1276
- package/references/minimem/src/search/__tests__/hybrid.test.ts +0 -247
- package/references/minimem/src/search/graph.ts +0 -234
- package/references/minimem/src/search/hybrid.ts +0 -151
- package/references/minimem/src/search/search.ts +0 -256
- package/references/minimem/src/server/__tests__/mcp.test.ts +0 -341
- package/references/minimem/src/server/__tests__/tools.test.ts +0 -364
- package/references/minimem/src/server/mcp.ts +0 -326
- package/references/minimem/src/server/tools.ts +0 -720
- package/references/minimem/src/session.ts +0 -460
- package/references/minimem/tsconfig.json +0 -19
- package/references/minimem/tsup.config.ts +0 -26
- package/references/minimem/vitest.config.ts +0 -24
- package/references/sessionlog/.husky/pre-commit +0 -1
- package/references/sessionlog/.lintstagedrc.json +0 -4
- package/references/sessionlog/.prettierignore +0 -4
- package/references/sessionlog/.prettierrc.json +0 -11
- package/references/sessionlog/LICENSE +0 -21
- package/references/sessionlog/README.md +0 -453
- package/references/sessionlog/eslint.config.js +0 -58
- package/references/sessionlog/package-lock.json +0 -3672
- package/references/sessionlog/package.json +0 -65
- package/references/sessionlog/src/__tests__/agent-hooks.test.ts +0 -570
- package/references/sessionlog/src/__tests__/agent-registry.test.ts +0 -127
- package/references/sessionlog/src/__tests__/claude-code-hooks.test.ts +0 -225
- package/references/sessionlog/src/__tests__/claude-generator.test.ts +0 -46
- package/references/sessionlog/src/__tests__/commit-msg.test.ts +0 -86
- package/references/sessionlog/src/__tests__/cursor-agent.test.ts +0 -224
- package/references/sessionlog/src/__tests__/e2e-live.test.ts +0 -890
- package/references/sessionlog/src/__tests__/event-log.test.ts +0 -183
- package/references/sessionlog/src/__tests__/flush-sentinel.test.ts +0 -105
- package/references/sessionlog/src/__tests__/gemini-agent.test.ts +0 -375
- package/references/sessionlog/src/__tests__/git-hooks.test.ts +0 -78
- package/references/sessionlog/src/__tests__/hook-managers.test.ts +0 -121
- package/references/sessionlog/src/__tests__/lifecycle-tasks.test.ts +0 -759
- package/references/sessionlog/src/__tests__/opencode-agent.test.ts +0 -338
- package/references/sessionlog/src/__tests__/redaction.test.ts +0 -136
- package/references/sessionlog/src/__tests__/session-repo.test.ts +0 -353
- package/references/sessionlog/src/__tests__/session-store.test.ts +0 -166
- package/references/sessionlog/src/__tests__/setup-ccweb.test.ts +0 -466
- package/references/sessionlog/src/__tests__/skill-live.test.ts +0 -461
- package/references/sessionlog/src/__tests__/summarize.test.ts +0 -348
- package/references/sessionlog/src/__tests__/task-plan-e2e.test.ts +0 -610
- package/references/sessionlog/src/__tests__/task-plan-live.test.ts +0 -632
- package/references/sessionlog/src/__tests__/transcript-timestamp.test.ts +0 -121
- package/references/sessionlog/src/__tests__/types.test.ts +0 -166
- package/references/sessionlog/src/__tests__/utils.test.ts +0 -333
- package/references/sessionlog/src/__tests__/validation.test.ts +0 -103
- package/references/sessionlog/src/__tests__/worktree.test.ts +0 -57
- package/references/sessionlog/src/agent/agents/claude-code.ts +0 -1089
- package/references/sessionlog/src/agent/agents/cursor.ts +0 -361
- package/references/sessionlog/src/agent/agents/gemini-cli.ts +0 -632
- package/references/sessionlog/src/agent/agents/opencode.ts +0 -540
- package/references/sessionlog/src/agent/registry.ts +0 -143
- package/references/sessionlog/src/agent/session-types.ts +0 -113
- package/references/sessionlog/src/agent/types.ts +0 -220
- package/references/sessionlog/src/cli.ts +0 -597
- package/references/sessionlog/src/commands/clean.ts +0 -133
- package/references/sessionlog/src/commands/disable.ts +0 -84
- package/references/sessionlog/src/commands/doctor.ts +0 -145
- package/references/sessionlog/src/commands/enable.ts +0 -202
- package/references/sessionlog/src/commands/explain.ts +0 -261
- package/references/sessionlog/src/commands/reset.ts +0 -105
- package/references/sessionlog/src/commands/resume.ts +0 -180
- package/references/sessionlog/src/commands/rewind.ts +0 -195
- package/references/sessionlog/src/commands/setup-ccweb.ts +0 -275
- package/references/sessionlog/src/commands/status.ts +0 -172
- package/references/sessionlog/src/config.ts +0 -165
- package/references/sessionlog/src/events/event-log.ts +0 -126
- package/references/sessionlog/src/git-operations.ts +0 -558
- package/references/sessionlog/src/hooks/git-hooks.ts +0 -165
- package/references/sessionlog/src/hooks/lifecycle.ts +0 -391
- package/references/sessionlog/src/index.ts +0 -650
- package/references/sessionlog/src/security/redaction.ts +0 -283
- package/references/sessionlog/src/session/state-machine.ts +0 -452
- package/references/sessionlog/src/store/checkpoint-store.ts +0 -509
- package/references/sessionlog/src/store/native-store.ts +0 -173
- package/references/sessionlog/src/store/provider-types.ts +0 -99
- package/references/sessionlog/src/store/session-store.ts +0 -266
- package/references/sessionlog/src/strategy/attribution.ts +0 -296
- package/references/sessionlog/src/strategy/common.ts +0 -207
- package/references/sessionlog/src/strategy/content-overlap.ts +0 -228
- package/references/sessionlog/src/strategy/manual-commit.ts +0 -988
- package/references/sessionlog/src/strategy/types.ts +0 -279
- package/references/sessionlog/src/summarize/claude-generator.ts +0 -115
- package/references/sessionlog/src/summarize/summarize.ts +0 -432
- package/references/sessionlog/src/types.ts +0 -508
- package/references/sessionlog/src/utils/chunk-files.ts +0 -49
- package/references/sessionlog/src/utils/commit-message.ts +0 -65
- package/references/sessionlog/src/utils/detect-agent.ts +0 -36
- package/references/sessionlog/src/utils/hook-managers.ts +0 -125
- package/references/sessionlog/src/utils/ide-tags.ts +0 -32
- package/references/sessionlog/src/utils/paths.ts +0 -79
- package/references/sessionlog/src/utils/preview-rewind.ts +0 -80
- package/references/sessionlog/src/utils/rewind-conflict.ts +0 -121
- package/references/sessionlog/src/utils/shadow-branch.ts +0 -109
- package/references/sessionlog/src/utils/string-utils.ts +0 -46
- package/references/sessionlog/src/utils/todo-extract.ts +0 -188
- package/references/sessionlog/src/utils/trailers.ts +0 -187
- package/references/sessionlog/src/utils/transcript-parse.ts +0 -177
- package/references/sessionlog/src/utils/transcript-timestamp.ts +0 -59
- package/references/sessionlog/src/utils/tree-ops.ts +0 -219
- package/references/sessionlog/src/utils/tty.ts +0 -72
- package/references/sessionlog/src/utils/validation.ts +0 -65
- package/references/sessionlog/src/utils/worktree.ts +0 -58
- package/references/sessionlog/src/wire-types.ts +0 -59
- package/references/sessionlog/templates/setup-env.sh +0 -153
- package/references/sessionlog/tsconfig.json +0 -18
- package/references/sessionlog/vitest.config.ts +0 -12
- package/references/skill-tree/.claude/settings.json +0 -6
- package/references/skill-tree/.sudocode/issues.jsonl +0 -19
- package/references/skill-tree/.sudocode/specs.jsonl +0 -3
- package/references/skill-tree/CLAUDE.md +0 -126
- package/references/skill-tree/README.md +0 -372
- package/references/skill-tree/docs/GAPS_v1.md +0 -221
- package/references/skill-tree/docs/INTEGRATION_PLAN.md +0 -467
- package/references/skill-tree/docs/TODOS.md +0 -91
- package/references/skill-tree/docs/anthropic_skill_guide.md +0 -1364
- package/references/skill-tree/docs/design/federated-skill-trees.md +0 -524
- package/references/skill-tree/docs/design/multi-agent-sync.md +0 -759
- package/references/skill-tree/docs/scraper/BRAINSTORM.md +0 -583
- package/references/skill-tree/docs/scraper/POC_PLAN.md +0 -420
- package/references/skill-tree/docs/scraper/README.md +0 -170
- package/references/skill-tree/examples/basic-usage.ts +0 -164
- package/references/skill-tree/package-lock.json +0 -1852
- package/references/skill-tree/package.json +0 -66
- package/references/skill-tree/scraper/README.md +0 -123
- package/references/skill-tree/scraper/docs/DESIGN.md +0 -683
- package/references/skill-tree/scraper/docs/PLAN.md +0 -336
- package/references/skill-tree/scraper/drizzle.config.ts +0 -10
- package/references/skill-tree/scraper/package-lock.json +0 -6329
- package/references/skill-tree/scraper/package.json +0 -68
- package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-description.md +0 -7
- package/references/skill-tree/scraper/test/fixtures/invalid-skill/missing-name.md +0 -7
- package/references/skill-tree/scraper/test/fixtures/minimal-skill/SKILL.md +0 -27
- package/references/skill-tree/scraper/test/fixtures/skill-json/SKILL.json +0 -21
- package/references/skill-tree/scraper/test/fixtures/skill-with-meta/SKILL.md +0 -54
- package/references/skill-tree/scraper/test/fixtures/skill-with-meta/_meta.json +0 -24
- package/references/skill-tree/scraper/test/fixtures/valid-skill/SKILL.md +0 -93
- package/references/skill-tree/scraper/test/fixtures/valid-skill/_meta.json +0 -22
- package/references/skill-tree/scraper/tsup.config.ts +0 -14
- package/references/skill-tree/scraper/vitest.config.ts +0 -17
- package/references/skill-tree/scripts/convert-to-vitest.ts +0 -166
- package/references/skill-tree/skills/skill-writer/SKILL.md +0 -339
- package/references/skill-tree/skills/skill-writer/references/examples.md +0 -326
- package/references/skill-tree/skills/skill-writer/references/patterns.md +0 -210
- package/references/skill-tree/skills/skill-writer/references/quality-checklist.md +0 -123
- package/references/skill-tree/test/run-all.ts +0 -106
- package/references/skill-tree/test/utils.ts +0 -128
- package/references/skill-tree/vitest.config.ts +0 -16
|
@@ -1,265 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Error path tests
|
|
3
|
-
*
|
|
4
|
-
* Tests error handling and recovery for:
|
|
5
|
-
* - Embedding API failures and timeouts
|
|
6
|
-
* - File system errors
|
|
7
|
-
* - Invalid configurations
|
|
8
|
-
* - Concurrent sync operations
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { describe, it, expect, beforeEach, afterEach, vi } from "vitest";
|
|
12
|
-
import fs from "node:fs/promises";
|
|
13
|
-
import os from "node:os";
|
|
14
|
-
import path from "node:path";
|
|
15
|
-
|
|
16
|
-
import { listMemoryFiles, logError, ensureDir } from "../internal.js";
|
|
17
|
-
import { parseFrontmatter, serializeFrontmatter, addFrontmatter } from "../session.js";
|
|
18
|
-
import { createEmbeddingProvider, type EmbeddingProviderOptions } from "../embeddings/embeddings.js";
|
|
19
|
-
|
|
20
|
-
describe("Error path: listMemoryFiles", () => {
|
|
21
|
-
let tempDir: string;
|
|
22
|
-
|
|
23
|
-
beforeEach(async () => {
|
|
24
|
-
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-err-"));
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
afterEach(async () => {
|
|
28
|
-
await fs.rm(tempDir, { recursive: true, force: true });
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it("throws when both MEMORY.md and memory.md exist as separate files", async () => {
|
|
32
|
-
await fs.writeFile(path.join(tempDir, "MEMORY.md"), "# Upper");
|
|
33
|
-
await fs.writeFile(path.join(tempDir, "memory.md"), "# Lower");
|
|
34
|
-
|
|
35
|
-
// On case-insensitive filesystems (macOS HFS+/APFS), both names resolve
|
|
36
|
-
// to the same file, so the error won't be thrown. Skip in that case.
|
|
37
|
-
const upperReal = await fs.realpath(path.join(tempDir, "MEMORY.md"));
|
|
38
|
-
const lowerReal = await fs.realpath(path.join(tempDir, "memory.md"));
|
|
39
|
-
if (upperReal === lowerReal) {
|
|
40
|
-
// Case-insensitive FS — can't have two distinct files
|
|
41
|
-
const files = await listMemoryFiles(tempDir);
|
|
42
|
-
expect(files).toHaveLength(1);
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
await expect(listMemoryFiles(tempDir)).rejects.toThrow(
|
|
47
|
-
/Both MEMORY\.md and memory\.md exist/,
|
|
48
|
-
);
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it("returns empty array when directory has no memory files", async () => {
|
|
52
|
-
const files = await listMemoryFiles(tempDir);
|
|
53
|
-
expect(files).toHaveLength(0);
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it("handles non-existent directory gracefully", async () => {
|
|
57
|
-
const badDir = path.join(tempDir, "does-not-exist");
|
|
58
|
-
const files = await listMemoryFiles(badDir);
|
|
59
|
-
expect(files).toHaveLength(0);
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
it("only returns one file when both MEMORY.md and memory.md resolve to same path", async () => {
|
|
63
|
-
// On case-insensitive filesystems, MEMORY.md and memory.md are the same file.
|
|
64
|
-
// On case-sensitive filesystems, this test verifies the single-file path.
|
|
65
|
-
await fs.writeFile(path.join(tempDir, "MEMORY.md"), "# Test");
|
|
66
|
-
|
|
67
|
-
const files = await listMemoryFiles(tempDir);
|
|
68
|
-
expect(files).toHaveLength(1);
|
|
69
|
-
expect(files[0]).toContain("MEMORY.md");
|
|
70
|
-
});
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
describe("Error path: logError", () => {
|
|
74
|
-
it("does nothing when debug is undefined", () => {
|
|
75
|
-
// Should not throw
|
|
76
|
-
logError("test", new Error("something broke"));
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
it("logs error message when debug is provided", () => {
|
|
80
|
-
const messages: string[] = [];
|
|
81
|
-
const debug = (msg: string) => messages.push(msg);
|
|
82
|
-
|
|
83
|
-
logError("testContext", new Error("something broke"), debug);
|
|
84
|
-
|
|
85
|
-
expect(messages).toHaveLength(1);
|
|
86
|
-
expect(messages[0]).toContain("[testContext]");
|
|
87
|
-
expect(messages[0]).toContain("something broke");
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
it("handles non-Error objects", () => {
|
|
91
|
-
const messages: string[] = [];
|
|
92
|
-
const debug = (msg: string) => messages.push(msg);
|
|
93
|
-
|
|
94
|
-
logError("testContext", "string error", debug);
|
|
95
|
-
expect(messages[0]).toContain("string error");
|
|
96
|
-
|
|
97
|
-
logError("testContext", 42, debug);
|
|
98
|
-
expect(messages[1]).toContain("42");
|
|
99
|
-
|
|
100
|
-
logError("testContext", null, debug);
|
|
101
|
-
expect(messages[2]).toContain("null");
|
|
102
|
-
});
|
|
103
|
-
});
|
|
104
|
-
|
|
105
|
-
describe("Error path: ensureDir", () => {
|
|
106
|
-
let tempDir: string;
|
|
107
|
-
|
|
108
|
-
beforeEach(async () => {
|
|
109
|
-
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-err-"));
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
afterEach(async () => {
|
|
113
|
-
await fs.rm(tempDir, { recursive: true, force: true });
|
|
114
|
-
});
|
|
115
|
-
|
|
116
|
-
it("creates nested directories", () => {
|
|
117
|
-
const nested = path.join(tempDir, "a", "b", "c");
|
|
118
|
-
const result = ensureDir(nested);
|
|
119
|
-
expect(result).toBe(nested);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
it("succeeds when directory already exists", () => {
|
|
123
|
-
ensureDir(tempDir);
|
|
124
|
-
const result = ensureDir(tempDir); // Call again
|
|
125
|
-
expect(result).toBe(tempDir);
|
|
126
|
-
});
|
|
127
|
-
|
|
128
|
-
it("logs non-EEXIST errors through debug", () => {
|
|
129
|
-
const messages: string[] = [];
|
|
130
|
-
const debug = (msg: string) => messages.push(msg);
|
|
131
|
-
|
|
132
|
-
// Attempt to create a directory with an invalid path (empty string)
|
|
133
|
-
// This may or may not fail depending on OS, so we just verify it doesn't throw
|
|
134
|
-
ensureDir(path.join(tempDir, "valid"), debug);
|
|
135
|
-
// No error logged for successful creation
|
|
136
|
-
});
|
|
137
|
-
});
|
|
138
|
-
|
|
139
|
-
describe("Error path: createEmbeddingProvider", () => {
|
|
140
|
-
it("returns no-op provider for 'none' without type coercion", async () => {
|
|
141
|
-
const options: EmbeddingProviderOptions = { provider: "none" };
|
|
142
|
-
const result = await createEmbeddingProvider(options);
|
|
143
|
-
|
|
144
|
-
expect(result.provider.id).toBe("none");
|
|
145
|
-
expect(result.provider.model).toBe("bm25-only");
|
|
146
|
-
expect(result.requestedProvider).toBe("none");
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
it("falls back to BM25-only when no API keys available in auto mode", async () => {
|
|
150
|
-
// Clear any API keys
|
|
151
|
-
const origOpenAi = process.env.OPENAI_API_KEY;
|
|
152
|
-
const origGoogle = process.env.GOOGLE_API_KEY;
|
|
153
|
-
const origGemini = process.env.GEMINI_API_KEY;
|
|
154
|
-
delete process.env.OPENAI_API_KEY;
|
|
155
|
-
delete process.env.GOOGLE_API_KEY;
|
|
156
|
-
delete process.env.GEMINI_API_KEY;
|
|
157
|
-
|
|
158
|
-
try {
|
|
159
|
-
const options: EmbeddingProviderOptions = { provider: "auto" };
|
|
160
|
-
const result = await createEmbeddingProvider(options);
|
|
161
|
-
|
|
162
|
-
expect(result.provider.id).toBe("none");
|
|
163
|
-
expect(result.requestedProvider).toBe("auto");
|
|
164
|
-
expect(result.fallbackFrom).toBe("auto");
|
|
165
|
-
expect(result.fallbackReason).toContain("BM25");
|
|
166
|
-
} finally {
|
|
167
|
-
// Restore
|
|
168
|
-
if (origOpenAi) process.env.OPENAI_API_KEY = origOpenAi;
|
|
169
|
-
if (origGoogle) process.env.GOOGLE_API_KEY = origGoogle;
|
|
170
|
-
if (origGemini) process.env.GEMINI_API_KEY = origGemini;
|
|
171
|
-
}
|
|
172
|
-
});
|
|
173
|
-
|
|
174
|
-
it("throws when openai explicitly requested without API key", async () => {
|
|
175
|
-
const origKey = process.env.OPENAI_API_KEY;
|
|
176
|
-
delete process.env.OPENAI_API_KEY;
|
|
177
|
-
|
|
178
|
-
try {
|
|
179
|
-
const options: EmbeddingProviderOptions = { provider: "openai" };
|
|
180
|
-
await expect(createEmbeddingProvider(options)).rejects.toThrow(/API key/);
|
|
181
|
-
} finally {
|
|
182
|
-
if (origKey) process.env.OPENAI_API_KEY = origKey;
|
|
183
|
-
}
|
|
184
|
-
});
|
|
185
|
-
|
|
186
|
-
it("throws when gemini explicitly requested without API key", async () => {
|
|
187
|
-
const origGoogle = process.env.GOOGLE_API_KEY;
|
|
188
|
-
const origGemini = process.env.GEMINI_API_KEY;
|
|
189
|
-
delete process.env.GOOGLE_API_KEY;
|
|
190
|
-
delete process.env.GEMINI_API_KEY;
|
|
191
|
-
|
|
192
|
-
try {
|
|
193
|
-
const options: EmbeddingProviderOptions = { provider: "gemini" };
|
|
194
|
-
await expect(createEmbeddingProvider(options)).rejects.toThrow(/API key/);
|
|
195
|
-
} finally {
|
|
196
|
-
if (origGoogle) process.env.GOOGLE_API_KEY = origGoogle;
|
|
197
|
-
if (origGemini) process.env.GEMINI_API_KEY = origGemini;
|
|
198
|
-
}
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
it("no-op provider returns empty vectors", async () => {
|
|
202
|
-
const options: EmbeddingProviderOptions = { provider: "none" };
|
|
203
|
-
const result = await createEmbeddingProvider(options);
|
|
204
|
-
|
|
205
|
-
const queryResult = await result.provider.embedQuery("test");
|
|
206
|
-
expect(queryResult).toEqual([]);
|
|
207
|
-
|
|
208
|
-
const batchResult = await result.provider.embedBatch(["test1", "test2"]);
|
|
209
|
-
expect(batchResult).toEqual([[], []]);
|
|
210
|
-
});
|
|
211
|
-
});
|
|
212
|
-
|
|
213
|
-
describe("Error path: parseFrontmatter", () => {
|
|
214
|
-
it("returns undefined frontmatter for content without frontmatter", () => {
|
|
215
|
-
const { frontmatter, body } = parseFrontmatter("# Just a heading\n\nSome content.");
|
|
216
|
-
expect(frontmatter).toBeUndefined();
|
|
217
|
-
expect(body).toBe("# Just a heading\n\nSome content.");
|
|
218
|
-
});
|
|
219
|
-
|
|
220
|
-
it("returns undefined frontmatter for malformed YAML", () => {
|
|
221
|
-
const content = "---\n{{{invalid: yaml: }}}\n---\nBody";
|
|
222
|
-
const { frontmatter, body } = parseFrontmatter(content);
|
|
223
|
-
// Malformed YAML should fall through to body
|
|
224
|
-
expect(body).toBeTruthy();
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
it("handles empty frontmatter block", () => {
|
|
228
|
-
const content = "---\n\n---\nBody content";
|
|
229
|
-
const { frontmatter, body } = parseFrontmatter(content);
|
|
230
|
-
expect(body).toBe("Body content");
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
it("handles content that starts with --- but has no closing ---", () => {
|
|
234
|
-
const content = "---\nkey: value\nMore content without closing";
|
|
235
|
-
const { frontmatter, body } = parseFrontmatter(content);
|
|
236
|
-
// No closing --- means no frontmatter
|
|
237
|
-
expect(frontmatter).toBeUndefined();
|
|
238
|
-
expect(body).toBe(content);
|
|
239
|
-
});
|
|
240
|
-
});
|
|
241
|
-
|
|
242
|
-
describe("Error path: addFrontmatter", () => {
|
|
243
|
-
it("creates frontmatter on content without any", () => {
|
|
244
|
-
const result = addFrontmatter("# Hello", { tags: ["test"] });
|
|
245
|
-
expect(result).toContain("---");
|
|
246
|
-
expect(result).toContain("tags: [test]");
|
|
247
|
-
expect(result).toContain("# Hello");
|
|
248
|
-
});
|
|
249
|
-
|
|
250
|
-
it("merges with existing frontmatter", () => {
|
|
251
|
-
const existing = "---\ncreated: 2024-01-01T00:00:00Z\n---\n# Hello";
|
|
252
|
-
const result = addFrontmatter(existing, { tags: ["new"] });
|
|
253
|
-
expect(result).toContain("tags: [new]");
|
|
254
|
-
expect(result).toContain("created: 2024-01-01T00:00:00Z");
|
|
255
|
-
expect(result).toContain("# Hello");
|
|
256
|
-
});
|
|
257
|
-
|
|
258
|
-
it("preserves session data when adding other frontmatter", () => {
|
|
259
|
-
const existing = "---\nsession:\n id: abc123\n source: test\n---\n# Hello";
|
|
260
|
-
const result = addFrontmatter(existing, { tags: ["new"] });
|
|
261
|
-
expect(result).toContain("id: abc123");
|
|
262
|
-
expect(result).toContain("source: test");
|
|
263
|
-
expect(result).toContain("tags: [new]");
|
|
264
|
-
});
|
|
265
|
-
});
|
|
@@ -1,199 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Shared test utilities for minimem tests
|
|
3
|
-
*
|
|
4
|
-
* These helpers provide deterministic, API-free testing of embedding
|
|
5
|
-
* and search functionality.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import fs from "node:fs/promises";
|
|
9
|
-
import os from "node:os";
|
|
10
|
-
import path from "node:path";
|
|
11
|
-
import { mock } from "node:test";
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Create a deterministic embedding based on keyword presence.
|
|
15
|
-
*
|
|
16
|
-
* Returns a normalized vector where dimensions correspond to keyword
|
|
17
|
-
* frequencies. This allows predictable test results without API calls.
|
|
18
|
-
*
|
|
19
|
-
* @param text - The text to embed
|
|
20
|
-
* @param dims - Number of dimensions (default: 128)
|
|
21
|
-
* @returns Normalized embedding vector
|
|
22
|
-
*/
|
|
23
|
-
export function createDeterministicEmbedding(text: string, dims = 128): number[] {
|
|
24
|
-
const lower = text.toLowerCase();
|
|
25
|
-
const keywords = [
|
|
26
|
-
"project", "meeting", "todo", "bug", "feature", "api", "database", "user",
|
|
27
|
-
"test", "deploy", "config", "error", "fix", "update", "review", "design",
|
|
28
|
-
"alpha", "beta", "gamma", "delta", "epsilon", "zeta", "eta", "theta",
|
|
29
|
-
"important", "urgent", "note", "remember", "decision", "action", "plan", "goal",
|
|
30
|
-
];
|
|
31
|
-
|
|
32
|
-
const vec = new Array(dims).fill(0);
|
|
33
|
-
|
|
34
|
-
// Set values based on keyword presence
|
|
35
|
-
keywords.forEach((keyword, i) => {
|
|
36
|
-
if (i < dims) {
|
|
37
|
-
const count = (lower.match(new RegExp(keyword, "g")) || []).length;
|
|
38
|
-
vec[i] = count * 0.5;
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
// Add some variation based on text length and characters
|
|
43
|
-
for (let i = 32; i < dims; i++) {
|
|
44
|
-
vec[i] = (lower.charCodeAt(i % lower.length) || 0) / 1000;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
// Normalize
|
|
48
|
-
const magnitude = Math.sqrt(vec.reduce((sum, v) => sum + v * v, 0)) || 1;
|
|
49
|
-
return vec.map(v => v / magnitude);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Create a mock fetch function that returns deterministic embeddings.
|
|
54
|
-
*
|
|
55
|
-
* Handles OpenAI and Gemini embedding API endpoints.
|
|
56
|
-
*/
|
|
57
|
-
export function createMockFetch() {
|
|
58
|
-
return mock.fn(async (url: string | URL, init?: RequestInit) => {
|
|
59
|
-
const urlStr = url.toString();
|
|
60
|
-
const body = init?.body ? JSON.parse(init.body as string) : {};
|
|
61
|
-
|
|
62
|
-
// Handle OpenAI embeddings endpoint
|
|
63
|
-
if (urlStr.includes("/embeddings")) {
|
|
64
|
-
const inputs = Array.isArray(body.input) ? body.input : [body.input];
|
|
65
|
-
const data = inputs.map((text: string, index: number) => ({
|
|
66
|
-
object: "embedding",
|
|
67
|
-
index,
|
|
68
|
-
embedding: createDeterministicEmbedding(text),
|
|
69
|
-
}));
|
|
70
|
-
|
|
71
|
-
return {
|
|
72
|
-
ok: true,
|
|
73
|
-
status: 200,
|
|
74
|
-
json: async () => ({ object: "list", data, model: body.model }),
|
|
75
|
-
text: async () => JSON.stringify({ object: "list", data, model: body.model }),
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
// Handle Gemini embeddings endpoint
|
|
80
|
-
if (urlStr.includes("embedContent") || urlStr.includes("batchEmbedContents")) {
|
|
81
|
-
const text = body.content?.parts?.[0]?.text || body.requests?.[0]?.content?.parts?.[0]?.text || "";
|
|
82
|
-
const embedding = createDeterministicEmbedding(text);
|
|
83
|
-
|
|
84
|
-
if (urlStr.includes("batchEmbedContents")) {
|
|
85
|
-
const requests = body.requests || [];
|
|
86
|
-
return {
|
|
87
|
-
ok: true,
|
|
88
|
-
status: 200,
|
|
89
|
-
json: async () => ({
|
|
90
|
-
embeddings: requests.map((req: { content?: { parts?: { text?: string }[] } }) => ({
|
|
91
|
-
values: createDeterministicEmbedding(req.content?.parts?.[0]?.text || ""),
|
|
92
|
-
})),
|
|
93
|
-
}),
|
|
94
|
-
text: async () => JSON.stringify({ embeddings: [] }),
|
|
95
|
-
};
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
return {
|
|
99
|
-
ok: true,
|
|
100
|
-
status: 200,
|
|
101
|
-
json: async () => ({ embedding: { values: embedding } }),
|
|
102
|
-
text: async () => JSON.stringify({ embedding: { values: embedding } }),
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
// Default: return error
|
|
107
|
-
return {
|
|
108
|
-
ok: false,
|
|
109
|
-
status: 404,
|
|
110
|
-
json: async () => ({ error: "Not found" }),
|
|
111
|
-
text: async () => "Not found",
|
|
112
|
-
};
|
|
113
|
-
});
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* Capture console output for testing CLI commands.
|
|
118
|
-
*
|
|
119
|
-
* Returns an object with logs and errors arrays, plus a restore function.
|
|
120
|
-
*/
|
|
121
|
-
export function captureConsole() {
|
|
122
|
-
const logs: string[] = [];
|
|
123
|
-
const errors: string[] = [];
|
|
124
|
-
const originalLog = console.log;
|
|
125
|
-
const originalError = console.error;
|
|
126
|
-
|
|
127
|
-
console.log = (...args: unknown[]) => {
|
|
128
|
-
logs.push(args.map(a => String(a)).join(" "));
|
|
129
|
-
};
|
|
130
|
-
console.error = (...args: unknown[]) => {
|
|
131
|
-
errors.push(args.map(a => String(a)).join(" "));
|
|
132
|
-
};
|
|
133
|
-
|
|
134
|
-
return {
|
|
135
|
-
logs,
|
|
136
|
-
errors,
|
|
137
|
-
restore: () => {
|
|
138
|
-
console.log = originalLog;
|
|
139
|
-
console.error = originalError;
|
|
140
|
-
},
|
|
141
|
-
};
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
/**
|
|
145
|
-
* Create a temporary directory for test isolation.
|
|
146
|
-
*
|
|
147
|
-
* @param prefix - Directory name prefix (default: "minimem-test-")
|
|
148
|
-
* @returns Object with dir path and cleanup function
|
|
149
|
-
*/
|
|
150
|
-
export async function createTempDir(prefix = "minimem-test-"): Promise<{
|
|
151
|
-
dir: string;
|
|
152
|
-
cleanup: () => Promise<void>;
|
|
153
|
-
}> {
|
|
154
|
-
const dir = await fs.mkdtemp(path.join(os.tmpdir(), prefix));
|
|
155
|
-
return {
|
|
156
|
-
dir,
|
|
157
|
-
cleanup: async () => {
|
|
158
|
-
await fs.rm(dir, { recursive: true, force: true });
|
|
159
|
-
},
|
|
160
|
-
};
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
/**
|
|
164
|
-
* Create a temporary directory with basic memory structure.
|
|
165
|
-
*
|
|
166
|
-
* Creates the directory with MEMORY.md and memory/ subdirectory.
|
|
167
|
-
*
|
|
168
|
-
* @param prefix - Directory name prefix
|
|
169
|
-
* @returns Object with dir path, cleanup function, and paths to common files
|
|
170
|
-
*/
|
|
171
|
-
export async function createTempMemoryDir(prefix = "minimem-test-"): Promise<{
|
|
172
|
-
dir: string;
|
|
173
|
-
memoryFile: string;
|
|
174
|
-
memorySubdir: string;
|
|
175
|
-
cleanup: () => Promise<void>;
|
|
176
|
-
}> {
|
|
177
|
-
const dir = await fs.mkdtemp(path.join(os.tmpdir(), prefix));
|
|
178
|
-
const memoryFile = path.join(dir, "MEMORY.md");
|
|
179
|
-
const memorySubdir = path.join(dir, "memory");
|
|
180
|
-
|
|
181
|
-
await fs.mkdir(memorySubdir, { recursive: true });
|
|
182
|
-
await fs.writeFile(memoryFile, "# Memory\n\n");
|
|
183
|
-
|
|
184
|
-
return {
|
|
185
|
-
dir,
|
|
186
|
-
memoryFile,
|
|
187
|
-
memorySubdir,
|
|
188
|
-
cleanup: async () => {
|
|
189
|
-
await fs.rm(dir, { recursive: true, force: true });
|
|
190
|
-
},
|
|
191
|
-
};
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
/**
|
|
195
|
-
* Wait for a specified number of milliseconds.
|
|
196
|
-
*/
|
|
197
|
-
export function sleep(ms: number): Promise<void> {
|
|
198
|
-
return new Promise(resolve => setTimeout(resolve, ms));
|
|
199
|
-
}
|