opentasks 0.0.4 → 0.0.6
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/README.md +40 -0
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +183 -21
- package/dist/cli.js.map +1 -1
- package/dist/client/client.d.ts.map +1 -1
- package/dist/client/client.js +14 -1
- package/dist/client/client.js.map +1 -1
- package/dist/config/schema.d.ts +139 -3
- package/dist/config/schema.d.ts.map +1 -1
- package/dist/config/schema.js +118 -2
- package/dist/config/schema.js.map +1 -1
- package/dist/core/discover.d.ts.map +1 -1
- package/dist/core/discover.js +55 -39
- package/dist/core/discover.js.map +1 -1
- package/dist/core/init.js +1 -1
- package/dist/core/init.js.map +1 -1
- package/dist/core/merge-driver.d.ts +6 -2
- package/dist/core/merge-driver.d.ts.map +1 -1
- package/dist/core/merge-driver.js +11 -7
- package/dist/core/merge-driver.js.map +1 -1
- package/dist/core/worktree.js +1 -1
- package/dist/core/worktree.js.map +1 -1
- package/dist/daemon/entire-linker.d.ts.map +1 -1
- package/dist/daemon/entire-linker.js +48 -42
- package/dist/daemon/entire-linker.js.map +1 -1
- package/dist/daemon/entire-watcher.d.ts +12 -1
- package/dist/daemon/entire-watcher.d.ts.map +1 -1
- package/dist/daemon/entire-watcher.js +34 -3
- package/dist/daemon/entire-watcher.js.map +1 -1
- package/dist/daemon/ipc.d.ts +9 -1
- package/dist/daemon/ipc.d.ts.map +1 -1
- package/dist/daemon/ipc.js +45 -2
- package/dist/daemon/ipc.js.map +1 -1
- package/dist/daemon/lifecycle.d.ts.map +1 -1
- package/dist/daemon/lifecycle.js +77 -3
- package/dist/daemon/lifecycle.js.map +1 -1
- package/dist/daemon/location-state.d.ts +3 -0
- package/dist/daemon/location-state.d.ts.map +1 -1
- package/dist/daemon/location-state.js +49 -2
- package/dist/daemon/location-state.js.map +1 -1
- package/dist/daemon/methods/watch.d.ts +23 -0
- package/dist/daemon/methods/watch.d.ts.map +1 -0
- package/dist/daemon/methods/watch.js +172 -0
- package/dist/daemon/methods/watch.js.map +1 -0
- package/dist/daemon/registry.d.ts.map +1 -1
- package/dist/daemon/registry.js +2 -1
- package/dist/daemon/registry.js.map +1 -1
- package/dist/entire/index.d.ts +1 -0
- package/dist/entire/index.d.ts.map +1 -1
- package/dist/entire/index.js.map +1 -1
- package/dist/entire/store/native-store.d.ts +1 -1
- package/dist/entire/store/native-store.d.ts.map +1 -1
- package/dist/entire/store/provider-types.d.ts +78 -0
- package/dist/entire/store/provider-types.d.ts.map +1 -0
- package/dist/entire/store/provider-types.js +12 -0
- package/dist/entire/store/provider-types.js.map +1 -0
- package/dist/graph/expansion.d.ts +3 -1
- package/dist/graph/expansion.d.ts.map +1 -1
- package/dist/graph/expansion.js +32 -2
- package/dist/graph/expansion.js.map +1 -1
- package/dist/graph/git-graph-syncer.d.ts +72 -0
- package/dist/graph/git-graph-syncer.d.ts.map +1 -0
- package/dist/graph/git-graph-syncer.js +205 -0
- package/dist/graph/git-graph-syncer.js.map +1 -0
- package/dist/graph/store.d.ts +4 -0
- package/dist/graph/store.d.ts.map +1 -1
- package/dist/graph/store.js +97 -2
- package/dist/graph/store.js.map +1 -1
- package/dist/providers/entire.d.ts +34 -69
- package/dist/providers/entire.d.ts.map +1 -1
- package/dist/providers/entire.js +63 -9
- package/dist/providers/entire.js.map +1 -1
- package/dist/providers/from-config.d.ts +3 -0
- package/dist/providers/from-config.d.ts.map +1 -1
- package/dist/providers/from-config.js +45 -20
- package/dist/providers/from-config.js.map +1 -1
- package/dist/providers/global.d.ts +2 -1
- package/dist/providers/global.d.ts.map +1 -1
- package/dist/providers/global.js +52 -1
- package/dist/providers/global.js.map +1 -1
- package/dist/providers/index.d.ts +3 -0
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +6 -0
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/map-client-factory.d.ts +55 -0
- package/dist/providers/map-client-factory.d.ts.map +1 -0
- package/dist/providers/map-client-factory.js +123 -0
- package/dist/providers/map-client-factory.js.map +1 -0
- package/dist/providers/map-event-bridge.d.ts +146 -0
- package/dist/providers/map-event-bridge.d.ts.map +1 -0
- package/dist/providers/map-event-bridge.js +208 -0
- package/dist/providers/map-event-bridge.js.map +1 -0
- package/dist/providers/map.d.ts +115 -0
- package/dist/providers/map.d.ts.map +1 -0
- package/dist/providers/map.js +376 -0
- package/dist/providers/map.js.map +1 -0
- package/dist/tracking/index.d.ts +0 -4
- package/dist/tracking/index.d.ts.map +1 -1
- package/dist/tracking/index.js +0 -2
- package/dist/tracking/index.js.map +1 -1
- package/dist/tracking/transcript-extractor.d.ts +0 -6
- package/dist/tracking/transcript-extractor.d.ts.map +1 -1
- package/dist/tracking/transcript-extractor.js +3 -12
- package/dist/tracking/transcript-extractor.js.map +1 -1
- package/package.json +3 -1
- package/dist/__tests__/cli-tools.test.d.ts +0 -8
- package/dist/__tests__/cli-tools.test.d.ts.map +0 -1
- package/dist/__tests__/cli-tools.test.js +0 -546
- package/dist/__tests__/cli-tools.test.js.map +0 -1
- package/dist/__tests__/cli.test.d.ts +0 -5
- package/dist/__tests__/cli.test.d.ts.map +0 -1
- package/dist/__tests__/cli.test.js +0 -77
- package/dist/__tests__/cli.test.js.map +0 -1
- package/dist/__tests__/p1-p3-gaps.test.d.ts +0 -2
- package/dist/__tests__/p1-p3-gaps.test.d.ts.map +0 -1
- package/dist/__tests__/p1-p3-gaps.test.js +0 -463
- package/dist/__tests__/p1-p3-gaps.test.js.map +0 -1
- package/dist/client/__tests__/client-crud.test.d.ts +0 -7
- package/dist/client/__tests__/client-crud.test.d.ts.map +0 -1
- package/dist/client/__tests__/client-crud.test.js +0 -404
- package/dist/client/__tests__/client-crud.test.js.map +0 -1
- package/dist/client/__tests__/client.test.d.ts +0 -5
- package/dist/client/__tests__/client.test.d.ts.map +0 -1
- package/dist/client/__tests__/client.test.js +0 -518
- package/dist/client/__tests__/client.test.js.map +0 -1
- package/dist/config/__tests__/defaults.test.d.ts +0 -2
- package/dist/config/__tests__/defaults.test.d.ts.map +0 -1
- package/dist/config/__tests__/defaults.test.js +0 -57
- package/dist/config/__tests__/defaults.test.js.map +0 -1
- package/dist/config/__tests__/env.test.d.ts +0 -2
- package/dist/config/__tests__/env.test.d.ts.map +0 -1
- package/dist/config/__tests__/env.test.js +0 -136
- package/dist/config/__tests__/env.test.js.map +0 -1
- package/dist/config/__tests__/index.test.d.ts +0 -2
- package/dist/config/__tests__/index.test.d.ts.map +0 -1
- package/dist/config/__tests__/index.test.js +0 -113
- package/dist/config/__tests__/index.test.js.map +0 -1
- package/dist/config/__tests__/loader.test.d.ts +0 -2
- package/dist/config/__tests__/loader.test.d.ts.map +0 -1
- package/dist/config/__tests__/loader.test.js +0 -128
- package/dist/config/__tests__/loader.test.js.map +0 -1
- package/dist/config/__tests__/merge.test.d.ts +0 -2
- package/dist/config/__tests__/merge.test.d.ts.map +0 -1
- package/dist/config/__tests__/merge.test.js +0 -79
- package/dist/config/__tests__/merge.test.js.map +0 -1
- package/dist/config/__tests__/schema.test.d.ts +0 -2
- package/dist/config/__tests__/schema.test.d.ts.map +0 -1
- package/dist/config/__tests__/schema.test.js +0 -300
- package/dist/config/__tests__/schema.test.js.map +0 -1
- package/dist/core/__tests__/conditional-redirects.test.d.ts +0 -2
- package/dist/core/__tests__/conditional-redirects.test.d.ts.map +0 -1
- package/dist/core/__tests__/conditional-redirects.test.js +0 -83
- package/dist/core/__tests__/conditional-redirects.test.js.map +0 -1
- package/dist/core/__tests__/connections.test.d.ts +0 -2
- package/dist/core/__tests__/connections.test.d.ts.map +0 -1
- package/dist/core/__tests__/connections.test.js +0 -158
- package/dist/core/__tests__/connections.test.js.map +0 -1
- package/dist/core/__tests__/hash.test.d.ts +0 -2
- package/dist/core/__tests__/hash.test.d.ts.map +0 -1
- package/dist/core/__tests__/hash.test.js +0 -139
- package/dist/core/__tests__/hash.test.js.map +0 -1
- package/dist/core/__tests__/id.test.d.ts +0 -2
- package/dist/core/__tests__/id.test.d.ts.map +0 -1
- package/dist/core/__tests__/id.test.js +0 -142
- package/dist/core/__tests__/id.test.js.map +0 -1
- package/dist/core/__tests__/location.test.d.ts +0 -2
- package/dist/core/__tests__/location.test.d.ts.map +0 -1
- package/dist/core/__tests__/location.test.js +0 -77
- package/dist/core/__tests__/location.test.js.map +0 -1
- package/dist/core/__tests__/merge-driver.test.d.ts +0 -2
- package/dist/core/__tests__/merge-driver.test.d.ts.map +0 -1
- package/dist/core/__tests__/merge-driver.test.js +0 -218
- package/dist/core/__tests__/merge-driver.test.js.map +0 -1
- package/dist/core/__tests__/redirects.test.d.ts +0 -2
- package/dist/core/__tests__/redirects.test.d.ts.map +0 -1
- package/dist/core/__tests__/redirects.test.js +0 -123
- package/dist/core/__tests__/redirects.test.js.map +0 -1
- package/dist/core/__tests__/resolve-location-target.test.d.ts +0 -8
- package/dist/core/__tests__/resolve-location-target.test.d.ts.map +0 -1
- package/dist/core/__tests__/resolve-location-target.test.js +0 -303
- package/dist/core/__tests__/resolve-location-target.test.js.map +0 -1
- package/dist/core/__tests__/uri.test.d.ts +0 -2
- package/dist/core/__tests__/uri.test.d.ts.map +0 -1
- package/dist/core/__tests__/uri.test.js +0 -159
- package/dist/core/__tests__/uri.test.js.map +0 -1
- package/dist/core/__tests__/worktree.test.d.ts +0 -2
- package/dist/core/__tests__/worktree.test.d.ts.map +0 -1
- package/dist/core/__tests__/worktree.test.js +0 -120
- package/dist/core/__tests__/worktree.test.js.map +0 -1
- package/dist/daemon/__tests__/flush.test.d.ts +0 -5
- package/dist/daemon/__tests__/flush.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/flush.test.js +0 -213
- package/dist/daemon/__tests__/flush.test.js.map +0 -1
- package/dist/daemon/__tests__/integration.test.d.ts +0 -7
- package/dist/daemon/__tests__/integration.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/integration.test.js +0 -276
- package/dist/daemon/__tests__/integration.test.js.map +0 -1
- package/dist/daemon/__tests__/ipc.test.d.ts +0 -5
- package/dist/daemon/__tests__/ipc.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/ipc.test.js +0 -314
- package/dist/daemon/__tests__/ipc.test.js.map +0 -1
- package/dist/daemon/__tests__/lifecycle.test.d.ts +0 -5
- package/dist/daemon/__tests__/lifecycle.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/lifecycle.test.js +0 -301
- package/dist/daemon/__tests__/lifecycle.test.js.map +0 -1
- package/dist/daemon/__tests__/lock.test.d.ts +0 -5
- package/dist/daemon/__tests__/lock.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/lock.test.js +0 -192
- package/dist/daemon/__tests__/lock.test.js.map +0 -1
- package/dist/daemon/__tests__/methods/graph.test.d.ts +0 -5
- package/dist/daemon/__tests__/methods/graph.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/methods/graph.test.js +0 -309
- package/dist/daemon/__tests__/methods/graph.test.js.map +0 -1
- package/dist/daemon/__tests__/methods/provider.test.d.ts +0 -7
- package/dist/daemon/__tests__/methods/provider.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/methods/provider.test.js +0 -181
- package/dist/daemon/__tests__/methods/provider.test.js.map +0 -1
- package/dist/daemon/__tests__/methods/tools.test.d.ts +0 -5
- package/dist/daemon/__tests__/methods/tools.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/methods/tools.test.js +0 -587
- package/dist/daemon/__tests__/methods/tools.test.js.map +0 -1
- package/dist/daemon/__tests__/multi-location.test.d.ts +0 -8
- package/dist/daemon/__tests__/multi-location.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/multi-location.test.js +0 -669
- package/dist/daemon/__tests__/multi-location.test.js.map +0 -1
- package/dist/daemon/__tests__/registry.test.d.ts +0 -5
- package/dist/daemon/__tests__/registry.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/registry.test.js +0 -208
- package/dist/daemon/__tests__/registry.test.js.map +0 -1
- package/dist/daemon/__tests__/watcher.test.d.ts +0 -5
- package/dist/daemon/__tests__/watcher.test.d.ts.map +0 -1
- package/dist/daemon/__tests__/watcher.test.js +0 -234
- package/dist/daemon/__tests__/watcher.test.js.map +0 -1
- package/dist/daemon/methods/__tests__/graph.test.d.ts +0 -5
- package/dist/daemon/methods/__tests__/graph.test.d.ts.map +0 -1
- package/dist/daemon/methods/__tests__/graph.test.js +0 -274
- package/dist/daemon/methods/__tests__/graph.test.js.map +0 -1
- package/dist/daemon/methods/__tests__/provider.test.d.ts +0 -5
- package/dist/daemon/methods/__tests__/provider.test.d.ts.map +0 -1
- package/dist/daemon/methods/__tests__/provider.test.js +0 -184
- package/dist/daemon/methods/__tests__/provider.test.js.map +0 -1
- package/dist/daemon/methods/__tests__/tools.test.d.ts +0 -5
- package/dist/daemon/methods/__tests__/tools.test.d.ts.map +0 -1
- package/dist/daemon/methods/__tests__/tools.test.js +0 -295
- package/dist/daemon/methods/__tests__/tools.test.js.map +0 -1
- package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts +0 -2
- package/dist/graph/__tests__/EdgeTypeRegistry.test.d.ts.map +0 -1
- package/dist/graph/__tests__/EdgeTypeRegistry.test.js +0 -212
- package/dist/graph/__tests__/EdgeTypeRegistry.test.js.map +0 -1
- package/dist/graph/__tests__/FederatedGraph.test.d.ts +0 -2
- package/dist/graph/__tests__/FederatedGraph.test.d.ts.map +0 -1
- package/dist/graph/__tests__/FederatedGraph.test.js +0 -661
- package/dist/graph/__tests__/FederatedGraph.test.js.map +0 -1
- package/dist/graph/__tests__/GraphologyAdapter.test.d.ts +0 -2
- package/dist/graph/__tests__/GraphologyAdapter.test.d.ts.map +0 -1
- package/dist/graph/__tests__/GraphologyAdapter.test.js +0 -326
- package/dist/graph/__tests__/GraphologyAdapter.test.js.map +0 -1
- package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts +0 -2
- package/dist/graph/__tests__/HydratingFederatedGraph.test.d.ts.map +0 -1
- package/dist/graph/__tests__/HydratingFederatedGraph.test.js +0 -587
- package/dist/graph/__tests__/HydratingFederatedGraph.test.js.map +0 -1
- package/dist/graph/__tests__/debounce.test.d.ts +0 -5
- package/dist/graph/__tests__/debounce.test.d.ts.map +0 -1
- package/dist/graph/__tests__/debounce.test.js +0 -195
- package/dist/graph/__tests__/debounce.test.js.map +0 -1
- package/dist/graph/__tests__/edge-cases.test.d.ts +0 -8
- package/dist/graph/__tests__/edge-cases.test.d.ts.map +0 -1
- package/dist/graph/__tests__/edge-cases.test.js +0 -472
- package/dist/graph/__tests__/edge-cases.test.js.map +0 -1
- package/dist/graph/__tests__/expansion.test.d.ts +0 -2
- package/dist/graph/__tests__/expansion.test.d.ts.map +0 -1
- package/dist/graph/__tests__/expansion.test.js +0 -105
- package/dist/graph/__tests__/expansion.test.js.map +0 -1
- package/dist/graph/__tests__/provider-store.test.d.ts +0 -5
- package/dist/graph/__tests__/provider-store.test.d.ts.map +0 -1
- package/dist/graph/__tests__/provider-store.test.js +0 -791
- package/dist/graph/__tests__/provider-store.test.js.map +0 -1
- package/dist/graph/__tests__/query.test.d.ts +0 -5
- package/dist/graph/__tests__/query.test.d.ts.map +0 -1
- package/dist/graph/__tests__/query.test.js +0 -774
- package/dist/graph/__tests__/query.test.js.map +0 -1
- package/dist/graph/__tests__/store.test.d.ts +0 -5
- package/dist/graph/__tests__/store.test.d.ts.map +0 -1
- package/dist/graph/__tests__/store.test.js +0 -489
- package/dist/graph/__tests__/store.test.js.map +0 -1
- package/dist/graph/__tests__/sync.test.d.ts +0 -5
- package/dist/graph/__tests__/sync.test.d.ts.map +0 -1
- package/dist/graph/__tests__/sync.test.js +0 -129
- package/dist/graph/__tests__/sync.test.js.map +0 -1
- package/dist/graph/__tests__/validation.test.d.ts +0 -2
- package/dist/graph/__tests__/validation.test.d.ts.map +0 -1
- package/dist/graph/__tests__/validation.test.js +0 -521
- package/dist/graph/__tests__/validation.test.js.map +0 -1
- package/dist/providers/__tests__/beads.test.d.ts +0 -5
- package/dist/providers/__tests__/beads.test.d.ts.map +0 -1
- package/dist/providers/__tests__/beads.test.js +0 -591
- package/dist/providers/__tests__/beads.test.js.map +0 -1
- package/dist/providers/__tests__/claude-tasks.test.d.ts +0 -5
- package/dist/providers/__tests__/claude-tasks.test.d.ts.map +0 -1
- package/dist/providers/__tests__/claude-tasks.test.js +0 -392
- package/dist/providers/__tests__/claude-tasks.test.js.map +0 -1
- package/dist/providers/__tests__/from-config.test.d.ts +0 -5
- package/dist/providers/__tests__/from-config.test.d.ts.map +0 -1
- package/dist/providers/__tests__/from-config.test.js +0 -152
- package/dist/providers/__tests__/from-config.test.js.map +0 -1
- package/dist/providers/__tests__/materialization.test.d.ts +0 -5
- package/dist/providers/__tests__/materialization.test.d.ts.map +0 -1
- package/dist/providers/__tests__/materialization.test.js +0 -407
- package/dist/providers/__tests__/materialization.test.js.map +0 -1
- package/dist/providers/__tests__/native.test.d.ts +0 -5
- package/dist/providers/__tests__/native.test.d.ts.map +0 -1
- package/dist/providers/__tests__/native.test.js +0 -566
- package/dist/providers/__tests__/native.test.js.map +0 -1
- package/dist/providers/__tests__/registry.test.d.ts +0 -5
- package/dist/providers/__tests__/registry.test.d.ts.map +0 -1
- package/dist/providers/__tests__/registry.test.js +0 -183
- package/dist/providers/__tests__/registry.test.js.map +0 -1
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts +0 -2
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.d.ts.map +0 -1
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.js +0 -169
- package/dist/providers/traits/__tests__/RelationshipQueryable.test.js.map +0 -1
- package/dist/providers/traits/__tests__/TaskManageable.test.d.ts +0 -2
- package/dist/providers/traits/__tests__/TaskManageable.test.d.ts.map +0 -1
- package/dist/providers/traits/__tests__/TaskManageable.test.js +0 -172
- package/dist/providers/traits/__tests__/TaskManageable.test.js.map +0 -1
- package/dist/schema/__tests__/validation.test.d.ts +0 -2
- package/dist/schema/__tests__/validation.test.d.ts.map +0 -1
- package/dist/schema/__tests__/validation.test.js +0 -241
- package/dist/schema/__tests__/validation.test.js.map +0 -1
- package/dist/storage/__tests__/atomic-write.test.d.ts +0 -5
- package/dist/storage/__tests__/atomic-write.test.d.ts.map +0 -1
- package/dist/storage/__tests__/atomic-write.test.js +0 -170
- package/dist/storage/__tests__/atomic-write.test.js.map +0 -1
- package/dist/storage/__tests__/file-lock.test.d.ts +0 -2
- package/dist/storage/__tests__/file-lock.test.d.ts.map +0 -1
- package/dist/storage/__tests__/file-lock.test.js +0 -89
- package/dist/storage/__tests__/file-lock.test.js.map +0 -1
- package/dist/storage/__tests__/jsonl.test.d.ts +0 -2
- package/dist/storage/__tests__/jsonl.test.d.ts.map +0 -1
- package/dist/storage/__tests__/jsonl.test.js +0 -228
- package/dist/storage/__tests__/jsonl.test.js.map +0 -1
- package/dist/storage/__tests__/locked-writer.test.d.ts +0 -2
- package/dist/storage/__tests__/locked-writer.test.d.ts.map +0 -1
- package/dist/storage/__tests__/locked-writer.test.js +0 -109
- package/dist/storage/__tests__/locked-writer.test.js.map +0 -1
- package/dist/storage/__tests__/sqlite.test.d.ts +0 -2
- package/dist/storage/__tests__/sqlite.test.d.ts.map +0 -1
- package/dist/storage/__tests__/sqlite.test.js +0 -470
- package/dist/storage/__tests__/sqlite.test.js.map +0 -1
- package/dist/tools/__tests__/annotate.test.d.ts +0 -5
- package/dist/tools/__tests__/annotate.test.d.ts.map +0 -1
- package/dist/tools/__tests__/annotate.test.js +0 -314
- package/dist/tools/__tests__/annotate.test.js.map +0 -1
- package/dist/tools/__tests__/link.test.d.ts +0 -5
- package/dist/tools/__tests__/link.test.d.ts.map +0 -1
- package/dist/tools/__tests__/link.test.js +0 -245
- package/dist/tools/__tests__/link.test.js.map +0 -1
- package/dist/tools/__tests__/query.test.d.ts +0 -5
- package/dist/tools/__tests__/query.test.d.ts.map +0 -1
- package/dist/tools/__tests__/query.test.js +0 -288
- package/dist/tools/__tests__/query.test.js.map +0 -1
- package/dist/tools/__tests__/task.test.d.ts +0 -5
- package/dist/tools/__tests__/task.test.d.ts.map +0 -1
- package/dist/tools/__tests__/task.test.js +0 -178
- package/dist/tools/__tests__/task.test.js.map +0 -1
- package/dist/tracking/claude-task-reconstructor.d.ts +0 -41
- package/dist/tracking/claude-task-reconstructor.d.ts.map +0 -1
- package/dist/tracking/claude-task-reconstructor.js +0 -91
- package/dist/tracking/claude-task-reconstructor.js.map +0 -1
- package/dist/tracking/plan-mode-tracker.d.ts +0 -20
- package/dist/tracking/plan-mode-tracker.d.ts.map +0 -1
- package/dist/tracking/plan-mode-tracker.js +0 -35
- package/dist/tracking/plan-mode-tracker.js.map +0 -1
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { sha256, computeContentHash, contentEqual } from '../hash.js';
|
|
3
|
-
describe('sha256', () => {
|
|
4
|
-
it('produces consistent hash for same input', () => {
|
|
5
|
-
const hash1 = sha256('hello world');
|
|
6
|
-
const hash2 = sha256('hello world');
|
|
7
|
-
expect(hash1).toBe(hash2);
|
|
8
|
-
});
|
|
9
|
-
it('produces different hash for different input', () => {
|
|
10
|
-
const hash1 = sha256('hello');
|
|
11
|
-
const hash2 = sha256('world');
|
|
12
|
-
expect(hash1).not.toBe(hash2);
|
|
13
|
-
});
|
|
14
|
-
it('produces 64-character hex string', () => {
|
|
15
|
-
const hash = sha256('test');
|
|
16
|
-
expect(hash).toHaveLength(64);
|
|
17
|
-
expect(hash).toMatch(/^[0-9a-f]{64}$/);
|
|
18
|
-
});
|
|
19
|
-
});
|
|
20
|
-
describe('computeContentHash', () => {
|
|
21
|
-
const baseNode = {
|
|
22
|
-
id: 's-a2b3',
|
|
23
|
-
uuid: '550e8400-e29b-41d4-a716-446655440000',
|
|
24
|
-
type: 'spec',
|
|
25
|
-
title: 'Test Spec',
|
|
26
|
-
content: 'Some content',
|
|
27
|
-
created_at: '2025-01-26T10:00:00Z',
|
|
28
|
-
updated_at: '2025-01-26T10:00:00Z',
|
|
29
|
-
};
|
|
30
|
-
it('produces consistent hash for same content', () => {
|
|
31
|
-
const hash1 = computeContentHash(baseNode);
|
|
32
|
-
const hash2 = computeContentHash(baseNode);
|
|
33
|
-
expect(hash1).toBe(hash2);
|
|
34
|
-
});
|
|
35
|
-
it('excludes non-substantive fields', () => {
|
|
36
|
-
const node1 = { ...baseNode };
|
|
37
|
-
const node2 = {
|
|
38
|
-
...baseNode,
|
|
39
|
-
id: 's-different',
|
|
40
|
-
uuid: 'different-uuid',
|
|
41
|
-
created_at: '2025-01-27T10:00:00Z',
|
|
42
|
-
updated_at: '2025-01-27T10:00:00Z',
|
|
43
|
-
claimed_by: 'agent-1',
|
|
44
|
-
claimed_at: '2025-01-27T10:00:00Z',
|
|
45
|
-
};
|
|
46
|
-
expect(computeContentHash(node1)).toBe(computeContentHash(node2));
|
|
47
|
-
});
|
|
48
|
-
it('includes substantive fields', () => {
|
|
49
|
-
const node1 = { ...baseNode };
|
|
50
|
-
const node2 = { ...baseNode, title: 'Different Title' };
|
|
51
|
-
const node3 = { ...baseNode, content: 'Different content' };
|
|
52
|
-
const node4 = { ...baseNode, priority: 1 };
|
|
53
|
-
expect(computeContentHash(node1)).not.toBe(computeContentHash(node2));
|
|
54
|
-
expect(computeContentHash(node1)).not.toBe(computeContentHash(node3));
|
|
55
|
-
expect(computeContentHash(node1)).not.toBe(computeContentHash(node4));
|
|
56
|
-
});
|
|
57
|
-
it('handles tags consistently (sorted)', () => {
|
|
58
|
-
const node1 = { ...baseNode, tags: ['b', 'a', 'c'] };
|
|
59
|
-
const node2 = { ...baseNode, tags: ['a', 'b', 'c'] };
|
|
60
|
-
const node3 = { ...baseNode, tags: ['c', 'a', 'b'] };
|
|
61
|
-
expect(computeContentHash(node1)).toBe(computeContentHash(node2));
|
|
62
|
-
expect(computeContentHash(node1)).toBe(computeContentHash(node3));
|
|
63
|
-
});
|
|
64
|
-
it('includes issue-specific fields', () => {
|
|
65
|
-
const issue1 = {
|
|
66
|
-
...baseNode,
|
|
67
|
-
type: 'issue',
|
|
68
|
-
status: 'open',
|
|
69
|
-
assignee: 'user1',
|
|
70
|
-
};
|
|
71
|
-
const issue2 = {
|
|
72
|
-
...baseNode,
|
|
73
|
-
type: 'issue',
|
|
74
|
-
status: 'open',
|
|
75
|
-
assignee: 'user2',
|
|
76
|
-
};
|
|
77
|
-
expect(computeContentHash(issue1)).not.toBe(computeContentHash(issue2));
|
|
78
|
-
});
|
|
79
|
-
it('includes feedback-specific fields', () => {
|
|
80
|
-
const feedback1 = {
|
|
81
|
-
...baseNode,
|
|
82
|
-
type: 'feedback',
|
|
83
|
-
target_id: 's-target1',
|
|
84
|
-
feedback_type: 'comment',
|
|
85
|
-
};
|
|
86
|
-
const feedback2 = {
|
|
87
|
-
...baseNode,
|
|
88
|
-
type: 'feedback',
|
|
89
|
-
target_id: 's-target2',
|
|
90
|
-
feedback_type: 'comment',
|
|
91
|
-
};
|
|
92
|
-
expect(computeContentHash(feedback1)).not.toBe(computeContentHash(feedback2));
|
|
93
|
-
});
|
|
94
|
-
it('includes external-specific fields', () => {
|
|
95
|
-
const external1 = {
|
|
96
|
-
...baseNode,
|
|
97
|
-
type: 'external',
|
|
98
|
-
uri: 'jira://PROJ-123',
|
|
99
|
-
source: 'jira',
|
|
100
|
-
materialized: false,
|
|
101
|
-
};
|
|
102
|
-
const external2 = {
|
|
103
|
-
...baseNode,
|
|
104
|
-
type: 'external',
|
|
105
|
-
uri: 'jira://PROJ-456',
|
|
106
|
-
source: 'jira',
|
|
107
|
-
materialized: false,
|
|
108
|
-
};
|
|
109
|
-
expect(computeContentHash(external1)).not.toBe(computeContentHash(external2));
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
describe('contentEqual', () => {
|
|
113
|
-
const baseNode = {
|
|
114
|
-
id: 's-a2b3',
|
|
115
|
-
uuid: '550e8400-e29b-41d4-a716-446655440000',
|
|
116
|
-
type: 'spec',
|
|
117
|
-
title: 'Test Spec',
|
|
118
|
-
content: 'Some content',
|
|
119
|
-
created_at: '2025-01-26T10:00:00Z',
|
|
120
|
-
updated_at: '2025-01-26T10:00:00Z',
|
|
121
|
-
};
|
|
122
|
-
it('returns true for equal content', () => {
|
|
123
|
-
const node1 = { ...baseNode };
|
|
124
|
-
const node2 = {
|
|
125
|
-
...baseNode,
|
|
126
|
-
id: 's-different',
|
|
127
|
-
uuid: 'different',
|
|
128
|
-
created_at: 'different',
|
|
129
|
-
updated_at: 'different',
|
|
130
|
-
};
|
|
131
|
-
expect(contentEqual(node1, node2)).toBe(true);
|
|
132
|
-
});
|
|
133
|
-
it('returns false for different content', () => {
|
|
134
|
-
const node1 = { ...baseNode };
|
|
135
|
-
const node2 = { ...baseNode, title: 'Different' };
|
|
136
|
-
expect(contentEqual(node1, node2)).toBe(false);
|
|
137
|
-
});
|
|
138
|
-
});
|
|
139
|
-
//# sourceMappingURL=hash.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"hash.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/hash.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"id.test.d.ts","sourceRoot":"","sources":["../../../src/core/__tests__/id.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { generateId, generateIdFromUuid, typePrefix, adaptiveLength, hexToBase36, parseIdPrefix, inferTypeFromId, } from '../id.js';
|
|
3
|
-
describe('typePrefix', () => {
|
|
4
|
-
it('returns correct prefix for each type', () => {
|
|
5
|
-
expect(typePrefix('spec')).toBe('s');
|
|
6
|
-
expect(typePrefix('issue')).toBe('i');
|
|
7
|
-
expect(typePrefix('feedback')).toBe('f');
|
|
8
|
-
expect(typePrefix('external')).toBe('e');
|
|
9
|
-
expect(typePrefix('edge')).toBe('x');
|
|
10
|
-
});
|
|
11
|
-
it('returns "n" for unknown types', () => {
|
|
12
|
-
expect(typePrefix('unknown')).toBe('n');
|
|
13
|
-
expect(typePrefix('custom')).toBe('n');
|
|
14
|
-
});
|
|
15
|
-
});
|
|
16
|
-
describe('adaptiveLength', () => {
|
|
17
|
-
it('returns 4 for small counts', () => {
|
|
18
|
-
expect(adaptiveLength(0)).toBe(4);
|
|
19
|
-
expect(adaptiveLength(100)).toBe(4);
|
|
20
|
-
expect(adaptiveLength(979)).toBe(4);
|
|
21
|
-
});
|
|
22
|
-
it('returns 5 for medium counts', () => {
|
|
23
|
-
expect(adaptiveLength(980)).toBe(5);
|
|
24
|
-
expect(adaptiveLength(3000)).toBe(5);
|
|
25
|
-
expect(adaptiveLength(5899)).toBe(5);
|
|
26
|
-
});
|
|
27
|
-
it('returns 6 for larger counts', () => {
|
|
28
|
-
expect(adaptiveLength(5900)).toBe(6);
|
|
29
|
-
expect(adaptiveLength(20000)).toBe(6);
|
|
30
|
-
expect(adaptiveLength(34999)).toBe(6);
|
|
31
|
-
});
|
|
32
|
-
it('returns 7 for even larger counts', () => {
|
|
33
|
-
expect(adaptiveLength(35000)).toBe(7);
|
|
34
|
-
expect(adaptiveLength(100000)).toBe(7);
|
|
35
|
-
expect(adaptiveLength(211999)).toBe(7);
|
|
36
|
-
});
|
|
37
|
-
it('returns 8 for very large counts', () => {
|
|
38
|
-
expect(adaptiveLength(212000)).toBe(8);
|
|
39
|
-
expect(adaptiveLength(1000000)).toBe(8);
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
describe('hexToBase36', () => {
|
|
43
|
-
it('converts hex to base36', () => {
|
|
44
|
-
// 255 in hex is 'ff', in base36 is '73'
|
|
45
|
-
expect(hexToBase36('ff')).toBe('73');
|
|
46
|
-
// 0 should be '0'
|
|
47
|
-
expect(hexToBase36('0')).toBe('0');
|
|
48
|
-
// 0x1000 = 4096 decimal = 3*36^2 + 5*36 + 28 = 35s in base36
|
|
49
|
-
expect(hexToBase36('1000')).toBe('35s');
|
|
50
|
-
});
|
|
51
|
-
it('produces lowercase output', () => {
|
|
52
|
-
const result = hexToBase36('abcdef');
|
|
53
|
-
expect(result).toBe(result.toLowerCase());
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
describe('generateId', () => {
|
|
57
|
-
it('generates id with correct prefix for spec', () => {
|
|
58
|
-
const { id, uuid } = generateId('spec');
|
|
59
|
-
expect(id).toMatch(/^s-[a-z0-9]{4,}$/);
|
|
60
|
-
expect(uuid).toMatch(/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/);
|
|
61
|
-
});
|
|
62
|
-
it('generates id with correct prefix for issue', () => {
|
|
63
|
-
const { id } = generateId('issue');
|
|
64
|
-
expect(id).toMatch(/^i-[a-z0-9]{4,}$/);
|
|
65
|
-
});
|
|
66
|
-
it('generates id with correct prefix for feedback', () => {
|
|
67
|
-
const { id } = generateId('feedback');
|
|
68
|
-
expect(id).toMatch(/^f-[a-z0-9]{4,}$/);
|
|
69
|
-
});
|
|
70
|
-
it('generates id with correct prefix for external', () => {
|
|
71
|
-
const { id } = generateId('external');
|
|
72
|
-
expect(id).toMatch(/^e-[a-z0-9]{4,}$/);
|
|
73
|
-
});
|
|
74
|
-
it('generates id with correct prefix for edge', () => {
|
|
75
|
-
const { id } = generateId('edge');
|
|
76
|
-
expect(id).toMatch(/^x-[a-z0-9]{4,}$/);
|
|
77
|
-
});
|
|
78
|
-
it('generates unique UUIDs', () => {
|
|
79
|
-
const uuids = new Set();
|
|
80
|
-
for (let i = 0; i < 100; i++) {
|
|
81
|
-
const { uuid } = generateId('issue');
|
|
82
|
-
uuids.add(uuid);
|
|
83
|
-
}
|
|
84
|
-
expect(uuids.size).toBe(100);
|
|
85
|
-
});
|
|
86
|
-
it('respects existingCount for adaptive length', () => {
|
|
87
|
-
const { id: small } = generateId('issue', 0);
|
|
88
|
-
const { id: large } = generateId('issue', 10000);
|
|
89
|
-
// Small count should have shorter hash part
|
|
90
|
-
const smallHash = small.split('-')[1];
|
|
91
|
-
const largeHash = large.split('-')[1];
|
|
92
|
-
expect(smallHash.length).toBe(4);
|
|
93
|
-
expect(largeHash.length).toBe(6);
|
|
94
|
-
});
|
|
95
|
-
});
|
|
96
|
-
describe('generateIdFromUuid', () => {
|
|
97
|
-
it('generates deterministic id from uuid', () => {
|
|
98
|
-
const uuid = '550e8400-e29b-41d4-a716-446655440000';
|
|
99
|
-
const result1 = generateIdFromUuid('issue', uuid);
|
|
100
|
-
const result2 = generateIdFromUuid('issue', uuid);
|
|
101
|
-
expect(result1.id).toBe(result2.id);
|
|
102
|
-
expect(result1.uuid).toBe(uuid);
|
|
103
|
-
});
|
|
104
|
-
it('same uuid produces same hash part', () => {
|
|
105
|
-
const uuid = '550e8400-e29b-41d4-a716-446655440000';
|
|
106
|
-
const spec = generateIdFromUuid('spec', uuid);
|
|
107
|
-
const issue = generateIdFromUuid('issue', uuid);
|
|
108
|
-
// Same hash, different prefix
|
|
109
|
-
expect(spec.id.slice(2)).toBe(issue.id.slice(2));
|
|
110
|
-
expect(spec.id[0]).toBe('s');
|
|
111
|
-
expect(issue.id[0]).toBe('i');
|
|
112
|
-
});
|
|
113
|
-
});
|
|
114
|
-
describe('parseIdPrefix', () => {
|
|
115
|
-
it('extracts prefix from valid ids', () => {
|
|
116
|
-
expect(parseIdPrefix('s-a2b3')).toBe('s');
|
|
117
|
-
expect(parseIdPrefix('i-x7k9pm')).toBe('i');
|
|
118
|
-
expect(parseIdPrefix('f-123')).toBe('f');
|
|
119
|
-
expect(parseIdPrefix('e-abc')).toBe('e');
|
|
120
|
-
expect(parseIdPrefix('x-xyz')).toBe('x');
|
|
121
|
-
});
|
|
122
|
-
it('returns null for invalid format', () => {
|
|
123
|
-
expect(parseIdPrefix('invalid')).toBeNull();
|
|
124
|
-
expect(parseIdPrefix('no-prefix-here')).toBeNull();
|
|
125
|
-
expect(parseIdPrefix('')).toBeNull();
|
|
126
|
-
expect(parseIdPrefix('A-uppercase')).toBeNull();
|
|
127
|
-
});
|
|
128
|
-
});
|
|
129
|
-
describe('inferTypeFromId', () => {
|
|
130
|
-
it('infers correct type from id', () => {
|
|
131
|
-
expect(inferTypeFromId('s-a2b3')).toBe('spec');
|
|
132
|
-
expect(inferTypeFromId('i-x7k9')).toBe('issue');
|
|
133
|
-
expect(inferTypeFromId('f-m4n5')).toBe('feedback');
|
|
134
|
-
expect(inferTypeFromId('e-p6q7')).toBe('external');
|
|
135
|
-
expect(inferTypeFromId('x-r8s9')).toBe('edge');
|
|
136
|
-
});
|
|
137
|
-
it('returns null for unknown prefix', () => {
|
|
138
|
-
expect(inferTypeFromId('z-unknown')).toBeNull();
|
|
139
|
-
expect(inferTypeFromId('invalid')).toBeNull();
|
|
140
|
-
});
|
|
141
|
-
});
|
|
142
|
-
//# sourceMappingURL=id.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"id.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/id.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"location.test.d.ts","sourceRoot":"","sources":["../../../src/core/__tests__/location.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { generateLocationHash, generateLocationHashFallback, generateLocationIdentity, isValidLocationHash, } from '../location.js';
|
|
3
|
-
describe('generateLocationHash', () => {
|
|
4
|
-
it('produces an 8-char base36 string', () => {
|
|
5
|
-
const hash = generateLocationHash('git@github.com:user/repo.git', '.');
|
|
6
|
-
expect(hash).toMatch(/^[a-z0-9]{8}$/);
|
|
7
|
-
});
|
|
8
|
-
it('is deterministic for the same inputs', () => {
|
|
9
|
-
const hash1 = generateLocationHash('git@github.com:user/repo.git', 'packages/app');
|
|
10
|
-
const hash2 = generateLocationHash('git@github.com:user/repo.git', 'packages/app');
|
|
11
|
-
expect(hash1).toBe(hash2);
|
|
12
|
-
});
|
|
13
|
-
it('produces different hashes for different remote URLs', () => {
|
|
14
|
-
const hash1 = generateLocationHash('git@github.com:user/repo-a.git', '.');
|
|
15
|
-
const hash2 = generateLocationHash('git@github.com:user/repo-b.git', '.');
|
|
16
|
-
expect(hash1).not.toBe(hash2);
|
|
17
|
-
});
|
|
18
|
-
it('produces different hashes for different paths', () => {
|
|
19
|
-
const hash1 = generateLocationHash('git@github.com:user/repo.git', 'packages/a');
|
|
20
|
-
const hash2 = generateLocationHash('git@github.com:user/repo.git', 'packages/b');
|
|
21
|
-
expect(hash1).not.toBe(hash2);
|
|
22
|
-
});
|
|
23
|
-
it('normalizes "." to empty string', () => {
|
|
24
|
-
const hash1 = generateLocationHash('git@github.com:user/repo.git', '.');
|
|
25
|
-
const hash2 = generateLocationHash('git@github.com:user/repo.git', '');
|
|
26
|
-
// Both should use empty relative path
|
|
27
|
-
expect(hash1).toBe(hash2);
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
describe('generateLocationHashFallback', () => {
|
|
31
|
-
it('produces an 8-char base36 string', () => {
|
|
32
|
-
const hash = generateLocationHashFallback('/home/user/project/.opentasks');
|
|
33
|
-
expect(hash).toMatch(/^[a-z0-9]{8}$/);
|
|
34
|
-
});
|
|
35
|
-
it('is deterministic for the same path', () => {
|
|
36
|
-
const hash1 = generateLocationHashFallback('/home/user/project/.opentasks');
|
|
37
|
-
const hash2 = generateLocationHashFallback('/home/user/project/.opentasks');
|
|
38
|
-
expect(hash1).toBe(hash2);
|
|
39
|
-
});
|
|
40
|
-
it('produces different hashes for different paths', () => {
|
|
41
|
-
const hash1 = generateLocationHashFallback('/home/user/project-a/.opentasks');
|
|
42
|
-
const hash2 = generateLocationHashFallback('/home/user/project-b/.opentasks');
|
|
43
|
-
expect(hash1).not.toBe(hash2);
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
describe('generateLocationIdentity', () => {
|
|
47
|
-
it('generates identity with hash, uuid, and name', () => {
|
|
48
|
-
const identity = generateLocationIdentity('/tmp/test-project/.opentasks', 'test-project');
|
|
49
|
-
expect(identity.hash).toMatch(/^[a-z0-9]{8}$/);
|
|
50
|
-
expect(identity.uuid).toMatch(/^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/);
|
|
51
|
-
expect(identity.name).toBe('test-project');
|
|
52
|
-
});
|
|
53
|
-
it('generates unique UUIDs on each call', () => {
|
|
54
|
-
const id1 = generateLocationIdentity('/tmp/test-project/.opentasks');
|
|
55
|
-
const id2 = generateLocationIdentity('/tmp/test-project/.opentasks');
|
|
56
|
-
expect(id1.uuid).not.toBe(id2.uuid);
|
|
57
|
-
});
|
|
58
|
-
it('uses directory basename as default name', () => {
|
|
59
|
-
const identity = generateLocationIdentity('/tmp/my-cool-project/.opentasks');
|
|
60
|
-
expect(identity.name).toBe('my-cool-project');
|
|
61
|
-
});
|
|
62
|
-
});
|
|
63
|
-
describe('isValidLocationHash', () => {
|
|
64
|
-
it('validates correct hashes', () => {
|
|
65
|
-
expect(isValidLocationHash('k7m2x9p4')).toBe(true);
|
|
66
|
-
expect(isValidLocationHash('abcdef12')).toBe(true);
|
|
67
|
-
expect(isValidLocationHash('00000000')).toBe(true);
|
|
68
|
-
});
|
|
69
|
-
it('rejects invalid hashes', () => {
|
|
70
|
-
expect(isValidLocationHash('')).toBe(false);
|
|
71
|
-
expect(isValidLocationHash('short')).toBe(false);
|
|
72
|
-
expect(isValidLocationHash('toolongaa')).toBe(false);
|
|
73
|
-
expect(isValidLocationHash('ABCDEFGH')).toBe(false);
|
|
74
|
-
expect(isValidLocationHash('k7m2-9p4')).toBe(false);
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
//# sourceMappingURL=location.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"location.test.js","sourceRoot":"","sources":["../../../src/core/__tests__/location.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"merge-driver.test.d.ts","sourceRoot":"","sources":["../../../src/core/__tests__/merge-driver.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,218 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
2
|
-
import * as fs from 'node:fs';
|
|
3
|
-
import * as path from 'node:path';
|
|
4
|
-
import * as os from 'node:os';
|
|
5
|
-
import { parseJsonlToMap, writeJsonlFromMap, deepEqual, fieldLevelMerge, mergeJsonl, } from '../merge-driver.js';
|
|
6
|
-
let tmpDir;
|
|
7
|
-
beforeEach(() => {
|
|
8
|
-
tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), 'opentasks-merge-test-'));
|
|
9
|
-
});
|
|
10
|
-
afterEach(() => {
|
|
11
|
-
fs.rmSync(tmpDir, { recursive: true, force: true });
|
|
12
|
-
});
|
|
13
|
-
function writeJsonl(name, entries) {
|
|
14
|
-
const filePath = path.join(tmpDir, name);
|
|
15
|
-
const content = entries.map((e) => JSON.stringify(e)).join('\n') + '\n';
|
|
16
|
-
fs.writeFileSync(filePath, content, 'utf-8');
|
|
17
|
-
return filePath;
|
|
18
|
-
}
|
|
19
|
-
describe('deepEqual', () => {
|
|
20
|
-
it('handles primitives', () => {
|
|
21
|
-
expect(deepEqual(1, 1)).toBe(true);
|
|
22
|
-
expect(deepEqual(1, 2)).toBe(false);
|
|
23
|
-
expect(deepEqual('a', 'a')).toBe(true);
|
|
24
|
-
expect(deepEqual(null, null)).toBe(true);
|
|
25
|
-
expect(deepEqual(null, undefined)).toBe(false);
|
|
26
|
-
});
|
|
27
|
-
it('handles arrays', () => {
|
|
28
|
-
expect(deepEqual([1, 2], [1, 2])).toBe(true);
|
|
29
|
-
expect(deepEqual([1, 2], [1, 3])).toBe(false);
|
|
30
|
-
expect(deepEqual([1, 2], [1])).toBe(false);
|
|
31
|
-
});
|
|
32
|
-
it('handles objects', () => {
|
|
33
|
-
expect(deepEqual({ a: 1 }, { a: 1 })).toBe(true);
|
|
34
|
-
expect(deepEqual({ a: 1 }, { a: 2 })).toBe(false);
|
|
35
|
-
expect(deepEqual({ a: 1 }, { a: 1, b: 2 })).toBe(false);
|
|
36
|
-
});
|
|
37
|
-
it('handles nested objects', () => {
|
|
38
|
-
expect(deepEqual({ a: { b: 1 } }, { a: { b: 1 } })).toBe(true);
|
|
39
|
-
expect(deepEqual({ a: { b: 1 } }, { a: { b: 2 } })).toBe(false);
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
describe('parseJsonlToMap', () => {
|
|
43
|
-
it('parses JSONL file into map', () => {
|
|
44
|
-
const filePath = writeJsonl('test.jsonl', [
|
|
45
|
-
{ id: 'i-1', title: 'First', updated_at: '2025-01-01T00:00:00Z' },
|
|
46
|
-
{ id: 'i-2', title: 'Second', updated_at: '2025-01-01T00:00:00Z' },
|
|
47
|
-
]);
|
|
48
|
-
const map = parseJsonlToMap(filePath);
|
|
49
|
-
expect(map.size).toBe(2);
|
|
50
|
-
expect(map.get('i-1')?.title).toBe('First');
|
|
51
|
-
expect(map.get('i-2')?.title).toBe('Second');
|
|
52
|
-
});
|
|
53
|
-
it('deduplicates by latest updated_at', () => {
|
|
54
|
-
const filePath = writeJsonl('test.jsonl', [
|
|
55
|
-
{ id: 'i-1', title: 'Old', updated_at: '2025-01-01T10:00:00Z' },
|
|
56
|
-
{ id: 'i-1', title: 'New', updated_at: '2025-01-01T12:00:00Z' },
|
|
57
|
-
]);
|
|
58
|
-
const map = parseJsonlToMap(filePath);
|
|
59
|
-
expect(map.size).toBe(1);
|
|
60
|
-
expect(map.get('i-1')?.title).toBe('New');
|
|
61
|
-
});
|
|
62
|
-
it('handles non-existent file', () => {
|
|
63
|
-
const map = parseJsonlToMap('/nonexistent/path');
|
|
64
|
-
expect(map.size).toBe(0);
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
describe('writeJsonlFromMap', () => {
|
|
68
|
-
it('writes map to JSONL', () => {
|
|
69
|
-
const map = new Map();
|
|
70
|
-
map.set('i-1', { id: 'i-1', title: 'First' });
|
|
71
|
-
map.set('x-1', { id: 'x-1', from_id: 'i-1', to_id: 'i-2', type: 'blocks' });
|
|
72
|
-
const filePath = path.join(tmpDir, 'output.jsonl');
|
|
73
|
-
writeJsonlFromMap(filePath, map);
|
|
74
|
-
const content = fs.readFileSync(filePath, 'utf-8');
|
|
75
|
-
const lines = content.trim().split('\n');
|
|
76
|
-
// Nodes before edges
|
|
77
|
-
expect(JSON.parse(lines[0]).id).toBe('i-1');
|
|
78
|
-
expect(JSON.parse(lines[1]).id).toBe('x-1');
|
|
79
|
-
});
|
|
80
|
-
});
|
|
81
|
-
describe('fieldLevelMerge', () => {
|
|
82
|
-
it('takes agreed-upon value when both sides match', () => {
|
|
83
|
-
const base = { id: 'i-1', status: 'open', title: 'Test', updated_at: '2025-01-01T00:00:00Z' };
|
|
84
|
-
const ours = { id: 'i-1', status: 'closed', title: 'Test', updated_at: '2025-01-01T01:00:00Z' };
|
|
85
|
-
const theirs = { id: 'i-1', status: 'closed', title: 'Test', updated_at: '2025-01-01T02:00:00Z' };
|
|
86
|
-
const result = fieldLevelMerge(base, ours, theirs);
|
|
87
|
-
expect(result.status).toBe('closed');
|
|
88
|
-
});
|
|
89
|
-
it('takes theirs when only theirs changed', () => {
|
|
90
|
-
const base = { id: 'i-1', status: 'open', title: 'Test', updated_at: '2025-01-01T00:00:00Z' };
|
|
91
|
-
const ours = { id: 'i-1', status: 'open', title: 'Test', updated_at: '2025-01-01T01:00:00Z' };
|
|
92
|
-
const theirs = { id: 'i-1', status: 'in_progress', title: 'Test', updated_at: '2025-01-01T02:00:00Z' };
|
|
93
|
-
const result = fieldLevelMerge(base, ours, theirs);
|
|
94
|
-
expect(result.status).toBe('in_progress');
|
|
95
|
-
});
|
|
96
|
-
it('takes ours when only ours changed', () => {
|
|
97
|
-
const base = { id: 'i-1', status: 'open', title: 'Test', updated_at: '2025-01-01T00:00:00Z' };
|
|
98
|
-
const ours = { id: 'i-1', status: 'closed', title: 'Test', updated_at: '2025-01-01T02:00:00Z' };
|
|
99
|
-
const theirs = { id: 'i-1', status: 'open', title: 'Test', updated_at: '2025-01-01T01:00:00Z' };
|
|
100
|
-
const result = fieldLevelMerge(base, ours, theirs);
|
|
101
|
-
expect(result.status).toBe('closed');
|
|
102
|
-
});
|
|
103
|
-
it('uses last-writer-wins when both changed differently', () => {
|
|
104
|
-
const base = { id: 'i-1', status: 'open', title: 'Test', updated_at: '2025-01-01T00:00:00Z' };
|
|
105
|
-
const ours = { id: 'i-1', status: 'closed', title: 'Test', updated_at: '2025-01-01T01:00:00Z' };
|
|
106
|
-
const theirs = { id: 'i-1', status: 'in_progress', title: 'Test', updated_at: '2025-01-01T02:00:00Z' };
|
|
107
|
-
const result = fieldLevelMerge(base, ours, theirs);
|
|
108
|
-
// theirs has newer updated_at → theirs' value wins
|
|
109
|
-
expect(result.status).toBe('in_progress');
|
|
110
|
-
});
|
|
111
|
-
it('ensures updated_at is the latest', () => {
|
|
112
|
-
const base = { id: 'i-1', updated_at: '2025-01-01T00:00:00Z' };
|
|
113
|
-
const ours = { id: 'i-1', updated_at: '2025-01-01T01:00:00Z' };
|
|
114
|
-
const theirs = { id: 'i-1', updated_at: '2025-01-01T02:00:00Z' };
|
|
115
|
-
const result = fieldLevelMerge(base, ours, theirs);
|
|
116
|
-
expect(result.updated_at).toBe('2025-01-01T02:00:00Z');
|
|
117
|
-
});
|
|
118
|
-
});
|
|
119
|
-
describe('mergeJsonl', () => {
|
|
120
|
-
it('handles no conflicts (only one side changed)', () => {
|
|
121
|
-
const base = writeJsonl('base.jsonl', [
|
|
122
|
-
{ id: 'i-1', status: 'open', title: 'Issue 1', updated_at: '2025-01-01T00:00:00Z' },
|
|
123
|
-
]);
|
|
124
|
-
const ours = writeJsonl('ours.jsonl', [
|
|
125
|
-
{ id: 'i-1', status: 'open', title: 'Issue 1', updated_at: '2025-01-01T00:00:00Z' },
|
|
126
|
-
]);
|
|
127
|
-
const theirs = writeJsonl('theirs.jsonl', [
|
|
128
|
-
{ id: 'i-1', status: 'closed', title: 'Issue 1', updated_at: '2025-01-01T01:00:00Z' },
|
|
129
|
-
]);
|
|
130
|
-
const exitCode = mergeJsonl(base, ours, theirs);
|
|
131
|
-
expect(exitCode).toBe(0);
|
|
132
|
-
// Result should be in "ours" file
|
|
133
|
-
const result = parseJsonlToMap(ours);
|
|
134
|
-
expect(result.get('i-1')?.status).toBe('closed');
|
|
135
|
-
});
|
|
136
|
-
it('handles additions from both sides', () => {
|
|
137
|
-
const base = writeJsonl('base.jsonl', [
|
|
138
|
-
{ id: 'i-1', title: 'Existing', updated_at: '2025-01-01T00:00:00Z' },
|
|
139
|
-
]);
|
|
140
|
-
const ours = writeJsonl('ours.jsonl', [
|
|
141
|
-
{ id: 'i-1', title: 'Existing', updated_at: '2025-01-01T00:00:00Z' },
|
|
142
|
-
{ id: 'i-2', title: 'Our Addition', updated_at: '2025-01-01T01:00:00Z' },
|
|
143
|
-
]);
|
|
144
|
-
const theirs = writeJsonl('theirs.jsonl', [
|
|
145
|
-
{ id: 'i-1', title: 'Existing', updated_at: '2025-01-01T00:00:00Z' },
|
|
146
|
-
{ id: 'i-3', title: 'Their Addition', updated_at: '2025-01-01T01:00:00Z' },
|
|
147
|
-
]);
|
|
148
|
-
const exitCode = mergeJsonl(base, ours, theirs);
|
|
149
|
-
expect(exitCode).toBe(0);
|
|
150
|
-
const result = parseJsonlToMap(ours);
|
|
151
|
-
expect(result.size).toBe(3);
|
|
152
|
-
expect(result.has('i-1')).toBe(true);
|
|
153
|
-
expect(result.has('i-2')).toBe(true);
|
|
154
|
-
expect(result.has('i-3')).toBe(true);
|
|
155
|
-
});
|
|
156
|
-
it('handles true conflict with field-level merge', () => {
|
|
157
|
-
const base = writeJsonl('base.jsonl', [
|
|
158
|
-
{ id: 'i-1', status: 'open', title: 'Original', priority: 1, updated_at: '2025-01-01T00:00:00Z' },
|
|
159
|
-
]);
|
|
160
|
-
const ours = writeJsonl('ours.jsonl', [
|
|
161
|
-
{ id: 'i-1', status: 'closed', title: 'Original', priority: 1, updated_at: '2025-01-01T01:00:00Z' },
|
|
162
|
-
]);
|
|
163
|
-
const theirs = writeJsonl('theirs.jsonl', [
|
|
164
|
-
{ id: 'i-1', status: 'open', title: 'Updated Title', priority: 2, updated_at: '2025-01-01T02:00:00Z' },
|
|
165
|
-
]);
|
|
166
|
-
const exitCode = mergeJsonl(base, ours, theirs);
|
|
167
|
-
expect(exitCode).toBe(0);
|
|
168
|
-
const result = parseJsonlToMap(ours);
|
|
169
|
-
const node = result.get('i-1');
|
|
170
|
-
// status: ours changed to 'closed', theirs kept 'open' → take ours
|
|
171
|
-
expect(node.status).toBe('closed');
|
|
172
|
-
// title: only theirs changed → take theirs
|
|
173
|
-
expect(node.title).toBe('Updated Title');
|
|
174
|
-
// priority: only theirs changed → take theirs
|
|
175
|
-
expect(node.priority).toBe(2);
|
|
176
|
-
});
|
|
177
|
-
it('handles one side deleting, other modifying', () => {
|
|
178
|
-
const base = writeJsonl('base.jsonl', [
|
|
179
|
-
{ id: 'i-1', title: 'Original', updated_at: '2025-01-01T00:00:00Z' },
|
|
180
|
-
]);
|
|
181
|
-
const ours = writeJsonl('ours.jsonl', [
|
|
182
|
-
// i-1 deleted from ours
|
|
183
|
-
]);
|
|
184
|
-
const theirs = writeJsonl('theirs.jsonl', [
|
|
185
|
-
{ id: 'i-1', title: 'Modified', updated_at: '2025-01-01T01:00:00Z' },
|
|
186
|
-
]);
|
|
187
|
-
const exitCode = mergeJsonl(base, ours, theirs);
|
|
188
|
-
expect(exitCode).toBe(0);
|
|
189
|
-
// Should keep the modification
|
|
190
|
-
const result = parseJsonlToMap(ours);
|
|
191
|
-
expect(result.size).toBe(1);
|
|
192
|
-
expect(result.get('i-1')?.title).toBe('Modified');
|
|
193
|
-
});
|
|
194
|
-
it('handles both sides deleting', () => {
|
|
195
|
-
const base = writeJsonl('base.jsonl', [
|
|
196
|
-
{ id: 'i-1', title: 'Original', updated_at: '2025-01-01T00:00:00Z' },
|
|
197
|
-
{ id: 'i-2', title: 'Surviving', updated_at: '2025-01-01T00:00:00Z' },
|
|
198
|
-
]);
|
|
199
|
-
const ours = writeJsonl('ours.jsonl', [
|
|
200
|
-
{ id: 'i-2', title: 'Surviving', updated_at: '2025-01-01T00:00:00Z' },
|
|
201
|
-
]);
|
|
202
|
-
const theirs = writeJsonl('theirs.jsonl', [
|
|
203
|
-
{ id: 'i-2', title: 'Surviving', updated_at: '2025-01-01T00:00:00Z' },
|
|
204
|
-
]);
|
|
205
|
-
const exitCode = mergeJsonl(base, ours, theirs);
|
|
206
|
-
expect(exitCode).toBe(0);
|
|
207
|
-
const result = parseJsonlToMap(ours);
|
|
208
|
-
expect(result.size).toBe(1);
|
|
209
|
-
expect(result.has('i-2')).toBe(true);
|
|
210
|
-
});
|
|
211
|
-
it('returns 0 (always succeeds)', () => {
|
|
212
|
-
const base = writeJsonl('base.jsonl', []);
|
|
213
|
-
const ours = writeJsonl('ours.jsonl', []);
|
|
214
|
-
const theirs = writeJsonl('theirs.jsonl', []);
|
|
215
|
-
expect(mergeJsonl(base, ours, theirs)).toBe(0);
|
|
216
|
-
});
|
|
217
|
-
});
|
|
218
|
-
//# sourceMappingURL=merge-driver.test.js.map
|