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,476 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Integration tests for the git sync system
|
|
3
|
-
*
|
|
4
|
-
* Tests end-to-end workflows including:
|
|
5
|
-
* - Bootstrap flows (central repo creation, sync init)
|
|
6
|
-
* - Push/pull operations with last-write-wins
|
|
7
|
-
* - Change detection
|
|
8
|
-
* - Collision prevention
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import { describe, it, beforeEach, afterEach, expect } from "vitest";
|
|
12
|
-
import fs from "node:fs/promises";
|
|
13
|
-
import path from "node:path";
|
|
14
|
-
import os from "node:os";
|
|
15
|
-
|
|
16
|
-
import { initCentralRepo, validateCentralRepo, getCentralRepoPath } from "../central.js";
|
|
17
|
-
import {
|
|
18
|
-
readRegistry,
|
|
19
|
-
writeRegistry,
|
|
20
|
-
createEmptyRegistry,
|
|
21
|
-
addMapping,
|
|
22
|
-
checkCollision,
|
|
23
|
-
} from "../registry.js";
|
|
24
|
-
import {
|
|
25
|
-
loadSyncState,
|
|
26
|
-
saveSyncState,
|
|
27
|
-
computeFileHash,
|
|
28
|
-
listSyncableFiles,
|
|
29
|
-
} from "../state.js";
|
|
30
|
-
import { detectChanges, quarantineConflict, listQuarantinedConflicts } from "../conflicts.js";
|
|
31
|
-
import { push, pull, bidirectionalSync } from "../operations.js";
|
|
32
|
-
import { validateRegistry } from "../validation.js";
|
|
33
|
-
import { saveConfig, loadXdgConfig, saveXdgConfig } from "../../config.js";
|
|
34
|
-
|
|
35
|
-
describe("Git Sync Integration Tests", () => {
|
|
36
|
-
let tempDir: string;
|
|
37
|
-
let centralRepo: string;
|
|
38
|
-
let localDir1: string;
|
|
39
|
-
let localDir2: string;
|
|
40
|
-
let xdgDir: string;
|
|
41
|
-
|
|
42
|
-
beforeEach(async () => {
|
|
43
|
-
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "minimem-integration-"));
|
|
44
|
-
centralRepo = path.join(tempDir, "central");
|
|
45
|
-
localDir1 = path.join(tempDir, "local1");
|
|
46
|
-
localDir2 = path.join(tempDir, "local2");
|
|
47
|
-
xdgDir = path.join(tempDir, "xdg-config");
|
|
48
|
-
|
|
49
|
-
// Create directories
|
|
50
|
-
await fs.mkdir(localDir1, { recursive: true });
|
|
51
|
-
await fs.mkdir(path.join(localDir1, ".minimem"), { recursive: true });
|
|
52
|
-
await fs.mkdir(path.join(localDir1, "memory"), { recursive: true });
|
|
53
|
-
|
|
54
|
-
await fs.mkdir(localDir2, { recursive: true });
|
|
55
|
-
await fs.mkdir(path.join(localDir2, ".minimem"), { recursive: true });
|
|
56
|
-
await fs.mkdir(path.join(localDir2, "memory"), { recursive: true });
|
|
57
|
-
|
|
58
|
-
// Set up XDG config
|
|
59
|
-
process.env.XDG_CONFIG_HOME = xdgDir;
|
|
60
|
-
await fs.mkdir(path.join(xdgDir, "minimem"), { recursive: true });
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
afterEach(async () => {
|
|
64
|
-
delete process.env.XDG_CONFIG_HOME;
|
|
65
|
-
try {
|
|
66
|
-
await fs.rm(tempDir, { recursive: true, force: true });
|
|
67
|
-
} catch {
|
|
68
|
-
// Ignore cleanup errors
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
describe("Bootstrap Flows", () => {
|
|
73
|
-
it("should create fresh central repository", async () => {
|
|
74
|
-
const result = await initCentralRepo(centralRepo);
|
|
75
|
-
|
|
76
|
-
expect(result.success).toBe(true);
|
|
77
|
-
expect(result.created).toBe(true);
|
|
78
|
-
|
|
79
|
-
const validation = await validateCentralRepo(centralRepo);
|
|
80
|
-
expect(validation.valid).toBe(true);
|
|
81
|
-
|
|
82
|
-
const registry = await readRegistry(centralRepo);
|
|
83
|
-
expect(registry).toBeTruthy();
|
|
84
|
-
expect(registry.mappings.length).toBe(0);
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
it("should set up XDG config with central repo path", async () => {
|
|
88
|
-
await initCentralRepo(centralRepo);
|
|
89
|
-
await saveXdgConfig({ centralRepo, machineId: "test-machine" });
|
|
90
|
-
|
|
91
|
-
const path = await getCentralRepoPath();
|
|
92
|
-
expect(path).toBe(centralRepo);
|
|
93
|
-
});
|
|
94
|
-
|
|
95
|
-
it("should initialize directory for sync", async () => {
|
|
96
|
-
await initCentralRepo(centralRepo);
|
|
97
|
-
await saveXdgConfig({ centralRepo, machineId: "machine-1" });
|
|
98
|
-
|
|
99
|
-
// Create MEMORY.md
|
|
100
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Initial Memory\n");
|
|
101
|
-
|
|
102
|
-
// Configure sync
|
|
103
|
-
await saveConfig(localDir1, {
|
|
104
|
-
sync: {
|
|
105
|
-
enabled: true,
|
|
106
|
-
path: "project1",
|
|
107
|
-
},
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
// Add to registry
|
|
111
|
-
const registry = await readRegistry(centralRepo);
|
|
112
|
-
const updated = addMapping(registry, {
|
|
113
|
-
path: "project1",
|
|
114
|
-
localPath: localDir1,
|
|
115
|
-
machineId: "machine-1",
|
|
116
|
-
lastSync: new Date().toISOString(),
|
|
117
|
-
});
|
|
118
|
-
await writeRegistry(centralRepo, updated);
|
|
119
|
-
|
|
120
|
-
// Verify
|
|
121
|
-
const finalRegistry = await readRegistry(centralRepo);
|
|
122
|
-
expect(finalRegistry.mappings.length).toBe(1);
|
|
123
|
-
// Path may have trailing slash due to normalization
|
|
124
|
-
expect(finalRegistry.mappings[0].path.startsWith("project1")).toBeTruthy();
|
|
125
|
-
});
|
|
126
|
-
|
|
127
|
-
it("should simulate clone setup on new machine", async () => {
|
|
128
|
-
// Setup: machine 1 pushes initial content
|
|
129
|
-
await initCentralRepo(centralRepo);
|
|
130
|
-
await saveXdgConfig({ centralRepo, machineId: "machine-1" });
|
|
131
|
-
|
|
132
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Shared Memory\n");
|
|
133
|
-
await saveConfig(localDir1, { sync: { enabled: true, path: "shared" } });
|
|
134
|
-
|
|
135
|
-
// Create remote directory structure
|
|
136
|
-
const remotePath = path.join(centralRepo, "shared");
|
|
137
|
-
await fs.mkdir(remotePath, { recursive: true });
|
|
138
|
-
await fs.copyFile(path.join(localDir1, "MEMORY.md"), path.join(remotePath, "MEMORY.md"));
|
|
139
|
-
|
|
140
|
-
// Add mapping
|
|
141
|
-
let registry = await readRegistry(centralRepo);
|
|
142
|
-
registry = addMapping(registry, {
|
|
143
|
-
path: "shared",
|
|
144
|
-
localPath: localDir1,
|
|
145
|
-
machineId: "machine-1",
|
|
146
|
-
lastSync: new Date().toISOString(),
|
|
147
|
-
});
|
|
148
|
-
await writeRegistry(centralRepo, registry);
|
|
149
|
-
|
|
150
|
-
// Now: machine 2 sets up and pulls
|
|
151
|
-
await saveXdgConfig({ centralRepo, machineId: "machine-2" });
|
|
152
|
-
await saveConfig(localDir2, { sync: { enabled: true, path: "shared" } });
|
|
153
|
-
|
|
154
|
-
// Pull content
|
|
155
|
-
const result = await pull(localDir2, {});
|
|
156
|
-
|
|
157
|
-
expect(result.pulled.length > 0 || result.skipped.length >= 0).toBeTruthy();
|
|
158
|
-
|
|
159
|
-
// Verify content is available
|
|
160
|
-
const content = await fs.readFile(path.join(localDir2, "MEMORY.md"), "utf-8");
|
|
161
|
-
expect(content.includes("Shared Memory")).toBeTruthy();
|
|
162
|
-
});
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
describe("Sync Operations", () => {
|
|
166
|
-
beforeEach(async () => {
|
|
167
|
-
await initCentralRepo(centralRepo);
|
|
168
|
-
await saveXdgConfig({ centralRepo, machineId: "test-machine" });
|
|
169
|
-
|
|
170
|
-
// Set up local directory with sync config
|
|
171
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Memory\n");
|
|
172
|
-
await saveConfig(localDir1, { sync: { enabled: true, path: "test-project" } });
|
|
173
|
-
|
|
174
|
-
// Create remote directory
|
|
175
|
-
const remotePath = path.join(centralRepo, "test-project");
|
|
176
|
-
await fs.mkdir(remotePath, { recursive: true });
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
it("should push local changes to central", async () => {
|
|
180
|
-
// Initial push
|
|
181
|
-
const result = await push(localDir1, {});
|
|
182
|
-
|
|
183
|
-
expect(result.success).toBe(true);
|
|
184
|
-
expect(result.pushed.includes("MEMORY.md")).toBeTruthy();
|
|
185
|
-
|
|
186
|
-
// Verify file exists in central
|
|
187
|
-
const remotePath = path.join(centralRepo, "test-project", "MEMORY.md");
|
|
188
|
-
const content = await fs.readFile(remotePath, "utf-8");
|
|
189
|
-
expect(content).toBe("# Memory\n");
|
|
190
|
-
});
|
|
191
|
-
|
|
192
|
-
it("should pull remote changes to local", async () => {
|
|
193
|
-
// Set up remote content
|
|
194
|
-
const remotePath = path.join(centralRepo, "test-project");
|
|
195
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "# Remote Memory\n");
|
|
196
|
-
await fs.mkdir(path.join(remotePath, "memory"), { recursive: true });
|
|
197
|
-
await fs.writeFile(path.join(remotePath, "memory", "note.md"), "# Note\n");
|
|
198
|
-
|
|
199
|
-
const result = await pull(localDir1, {});
|
|
200
|
-
|
|
201
|
-
expect(result.success).toBe(true);
|
|
202
|
-
expect(result.pulled.length >= 1).toBeTruthy();
|
|
203
|
-
|
|
204
|
-
// Verify local content
|
|
205
|
-
const content = await fs.readFile(path.join(localDir1, "MEMORY.md"), "utf-8");
|
|
206
|
-
expect(content.includes("Remote Memory") || content.includes("Memory")).toBeTruthy();
|
|
207
|
-
});
|
|
208
|
-
|
|
209
|
-
it("should handle bidirectional sync", async () => {
|
|
210
|
-
// Local has changes
|
|
211
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Local Version\n");
|
|
212
|
-
|
|
213
|
-
// Remote has different file
|
|
214
|
-
const remotePath = path.join(centralRepo, "test-project");
|
|
215
|
-
await fs.mkdir(path.join(remotePath, "memory"), { recursive: true });
|
|
216
|
-
await fs.writeFile(path.join(remotePath, "memory", "remote-note.md"), "# From Remote\n");
|
|
217
|
-
|
|
218
|
-
const result = await bidirectionalSync(localDir1, {});
|
|
219
|
-
|
|
220
|
-
expect(result.success).toBe(true);
|
|
221
|
-
// Should have pushed local changes and pulled remote file
|
|
222
|
-
});
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
describe("Change Detection (Last-Write-Wins)", () => {
|
|
226
|
-
beforeEach(async () => {
|
|
227
|
-
await initCentralRepo(centralRepo);
|
|
228
|
-
await saveXdgConfig({ centralRepo, machineId: "test-machine" });
|
|
229
|
-
|
|
230
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Original\n");
|
|
231
|
-
await saveConfig(localDir1, { sync: { enabled: true, path: "change-test" } });
|
|
232
|
-
|
|
233
|
-
const remotePath = path.join(centralRepo, "change-test");
|
|
234
|
-
await fs.mkdir(remotePath, { recursive: true });
|
|
235
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "# Original\n");
|
|
236
|
-
|
|
237
|
-
// Set up initial sync state
|
|
238
|
-
const hash = await computeFileHash(path.join(localDir1, "MEMORY.md"));
|
|
239
|
-
await saveSyncState(localDir1, {
|
|
240
|
-
version: 2,
|
|
241
|
-
centralPath: "change-test",
|
|
242
|
-
lastSync: new Date().toISOString(),
|
|
243
|
-
files: {
|
|
244
|
-
"MEMORY.md": {
|
|
245
|
-
localHash: hash,
|
|
246
|
-
remoteHash: hash,
|
|
247
|
-
lastModified: new Date().toISOString(),
|
|
248
|
-
},
|
|
249
|
-
},
|
|
250
|
-
});
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
it("should detect changes when both sides modified", async () => {
|
|
254
|
-
// Local change
|
|
255
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Local Change\n");
|
|
256
|
-
|
|
257
|
-
// Remote change
|
|
258
|
-
const remotePath = path.join(centralRepo, "change-test");
|
|
259
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "# Remote Change\n");
|
|
260
|
-
|
|
261
|
-
const detection = await detectChanges(localDir1);
|
|
262
|
-
|
|
263
|
-
// With 2-way comparison, different content = local-modified
|
|
264
|
-
expect(detection.summary.localModified).toBe(1);
|
|
265
|
-
expect(detection.changes.some((c) => c.status === "local-modified")).toBeTruthy();
|
|
266
|
-
});
|
|
267
|
-
|
|
268
|
-
it("should push local changes overwriting remote (last-write-wins)", async () => {
|
|
269
|
-
// Local change
|
|
270
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Local Content\n");
|
|
271
|
-
|
|
272
|
-
// Remote has different content
|
|
273
|
-
const remotePath = path.join(centralRepo, "change-test");
|
|
274
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "# Remote Content\n");
|
|
275
|
-
|
|
276
|
-
// Push overwrites remote
|
|
277
|
-
const result = await push(localDir1, {});
|
|
278
|
-
|
|
279
|
-
expect(result.success).toBe(true);
|
|
280
|
-
expect(result.pushed.includes("MEMORY.md")).toBeTruthy();
|
|
281
|
-
|
|
282
|
-
// Verify remote now has local content
|
|
283
|
-
const remoteContent = await fs.readFile(path.join(remotePath, "MEMORY.md"), "utf-8");
|
|
284
|
-
expect(remoteContent).toBe("# Local Content\n");
|
|
285
|
-
});
|
|
286
|
-
|
|
287
|
-
it("should pull remote changes overwriting local with --force", async () => {
|
|
288
|
-
// Local has changes
|
|
289
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Local Content\n");
|
|
290
|
-
|
|
291
|
-
// Remote has different content
|
|
292
|
-
const remotePath = path.join(centralRepo, "change-test");
|
|
293
|
-
await fs.writeFile(path.join(remotePath, "MEMORY.md"), "# Remote Content\n");
|
|
294
|
-
|
|
295
|
-
// Pull with force overwrites local
|
|
296
|
-
const result = await pull(localDir1, { force: true });
|
|
297
|
-
|
|
298
|
-
expect(result.success).toBe(true);
|
|
299
|
-
expect(result.pulled.includes("MEMORY.md")).toBeTruthy();
|
|
300
|
-
|
|
301
|
-
// Verify local now has remote content
|
|
302
|
-
const localContent = await fs.readFile(path.join(localDir1, "MEMORY.md"), "utf-8");
|
|
303
|
-
expect(localContent).toBe("# Remote Content\n");
|
|
304
|
-
});
|
|
305
|
-
|
|
306
|
-
it("should quarantine files for manual review", async () => {
|
|
307
|
-
const localContent = "Local version";
|
|
308
|
-
const remoteContent = "Remote version";
|
|
309
|
-
|
|
310
|
-
const conflictDir = await quarantineConflict(
|
|
311
|
-
localDir1,
|
|
312
|
-
"MEMORY.md",
|
|
313
|
-
localContent,
|
|
314
|
-
remoteContent
|
|
315
|
-
);
|
|
316
|
-
|
|
317
|
-
expect(conflictDir.includes("conflicts")).toBeTruthy();
|
|
318
|
-
|
|
319
|
-
const quarantined = await listQuarantinedConflicts(localDir1);
|
|
320
|
-
expect(quarantined.length > 0).toBeTruthy();
|
|
321
|
-
expect(quarantined[0].files.includes("MEMORY.md")).toBeTruthy();
|
|
322
|
-
});
|
|
323
|
-
});
|
|
324
|
-
|
|
325
|
-
describe("Collision Prevention", () => {
|
|
326
|
-
beforeEach(async () => {
|
|
327
|
-
await initCentralRepo(centralRepo);
|
|
328
|
-
});
|
|
329
|
-
|
|
330
|
-
it("should block duplicate path mapping from different machines", async () => {
|
|
331
|
-
let registry = createEmptyRegistry();
|
|
332
|
-
|
|
333
|
-
// Machine 1 maps path
|
|
334
|
-
registry = addMapping(registry, {
|
|
335
|
-
path: "shared-project",
|
|
336
|
-
localPath: "/home/user1/project",
|
|
337
|
-
machineId: "machine-1",
|
|
338
|
-
lastSync: new Date().toISOString(),
|
|
339
|
-
});
|
|
340
|
-
|
|
341
|
-
// Machine 2 tries to map same path
|
|
342
|
-
const collision = checkCollision(
|
|
343
|
-
registry,
|
|
344
|
-
"shared-project",
|
|
345
|
-
"/home/user2/project",
|
|
346
|
-
"machine-2"
|
|
347
|
-
);
|
|
348
|
-
|
|
349
|
-
expect(collision).toBe("collision");
|
|
350
|
-
});
|
|
351
|
-
|
|
352
|
-
it("should allow same machine to remap path", async () => {
|
|
353
|
-
let registry = createEmptyRegistry();
|
|
354
|
-
|
|
355
|
-
// Machine 1 maps path
|
|
356
|
-
registry = addMapping(registry, {
|
|
357
|
-
path: "my-project",
|
|
358
|
-
localPath: "/old/path",
|
|
359
|
-
machineId: "machine-1",
|
|
360
|
-
lastSync: new Date().toISOString(),
|
|
361
|
-
});
|
|
362
|
-
|
|
363
|
-
// Same machine remaps
|
|
364
|
-
const collision = checkCollision(
|
|
365
|
-
registry,
|
|
366
|
-
"my-project",
|
|
367
|
-
"/new/path",
|
|
368
|
-
"machine-1"
|
|
369
|
-
);
|
|
370
|
-
|
|
371
|
-
expect(collision).toBe("same-machine");
|
|
372
|
-
});
|
|
373
|
-
|
|
374
|
-
it("should allow different paths for different machines", async () => {
|
|
375
|
-
let registry = createEmptyRegistry();
|
|
376
|
-
|
|
377
|
-
registry = addMapping(registry, {
|
|
378
|
-
path: "project-1",
|
|
379
|
-
localPath: "/path/1",
|
|
380
|
-
machineId: "machine-1",
|
|
381
|
-
lastSync: new Date().toISOString(),
|
|
382
|
-
});
|
|
383
|
-
|
|
384
|
-
const collision = checkCollision(
|
|
385
|
-
registry,
|
|
386
|
-
"project-2",
|
|
387
|
-
"/path/2",
|
|
388
|
-
"machine-2"
|
|
389
|
-
);
|
|
390
|
-
|
|
391
|
-
expect(collision).toBe("none");
|
|
392
|
-
});
|
|
393
|
-
|
|
394
|
-
it("should detect collisions in validation", async () => {
|
|
395
|
-
await saveXdgConfig({ centralRepo, machineId: "machine-1" });
|
|
396
|
-
|
|
397
|
-
let registry = createEmptyRegistry();
|
|
398
|
-
registry.mappings.push({
|
|
399
|
-
path: "shared",
|
|
400
|
-
localPath: "/path1",
|
|
401
|
-
machineId: "machine-1",
|
|
402
|
-
lastSync: new Date().toISOString(),
|
|
403
|
-
});
|
|
404
|
-
registry.mappings.push({
|
|
405
|
-
path: "shared",
|
|
406
|
-
localPath: "/path2",
|
|
407
|
-
machineId: "machine-2",
|
|
408
|
-
lastSync: new Date().toISOString(),
|
|
409
|
-
});
|
|
410
|
-
await writeRegistry(centralRepo, registry);
|
|
411
|
-
|
|
412
|
-
const result = await validateRegistry();
|
|
413
|
-
|
|
414
|
-
expect(result.valid).toBe(false);
|
|
415
|
-
expect(result.stats.collisions).toBe(1);
|
|
416
|
-
});
|
|
417
|
-
});
|
|
418
|
-
|
|
419
|
-
describe("Full Workflow", () => {
|
|
420
|
-
it("should complete full sync workflow", async () => {
|
|
421
|
-
// 1. Initialize central repo
|
|
422
|
-
await initCentralRepo(centralRepo);
|
|
423
|
-
|
|
424
|
-
// 2. Set up machine config
|
|
425
|
-
await saveXdgConfig({ centralRepo, machineId: "dev-machine" });
|
|
426
|
-
|
|
427
|
-
// 3. Create local memory directory with content
|
|
428
|
-
await fs.writeFile(path.join(localDir1, "MEMORY.md"), "# Project Memory\n\nThis is the main memory file.\n");
|
|
429
|
-
await fs.writeFile(path.join(localDir1, "memory", "2024-01-15.md"), "# Daily Log\n\nWorked on feature X.\n");
|
|
430
|
-
|
|
431
|
-
// 4. Configure sync
|
|
432
|
-
await saveConfig(localDir1, {
|
|
433
|
-
sync: {
|
|
434
|
-
enabled: true,
|
|
435
|
-
path: "my-project",
|
|
436
|
-
autoSync: false,
|
|
437
|
-
},
|
|
438
|
-
});
|
|
439
|
-
|
|
440
|
-
// 5. Add to registry
|
|
441
|
-
let registry = await readRegistry(centralRepo);
|
|
442
|
-
registry = addMapping(registry, {
|
|
443
|
-
path: "my-project",
|
|
444
|
-
localPath: localDir1,
|
|
445
|
-
machineId: "dev-machine",
|
|
446
|
-
lastSync: new Date().toISOString(),
|
|
447
|
-
});
|
|
448
|
-
await writeRegistry(centralRepo, registry);
|
|
449
|
-
|
|
450
|
-
// Create remote directory
|
|
451
|
-
const remotePath = path.join(centralRepo, "my-project");
|
|
452
|
-
await fs.mkdir(remotePath, { recursive: true });
|
|
453
|
-
|
|
454
|
-
// 6. Push initial content
|
|
455
|
-
const pushResult = await push(localDir1, {});
|
|
456
|
-
expect(pushResult.success).toBe(true);
|
|
457
|
-
expect(pushResult.pushed.length >= 1).toBeTruthy();
|
|
458
|
-
|
|
459
|
-
// 7. Verify remote content
|
|
460
|
-
const remoteContent = await fs.readFile(path.join(remotePath, "MEMORY.md"), "utf-8");
|
|
461
|
-
expect(remoteContent.includes("Project Memory")).toBeTruthy();
|
|
462
|
-
|
|
463
|
-
// 8. Simulate remote change
|
|
464
|
-
await fs.appendFile(path.join(remotePath, "MEMORY.md"), "\n## New Section\nAdded remotely.\n");
|
|
465
|
-
|
|
466
|
-
// 9. Pull changes - with last-write-wins, this may skip if local has changes
|
|
467
|
-
const pullResult = await pull(localDir1, { force: true });
|
|
468
|
-
// With force, should succeed
|
|
469
|
-
expect(pullResult.success).toBeTruthy();
|
|
470
|
-
|
|
471
|
-
// 10. Validate registry
|
|
472
|
-
const validation = await validateRegistry();
|
|
473
|
-
expect(validation.stats.collisions).toBe(0);
|
|
474
|
-
});
|
|
475
|
-
});
|
|
476
|
-
});
|