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,209 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for change detection and quarantine
|
|
3
|
-
*
|
|
4
|
-
* Note: Shadow copy system was removed in favor of last-write-wins.
|
|
5
|
-
* Only quarantine functions remain for manual review when needed.
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
import { describe, it, beforeEach, afterEach, expect } from "vitest";
|
|
9
|
-
import fs from "node:fs/promises";
|
|
10
|
-
import path from "node:path";
|
|
11
|
-
import os from "node:os";
|
|
12
|
-
|
|
13
|
-
import {
|
|
14
|
-
detectChanges,
|
|
15
|
-
quarantineConflict,
|
|
16
|
-
listQuarantinedConflicts,
|
|
17
|
-
getConflictsDir,
|
|
18
|
-
} from "../conflicts.js";
|
|
19
|
-
import { initCentralRepo } from "../central.js";
|
|
20
|
-
import { saveSyncState, computeFileHash } from "../state.js";
|
|
21
|
-
import { saveConfig } from "../../config.js";
|
|
22
|
-
|
|
23
|
-
describe("conflicts", () => {
|
|
24
|
-
let tempDir: string;
|
|
25
|
-
let localDir: string;
|
|
26
|
-
let centralRepo: string;
|
|
27
|
-
let remotePath: string;
|
|
28
|
-
|
|
29
|
-
beforeEach(async () => {
|
|
30
|
-
// Create temp directories
|
|
31
|
-
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-conflicts-test-"));
|
|
32
|
-
localDir = path.join(tempDir, "local");
|
|
33
|
-
centralRepo = path.join(tempDir, "central");
|
|
34
|
-
remotePath = path.join(centralRepo, "test-project");
|
|
35
|
-
|
|
36
|
-
// Set up directories
|
|
37
|
-
await fs.mkdir(localDir, { recursive: true });
|
|
38
|
-
await fs.mkdir(path.join(localDir, ".minimem"), { recursive: true });
|
|
39
|
-
await fs.mkdir(path.join(localDir, "memory"), { recursive: true });
|
|
40
|
-
await fs.mkdir(remotePath, { recursive: true });
|
|
41
|
-
await fs.mkdir(path.join(remotePath, "memory"), { recursive: true });
|
|
42
|
-
|
|
43
|
-
// Initialize central repo
|
|
44
|
-
await initCentralRepo(centralRepo);
|
|
45
|
-
|
|
46
|
-
// Write MEMORY.md to both
|
|
47
|
-
await fs.writeFile(path.join(localDir, "MEMORY.md"), "# Local Memory\n");
|
|
48
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "# Remote Memory\n");
|
|
49
|
-
|
|
50
|
-
// Configure sync
|
|
51
|
-
const config = {
|
|
52
|
-
sync: {
|
|
53
|
-
enabled: true,
|
|
54
|
-
path: "test-project",
|
|
55
|
-
},
|
|
56
|
-
};
|
|
57
|
-
await saveConfig(localDir, config);
|
|
58
|
-
|
|
59
|
-
// Set up XDG config with central repo path
|
|
60
|
-
const xdgDir = path.join(tempDir, "xdg-config");
|
|
61
|
-
await fs.mkdir(xdgDir, { recursive: true });
|
|
62
|
-
process.env.XDG_CONFIG_HOME = xdgDir;
|
|
63
|
-
await fs.mkdir(path.join(xdgDir, "minimem"), { recursive: true });
|
|
64
|
-
await fs.writeFile(
|
|
65
|
-
path.join(xdgDir, "minimem", "config.json"),
|
|
66
|
-
JSON.stringify({ centralRepo }, null, 2)
|
|
67
|
-
);
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
afterEach(async () => {
|
|
71
|
-
delete process.env.XDG_CONFIG_HOME;
|
|
72
|
-
try {
|
|
73
|
-
await fs.rm(tempDir, { recursive: true, force: true });
|
|
74
|
-
} catch {
|
|
75
|
-
// Ignore cleanup errors
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
describe("quarantine", () => {
|
|
80
|
-
it("should quarantine file versions for manual review", async () => {
|
|
81
|
-
const localContent = "Local version";
|
|
82
|
-
const remoteContent = "Remote version";
|
|
83
|
-
|
|
84
|
-
const conflictDir = await quarantineConflict(
|
|
85
|
-
localDir,
|
|
86
|
-
"MEMORY.md",
|
|
87
|
-
localContent,
|
|
88
|
-
remoteContent
|
|
89
|
-
);
|
|
90
|
-
|
|
91
|
-
const files = await fs.readdir(conflictDir);
|
|
92
|
-
expect(files.includes("MEMORY.md.local")).toBeTruthy();
|
|
93
|
-
expect(files.includes("MEMORY.md.remote")).toBeTruthy();
|
|
94
|
-
|
|
95
|
-
const local = await fs.readFile(path.join(conflictDir, "MEMORY.md.local"), "utf-8");
|
|
96
|
-
expect(local).toBe(localContent);
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
it("should handle null versions", async () => {
|
|
100
|
-
const conflictDir = await quarantineConflict(
|
|
101
|
-
localDir,
|
|
102
|
-
"MEMORY.md",
|
|
103
|
-
"Local only",
|
|
104
|
-
null
|
|
105
|
-
);
|
|
106
|
-
|
|
107
|
-
const files = await fs.readdir(conflictDir);
|
|
108
|
-
expect(files.includes("MEMORY.md.local")).toBeTruthy();
|
|
109
|
-
expect(!files.includes("MEMORY.md.remote")).toBeTruthy();
|
|
110
|
-
});
|
|
111
|
-
|
|
112
|
-
it("should list quarantined file versions", async () => {
|
|
113
|
-
await quarantineConflict(localDir, "MEMORY.md", "Local", "Remote");
|
|
114
|
-
await new Promise((r) => setTimeout(r, 50)); // Slight delay for unique timestamp
|
|
115
|
-
await quarantineConflict(localDir, "memory/file.md", "Local 2", "Remote 2");
|
|
116
|
-
|
|
117
|
-
const conflicts = await listQuarantinedConflicts(localDir);
|
|
118
|
-
|
|
119
|
-
expect(conflicts.length >= 2).toBeTruthy();
|
|
120
|
-
expect(conflicts.some((c) => c.files.includes("MEMORY.md"))).toBeTruthy();
|
|
121
|
-
expect(conflicts.some((c) => c.files.includes("memory/file.md"))).toBeTruthy();
|
|
122
|
-
});
|
|
123
|
-
|
|
124
|
-
it("should return empty array when no quarantined files", async () => {
|
|
125
|
-
const conflicts = await listQuarantinedConflicts(localDir);
|
|
126
|
-
expect(conflicts.length).toBe(0);
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
it("should create conflicts directory path correctly", () => {
|
|
130
|
-
const conflictsDir = getConflictsDir(localDir);
|
|
131
|
-
expect(conflictsDir).toBe(path.join(localDir, ".minimem", "conflicts"));
|
|
132
|
-
});
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
describe("detectChanges", () => {
|
|
136
|
-
it("should detect unchanged files", async () => {
|
|
137
|
-
// Same content in both
|
|
138
|
-
await fs.writeFile(path.join(localDir, "MEMORY.md"), "Same content");
|
|
139
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "Same content");
|
|
140
|
-
|
|
141
|
-
// Set up sync state with matching hash
|
|
142
|
-
const hash = await computeFileHash(path.join(localDir, "MEMORY.md"));
|
|
143
|
-
const state = {
|
|
144
|
-
version: 2,
|
|
145
|
-
centralPath: "test-project",
|
|
146
|
-
lastSync: new Date().toISOString(),
|
|
147
|
-
files: {
|
|
148
|
-
"MEMORY.md": {
|
|
149
|
-
localHash: hash,
|
|
150
|
-
remoteHash: hash,
|
|
151
|
-
lastModified: new Date().toISOString(),
|
|
152
|
-
},
|
|
153
|
-
},
|
|
154
|
-
};
|
|
155
|
-
await saveSyncState(localDir, state);
|
|
156
|
-
|
|
157
|
-
const result = await detectChanges(localDir);
|
|
158
|
-
|
|
159
|
-
expect(result.summary.unchanged).toBe(1);
|
|
160
|
-
expect(result.changes.length).toBe(0);
|
|
161
|
-
});
|
|
162
|
-
|
|
163
|
-
it("should detect local-only changes", async () => {
|
|
164
|
-
// Local has different content
|
|
165
|
-
await fs.writeFile(path.join(localDir, "MEMORY.md"), "Local change");
|
|
166
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "Original");
|
|
167
|
-
|
|
168
|
-
const result = await detectChanges(localDir);
|
|
169
|
-
|
|
170
|
-
expect(result.summary.localModified).toBe(1);
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
it("should detect remote-only files", async () => {
|
|
174
|
-
// Remove local file, keep remote
|
|
175
|
-
await fs.unlink(path.join(localDir, "MEMORY.md"));
|
|
176
|
-
|
|
177
|
-
const result = await detectChanges(localDir);
|
|
178
|
-
|
|
179
|
-
expect(result.summary.remoteOnly >= 1).toBeTruthy();
|
|
180
|
-
});
|
|
181
|
-
|
|
182
|
-
it("should detect differences when both changed", async () => {
|
|
183
|
-
// Both have different content
|
|
184
|
-
await fs.writeFile(path.join(localDir, "MEMORY.md"), "Local change");
|
|
185
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "Remote change");
|
|
186
|
-
|
|
187
|
-
const result = await detectChanges(localDir);
|
|
188
|
-
|
|
189
|
-
// With 2-way comparison, different content = local-modified
|
|
190
|
-
expect(result.summary.localModified).toBe(1);
|
|
191
|
-
});
|
|
192
|
-
|
|
193
|
-
it("should detect new local files", async () => {
|
|
194
|
-
await fs.writeFile(path.join(localDir, "memory", "new-file.md"), "New content");
|
|
195
|
-
|
|
196
|
-
const result = await detectChanges(localDir);
|
|
197
|
-
|
|
198
|
-
expect(result.summary.localOnly >= 1).toBeTruthy();
|
|
199
|
-
});
|
|
200
|
-
|
|
201
|
-
it("should detect new remote files", async () => {
|
|
202
|
-
await fs.writeFile(path.join(remotePath, "memory", "new-remote.md"), "Remote content");
|
|
203
|
-
|
|
204
|
-
const result = await detectChanges(localDir);
|
|
205
|
-
|
|
206
|
-
expect(result.summary.remoteOnly >= 1).toBeTruthy();
|
|
207
|
-
});
|
|
208
|
-
});
|
|
209
|
-
});
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for daemon module
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
import { describe, it, beforeEach, afterEach, expect } from "vitest";
|
|
6
|
-
import fs from "node:fs/promises";
|
|
7
|
-
import path from "node:path";
|
|
8
|
-
import os from "node:os";
|
|
9
|
-
|
|
10
|
-
import {
|
|
11
|
-
getDaemonDir,
|
|
12
|
-
getPidFilePath,
|
|
13
|
-
getDaemonLogPath,
|
|
14
|
-
isDaemonRunning,
|
|
15
|
-
getDaemonStatus,
|
|
16
|
-
} from "../daemon.js";
|
|
17
|
-
|
|
18
|
-
describe("Daemon", () => {
|
|
19
|
-
let originalHome: string | undefined;
|
|
20
|
-
let tempHome: string;
|
|
21
|
-
|
|
22
|
-
beforeEach(async () => {
|
|
23
|
-
// Create temp home directory
|
|
24
|
-
tempHome = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-daemon-test-"));
|
|
25
|
-
originalHome = process.env.HOME;
|
|
26
|
-
process.env.HOME = tempHome;
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
afterEach(async () => {
|
|
30
|
-
process.env.HOME = originalHome;
|
|
31
|
-
try {
|
|
32
|
-
await fs.rm(tempHome, { recursive: true, force: true });
|
|
33
|
-
} catch {
|
|
34
|
-
// Ignore cleanup errors
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
describe("getDaemonDir", () => {
|
|
39
|
-
it("should return path in home directory", () => {
|
|
40
|
-
const dir = getDaemonDir();
|
|
41
|
-
expect(dir.includes(".minimem")).toBeTruthy();
|
|
42
|
-
expect(dir.startsWith(tempHome)).toBeTruthy();
|
|
43
|
-
});
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
describe("getPidFilePath", () => {
|
|
47
|
-
it("should return path to daemon.pid", () => {
|
|
48
|
-
const pidPath = getPidFilePath();
|
|
49
|
-
expect(pidPath.endsWith("daemon.pid")).toBeTruthy();
|
|
50
|
-
expect(pidPath.includes(".minimem")).toBeTruthy();
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
describe("getDaemonLogPath", () => {
|
|
55
|
-
it("should return path to daemon.log", () => {
|
|
56
|
-
const logPath = getDaemonLogPath();
|
|
57
|
-
expect(logPath.endsWith("daemon.log")).toBeTruthy();
|
|
58
|
-
expect(logPath.includes(".minimem")).toBeTruthy();
|
|
59
|
-
});
|
|
60
|
-
});
|
|
61
|
-
|
|
62
|
-
describe("isDaemonRunning", () => {
|
|
63
|
-
it("should return false when no PID file exists", async () => {
|
|
64
|
-
const running = await isDaemonRunning();
|
|
65
|
-
expect(running).toBe(false);
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it("should return false when PID file has invalid content", async () => {
|
|
69
|
-
const daemonDir = getDaemonDir();
|
|
70
|
-
await fs.mkdir(daemonDir, { recursive: true });
|
|
71
|
-
await fs.writeFile(getPidFilePath(), "not-a-number");
|
|
72
|
-
|
|
73
|
-
const running = await isDaemonRunning();
|
|
74
|
-
expect(running).toBe(false);
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
it("should return false when process is not running", async () => {
|
|
78
|
-
const daemonDir = getDaemonDir();
|
|
79
|
-
await fs.mkdir(daemonDir, { recursive: true });
|
|
80
|
-
// Use a PID that definitely doesn't exist
|
|
81
|
-
await fs.writeFile(getPidFilePath(), "999999999");
|
|
82
|
-
|
|
83
|
-
const running = await isDaemonRunning();
|
|
84
|
-
expect(running).toBe(false);
|
|
85
|
-
|
|
86
|
-
// PID file should be cleaned up
|
|
87
|
-
const exists = await fs.access(getPidFilePath()).then(() => true).catch(() => false);
|
|
88
|
-
expect(exists).toBe(false);
|
|
89
|
-
});
|
|
90
|
-
|
|
91
|
-
it("should return true for current process PID", async () => {
|
|
92
|
-
const daemonDir = getDaemonDir();
|
|
93
|
-
await fs.mkdir(daemonDir, { recursive: true });
|
|
94
|
-
await fs.writeFile(getPidFilePath(), String(process.pid));
|
|
95
|
-
|
|
96
|
-
const running = await isDaemonRunning();
|
|
97
|
-
expect(running).toBe(true);
|
|
98
|
-
});
|
|
99
|
-
});
|
|
100
|
-
|
|
101
|
-
describe("getDaemonStatus", () => {
|
|
102
|
-
it("should return not running when no daemon", async () => {
|
|
103
|
-
const status = await getDaemonStatus();
|
|
104
|
-
expect(status.running).toBe(false);
|
|
105
|
-
expect(status.pid).toBe(undefined);
|
|
106
|
-
});
|
|
107
|
-
|
|
108
|
-
it("should return running with PID when daemon is running", async () => {
|
|
109
|
-
const daemonDir = getDaemonDir();
|
|
110
|
-
await fs.mkdir(daemonDir, { recursive: true });
|
|
111
|
-
await fs.writeFile(getPidFilePath(), String(process.pid));
|
|
112
|
-
|
|
113
|
-
const status = await getDaemonStatus();
|
|
114
|
-
expect(status.running).toBe(true);
|
|
115
|
-
expect(status.pid).toBe(process.pid);
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
});
|
|
@@ -1,207 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Tests for directory type detection
|
|
3
|
-
*
|
|
4
|
-
* Simplified to two types:
|
|
5
|
-
* - project-bound: inside git repo (synced via project's git)
|
|
6
|
-
* - standalone: uses minimem sync or not in git (default)
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
import fs from "node:fs/promises";
|
|
10
|
-
import os from "node:os";
|
|
11
|
-
import path from "node:path";
|
|
12
|
-
import { afterEach, beforeEach, describe, it, expect } from "vitest";
|
|
13
|
-
|
|
14
|
-
import {
|
|
15
|
-
detectDirectoryType,
|
|
16
|
-
isInsideGitRepo,
|
|
17
|
-
getGitRoot,
|
|
18
|
-
hasSyncConfig,
|
|
19
|
-
getDirectoryInfo,
|
|
20
|
-
} from "../detection.js";
|
|
21
|
-
|
|
22
|
-
describe("Directory Type Detection", () => {
|
|
23
|
-
let tempDir: string;
|
|
24
|
-
|
|
25
|
-
beforeEach(async () => {
|
|
26
|
-
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-detection-test-"));
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
afterEach(async () => {
|
|
30
|
-
await fs.rm(tempDir, { recursive: true, force: true });
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
describe("isInsideGitRepo", () => {
|
|
34
|
-
it("should return false for directory without .git", async () => {
|
|
35
|
-
const result = await isInsideGitRepo(tempDir);
|
|
36
|
-
expect(result).toBe(false);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
it("should return true for directory with .git", async () => {
|
|
40
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
41
|
-
const result = await isInsideGitRepo(tempDir);
|
|
42
|
-
expect(result).toBe(true);
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it("should return true for subdirectory of git repo", async () => {
|
|
46
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
47
|
-
const subDir = path.join(tempDir, "sub", "deep");
|
|
48
|
-
await fs.mkdir(subDir, { recursive: true });
|
|
49
|
-
|
|
50
|
-
const result = await isInsideGitRepo(subDir);
|
|
51
|
-
expect(result).toBe(true);
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
it("should handle .git as file (worktrees)", async () => {
|
|
55
|
-
await fs.writeFile(path.join(tempDir, ".git"), "gitdir: /path/to/git");
|
|
56
|
-
const result = await isInsideGitRepo(tempDir);
|
|
57
|
-
expect(result).toBe(true);
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
describe("getGitRoot", () => {
|
|
62
|
-
it("should return undefined for non-git directory", async () => {
|
|
63
|
-
const result = await getGitRoot(tempDir);
|
|
64
|
-
expect(result).toBe(undefined);
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
it("should return git root for git directory", async () => {
|
|
68
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
69
|
-
const result = await getGitRoot(tempDir);
|
|
70
|
-
expect(result).toBe(tempDir);
|
|
71
|
-
});
|
|
72
|
-
|
|
73
|
-
it("should return git root from subdirectory", async () => {
|
|
74
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
75
|
-
const subDir = path.join(tempDir, "sub", "deep");
|
|
76
|
-
await fs.mkdir(subDir, { recursive: true });
|
|
77
|
-
|
|
78
|
-
const result = await getGitRoot(subDir);
|
|
79
|
-
expect(result).toBe(tempDir);
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
describe("hasSyncConfig", () => {
|
|
84
|
-
it("should return false when no config exists", async () => {
|
|
85
|
-
const result = await hasSyncConfig(tempDir);
|
|
86
|
-
expect(result).toBe(false);
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it("should return false when config has no sync section", async () => {
|
|
90
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
91
|
-
await fs.writeFile(
|
|
92
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
93
|
-
JSON.stringify({ embedding: { provider: "auto" } })
|
|
94
|
-
);
|
|
95
|
-
|
|
96
|
-
const result = await hasSyncConfig(tempDir);
|
|
97
|
-
expect(result).toBe(false);
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it("should return true when sync.enabled is true", async () => {
|
|
101
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
102
|
-
await fs.writeFile(
|
|
103
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
104
|
-
JSON.stringify({ sync: { enabled: true } })
|
|
105
|
-
);
|
|
106
|
-
|
|
107
|
-
const result = await hasSyncConfig(tempDir);
|
|
108
|
-
expect(result).toBe(true);
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it("should return true when sync.path is set", async () => {
|
|
112
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
113
|
-
await fs.writeFile(
|
|
114
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
115
|
-
JSON.stringify({ sync: { path: "myproject/" } })
|
|
116
|
-
);
|
|
117
|
-
|
|
118
|
-
const result = await hasSyncConfig(tempDir);
|
|
119
|
-
expect(result).toBe(true);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
it("should return false when sync.enabled is false and no path", async () => {
|
|
123
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
124
|
-
await fs.writeFile(
|
|
125
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
126
|
-
JSON.stringify({ sync: { enabled: false } })
|
|
127
|
-
);
|
|
128
|
-
|
|
129
|
-
const result = await hasSyncConfig(tempDir);
|
|
130
|
-
expect(result).toBe(false);
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
|
|
134
|
-
describe("detectDirectoryType", () => {
|
|
135
|
-
it("should detect standalone (no git, no sync)", async () => {
|
|
136
|
-
const result = await detectDirectoryType(tempDir);
|
|
137
|
-
expect(result).toBe("standalone");
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
it("should detect project-bound (git, no sync)", async () => {
|
|
141
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
142
|
-
|
|
143
|
-
const result = await detectDirectoryType(tempDir);
|
|
144
|
-
expect(result).toBe("project-bound");
|
|
145
|
-
});
|
|
146
|
-
|
|
147
|
-
it("should detect standalone (no git, sync enabled)", async () => {
|
|
148
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
149
|
-
await fs.writeFile(
|
|
150
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
151
|
-
JSON.stringify({ sync: { enabled: true, path: "test/" } })
|
|
152
|
-
);
|
|
153
|
-
|
|
154
|
-
const result = await detectDirectoryType(tempDir);
|
|
155
|
-
expect(result).toBe("standalone");
|
|
156
|
-
});
|
|
157
|
-
|
|
158
|
-
it("should detect standalone when both git and sync enabled (sync takes precedence)", async () => {
|
|
159
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
160
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
161
|
-
await fs.writeFile(
|
|
162
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
163
|
-
JSON.stringify({ sync: { enabled: true, path: "test/" } })
|
|
164
|
-
);
|
|
165
|
-
|
|
166
|
-
const result = await detectDirectoryType(tempDir);
|
|
167
|
-
// Sync config takes precedence - directory uses minimem sync
|
|
168
|
-
expect(result).toBe("standalone");
|
|
169
|
-
});
|
|
170
|
-
});
|
|
171
|
-
|
|
172
|
-
describe("getDirectoryInfo", () => {
|
|
173
|
-
it("should return full info for directory with both git and sync", async () => {
|
|
174
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
175
|
-
await fs.mkdir(path.join(tempDir, ".minimem"), { recursive: true });
|
|
176
|
-
await fs.writeFile(
|
|
177
|
-
path.join(tempDir, ".minimem", "config.json"),
|
|
178
|
-
JSON.stringify({ sync: { enabled: true, path: "test/" } })
|
|
179
|
-
);
|
|
180
|
-
|
|
181
|
-
const info = await getDirectoryInfo(tempDir);
|
|
182
|
-
|
|
183
|
-
// Sync config takes precedence
|
|
184
|
-
expect(info.type).toBe("standalone");
|
|
185
|
-
expect(info.gitRoot).toBe(tempDir);
|
|
186
|
-
expect(info.hasSyncConfig).toBe(true);
|
|
187
|
-
});
|
|
188
|
-
|
|
189
|
-
it("should return undefined gitRoot for non-git directory", async () => {
|
|
190
|
-
const info = await getDirectoryInfo(tempDir);
|
|
191
|
-
|
|
192
|
-
expect(info.type).toBe("standalone");
|
|
193
|
-
expect(info.gitRoot).toBe(undefined);
|
|
194
|
-
expect(info.hasSyncConfig).toBe(false);
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
it("should return project-bound for git-only directory", async () => {
|
|
198
|
-
await fs.mkdir(path.join(tempDir, ".git"));
|
|
199
|
-
|
|
200
|
-
const info = await getDirectoryInfo(tempDir);
|
|
201
|
-
|
|
202
|
-
expect(info.type).toBe("project-bound");
|
|
203
|
-
expect(info.gitRoot).toBe(tempDir);
|
|
204
|
-
expect(info.hasSyncConfig).toBe(false);
|
|
205
|
-
});
|
|
206
|
-
});
|
|
207
|
-
});
|