document-drive 4.0.1 → 4.1.0-dev.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/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/prisma/schema.prisma +1 -2
- package/dist/src/drive-document-model/gen/document-model.js +3 -3
- package/dist/src/drive-document-model/gen/document-model.js.map +1 -1
- package/dist/src/drive-document-model/gen/drive/actions.d.ts +9 -9
- package/dist/src/drive-document-model/gen/drive/actions.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/node/actions.d.ts +8 -8
- package/dist/src/drive-document-model/gen/node/actions.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/node/creators.d.ts +6 -2
- package/dist/src/drive-document-model/gen/node/creators.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/node/creators.js +8 -1
- package/dist/src/drive-document-model/gen/node/creators.js.map +1 -1
- package/dist/src/drive-document-model/gen/reducer.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/reducer.js.map +1 -1
- package/dist/src/drive-document-model/gen/schema/types.d.ts +1 -14
- package/dist/src/drive-document-model/gen/schema/types.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/schema/zod.d.ts +1 -5
- package/dist/src/drive-document-model/gen/schema/zod.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/schema/zod.js +0 -12
- package/dist/src/drive-document-model/gen/schema/zod.js.map +1 -1
- package/dist/src/drive-document-model/gen/types.d.ts +13 -4
- package/dist/src/drive-document-model/gen/types.d.ts.map +1 -1
- package/dist/src/drive-document-model/gen/types.js.map +1 -1
- package/dist/src/drive-document-model/module.d.ts +2 -1
- package/dist/src/drive-document-model/module.d.ts.map +1 -1
- package/dist/src/drive-document-model/src/reducers/node.d.ts.map +1 -1
- package/dist/src/drive-document-model/src/reducers/node.js +1 -25
- package/dist/src/drive-document-model/src/reducers/node.js.map +1 -1
- package/dist/src/drive-document-model/src/tests/actions.test.js +1 -23
- package/dist/src/drive-document-model/src/tests/actions.test.js.map +1 -1
- package/dist/src/drive-document-model/src/tests/base.test.js +0 -32
- package/dist/src/drive-document-model/src/tests/base.test.js.map +1 -1
- package/dist/src/drive-document-model/src/tests/utils.test.js +7 -37
- package/dist/src/drive-document-model/src/tests/utils.test.js.map +1 -1
- package/dist/src/drive-document-model/src/utils.d.ts +2 -8
- package/dist/src/drive-document-model/src/utils.d.ts.map +1 -1
- package/dist/src/drive-document-model/src/utils.js +6 -55
- package/dist/src/drive-document-model/src/utils.js.map +1 -1
- package/dist/src/processors/types.d.ts +2 -1
- package/dist/src/processors/types.d.ts.map +1 -1
- package/dist/src/queue/base.d.ts +6 -27
- package/dist/src/queue/base.d.ts.map +1 -1
- package/dist/src/queue/base.js +15 -203
- package/dist/src/queue/base.js.map +1 -1
- package/dist/src/queue/event.d.ts +41 -0
- package/dist/src/queue/event.d.ts.map +1 -0
- package/dist/src/queue/event.js +222 -0
- package/dist/src/queue/event.js.map +1 -0
- package/dist/src/queue/redis.d.ts +1 -27
- package/dist/src/queue/redis.d.ts.map +1 -1
- package/dist/src/queue/redis.js +122 -110
- package/dist/src/queue/redis.js.map +1 -1
- package/dist/src/queue/types.d.ts +18 -12
- package/dist/src/queue/types.d.ts.map +1 -1
- package/dist/src/queue/types.js +3 -0
- package/dist/src/queue/types.js.map +1 -1
- package/dist/src/server/base-server.d.ts +87 -11
- package/dist/src/server/base-server.d.ts.map +1 -1
- package/dist/src/server/base-server.js +549 -250
- package/dist/src/server/base-server.js.map +1 -1
- package/dist/src/server/builder.js +2 -2
- package/dist/src/server/builder.js.map +1 -1
- package/dist/src/server/error.d.ts +3 -3
- package/dist/src/server/error.d.ts.map +1 -1
- package/dist/src/server/error.js +2 -2
- package/dist/src/server/error.js.map +1 -1
- package/dist/src/server/listener/listener-manager.d.ts +5 -6
- package/dist/src/server/listener/listener-manager.d.ts.map +1 -1
- package/dist/src/server/listener/listener-manager.js +62 -79
- package/dist/src/server/listener/listener-manager.js.map +1 -1
- package/dist/src/server/listener/transmitter/internal.d.ts +3 -3
- package/dist/src/server/listener/transmitter/internal.d.ts.map +1 -1
- package/dist/src/server/listener/transmitter/internal.js +18 -13
- package/dist/src/server/listener/transmitter/internal.js.map +1 -1
- package/dist/src/server/listener/transmitter/pull-responder.d.ts.map +1 -1
- package/dist/src/server/listener/transmitter/pull-responder.js +14 -8
- package/dist/src/server/listener/transmitter/pull-responder.js.map +1 -1
- package/dist/src/server/listener/transmitter/switchboard-push.d.ts.map +1 -1
- package/dist/src/server/listener/transmitter/switchboard-push.js +13 -8
- package/dist/src/server/listener/transmitter/switchboard-push.js.map +1 -1
- package/dist/src/server/sync-manager.d.ts +8 -10
- package/dist/src/server/sync-manager.d.ts.map +1 -1
- package/dist/src/server/sync-manager.js +62 -147
- package/dist/src/server/sync-manager.js.map +1 -1
- package/dist/src/server/sync-unit-map.d.ts +137 -0
- package/dist/src/server/sync-unit-map.d.ts.map +1 -0
- package/dist/src/server/sync-unit-map.js +234 -0
- package/dist/src/server/sync-unit-map.js.map +1 -0
- package/dist/src/server/types.d.ts +116 -33
- package/dist/src/server/types.d.ts.map +1 -1
- package/dist/src/server/types.js.map +1 -1
- package/dist/src/server/utils.d.ts +10 -1
- package/dist/src/server/utils.d.ts.map +1 -1
- package/dist/src/server/utils.js +44 -1
- package/dist/src/server/utils.js.map +1 -1
- package/dist/src/storage/browser.d.ts +7 -2
- package/dist/src/storage/browser.d.ts.map +1 -1
- package/dist/src/storage/browser.js +80 -22
- package/dist/src/storage/browser.js.map +1 -1
- package/dist/src/storage/filesystem.d.ts +7 -2
- package/dist/src/storage/filesystem.d.ts.map +1 -1
- package/dist/src/storage/filesystem.js +79 -22
- package/dist/src/storage/filesystem.js.map +1 -1
- package/dist/src/storage/memory.d.ts +7 -2
- package/dist/src/storage/memory.d.ts.map +1 -1
- package/dist/src/storage/memory.js +76 -22
- package/dist/src/storage/memory.js.map +1 -1
- package/dist/src/storage/prisma/client/edge.js +5 -4
- package/dist/src/storage/prisma/client/index-browser.js +2 -1
- package/dist/src/storage/prisma/client/index.d.ts +58 -249
- package/dist/src/storage/prisma/client/index.js +5 -4
- package/dist/src/storage/prisma/client/package.json +1 -1
- package/dist/src/storage/prisma/client/schema.prisma +2 -3
- package/dist/src/storage/prisma/client/wasm.js +2 -1
- package/dist/src/storage/prisma/prisma.d.ts +9 -4
- package/dist/src/storage/prisma/prisma.d.ts.map +1 -1
- package/dist/src/storage/prisma/prisma.js +119 -51
- package/dist/src/storage/prisma/prisma.js.map +1 -1
- package/dist/src/storage/types.d.ts +43 -4
- package/dist/src/storage/types.d.ts.map +1 -1
- package/dist/src/storage/utils.d.ts +3 -0
- package/dist/src/storage/utils.d.ts.map +1 -1
- package/dist/src/storage/utils.js +14 -0
- package/dist/src/storage/utils.js.map +1 -1
- package/dist/src/utils/gql-transformations.d.ts +14 -5
- package/dist/src/utils/gql-transformations.d.ts.map +1 -1
- package/dist/src/utils/gql-transformations.js +1 -0
- package/dist/src/utils/gql-transformations.js.map +1 -1
- package/dist/src/utils/migrations.d.ts.map +1 -1
- package/dist/src/utils/migrations.js.map +1 -1
- package/dist/src/utils/misc.d.ts +2 -0
- package/dist/src/utils/misc.d.ts.map +1 -1
- package/dist/src/utils/misc.js +4 -0
- package/dist/src/utils/misc.js.map +1 -1
- package/dist/tsconfig.lib.tsbuildinfo +1 -0
- package/package.json +4 -4
- package/dist/test/cache.test.d.ts +0 -2
- package/dist/test/cache.test.d.ts.map +0 -1
- package/dist/test/cache.test.js +0 -281
- package/dist/test/cache.test.js.map +0 -1
- package/dist/test/default-remote-drives.test.d.ts +0 -2
- package/dist/test/default-remote-drives.test.d.ts.map +0 -1
- package/dist/test/default-remote-drives.test.js +0 -446
- package/dist/test/default-remote-drives.test.js.map +0 -1
- package/dist/test/document-helpers/addUndo.test.d.ts +0 -2
- package/dist/test/document-helpers/addUndo.test.d.ts.map +0 -1
- package/dist/test/document-helpers/addUndo.test.js +0 -120
- package/dist/test/document-helpers/addUndo.test.js.map +0 -1
- package/dist/test/document-helpers/attachBranch.test.d.ts +0 -2
- package/dist/test/document-helpers/attachBranch.test.d.ts.map +0 -1
- package/dist/test/document-helpers/attachBranch.test.js +0 -333
- package/dist/test/document-helpers/attachBranch.test.js.map +0 -1
- package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts +0 -2
- package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts.map +0 -1
- package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js +0 -252
- package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js.map +0 -1
- package/dist/test/document-helpers/garbageCollect.test.d.ts +0 -2
- package/dist/test/document-helpers/garbageCollect.test.d.ts.map +0 -1
- package/dist/test/document-helpers/garbageCollect.test.js +0 -136
- package/dist/test/document-helpers/garbageCollect.test.js.map +0 -1
- package/dist/test/document-helpers/groupOperationsByScope.test.d.ts +0 -2
- package/dist/test/document-helpers/groupOperationsByScope.test.d.ts.map +0 -1
- package/dist/test/document-helpers/groupOperationsByScope.test.js +0 -98
- package/dist/test/document-helpers/groupOperationsByScope.test.js.map +0 -1
- package/dist/test/document-helpers/merge.test.d.ts +0 -2
- package/dist/test/document-helpers/merge.test.d.ts.map +0 -1
- package/dist/test/document-helpers/merge.test.js +0 -757
- package/dist/test/document-helpers/merge.test.js.map +0 -1
- package/dist/test/document-helpers/nextSkipNumber.test.d.ts +0 -2
- package/dist/test/document-helpers/nextSkipNumber.test.d.ts.map +0 -1
- package/dist/test/document-helpers/nextSkipNumber.test.js +0 -123
- package/dist/test/document-helpers/nextSkipNumber.test.js.map +0 -1
- package/dist/test/document-helpers/prepareOperations.test.d.ts +0 -2
- package/dist/test/document-helpers/prepareOperations.test.d.ts.map +0 -1
- package/dist/test/document-helpers/prepareOperations.test.js +0 -304
- package/dist/test/document-helpers/prepareOperations.test.js.map +0 -1
- package/dist/test/document-helpers/removeExistingOperations.test.d.ts +0 -2
- package/dist/test/document-helpers/removeExistingOperations.test.d.ts.map +0 -1
- package/dist/test/document-helpers/removeExistingOperations.test.js +0 -150
- package/dist/test/document-helpers/removeExistingOperations.test.js.map +0 -1
- package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts +0 -2
- package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts.map +0 -1
- package/dist/test/document-helpers/reshuffleByTimestamp.test.js +0 -148
- package/dist/test/document-helpers/reshuffleByTimestamp.test.js.map +0 -1
- package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts +0 -2
- package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts.map +0 -1
- package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js +0 -200
- package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js.map +0 -1
- package/dist/test/document-helpers/sortOperations.test.d.ts +0 -2
- package/dist/test/document-helpers/sortOperations.test.d.ts.map +0 -1
- package/dist/test/document-helpers/sortOperations.test.js +0 -101
- package/dist/test/document-helpers/sortOperations.test.js.map +0 -1
- package/dist/test/document-helpers/split.test.d.ts +0 -2
- package/dist/test/document-helpers/split.test.d.ts.map +0 -1
- package/dist/test/document-helpers/split.test.js +0 -121
- package/dist/test/document-helpers/split.test.js.map +0 -1
- package/dist/test/document-helpers/utils.d.ts +0 -8
- package/dist/test/document-helpers/utils.d.ts.map +0 -1
- package/dist/test/document-helpers/utils.js +0 -22
- package/dist/test/document-helpers/utils.js.map +0 -1
- package/dist/test/drive-operations.test.d.ts +0 -2
- package/dist/test/drive-operations.test.d.ts.map +0 -1
- package/dist/test/drive-operations.test.js +0 -145
- package/dist/test/drive-operations.test.js.map +0 -1
- package/dist/test/graphql.test.d.ts +0 -2
- package/dist/test/graphql.test.d.ts.map +0 -1
- package/dist/test/graphql.test.js +0 -10
- package/dist/test/graphql.test.js.map +0 -1
- package/dist/test/internal-listener.test.d.ts +0 -2
- package/dist/test/internal-listener.test.d.ts.map +0 -1
- package/dist/test/internal-listener.test.js +0 -277
- package/dist/test/internal-listener.test.js.map +0 -1
- package/dist/test/queue.test.d.ts +0 -2
- package/dist/test/queue.test.d.ts.map +0 -1
- package/dist/test/queue.test.js +0 -338
- package/dist/test/queue.test.js.map +0 -1
- package/dist/test/read-mode.test.d.ts +0 -2
- package/dist/test/read-mode.test.d.ts.map +0 -1
- package/dist/test/read-mode.test.js +0 -578
- package/dist/test/read-mode.test.js.map +0 -1
- package/dist/test/server/driveOperationsConflictResolution.test.d.ts +0 -2
- package/dist/test/server/driveOperationsConflictResolution.test.d.ts.map +0 -1
- package/dist/test/server/driveOperationsConflictResolution.test.js +0 -460
- package/dist/test/server/driveOperationsConflictResolution.test.js.map +0 -1
- package/dist/test/server/mergeOperations.test.d.ts +0 -2
- package/dist/test/server/mergeOperations.test.d.ts.map +0 -1
- package/dist/test/server/mergeOperations.test.js +0 -107
- package/dist/test/server/mergeOperations.test.js.map +0 -1
- package/dist/test/server/processOperations.test.d.ts +0 -2
- package/dist/test/server/processOperations.test.d.ts.map +0 -1
- package/dist/test/server/processOperations.test.js +0 -380
- package/dist/test/server/processOperations.test.js.map +0 -1
- package/dist/test/server.test.d.ts +0 -2
- package/dist/test/server.test.d.ts.map +0 -1
- package/dist/test/server.test.js +0 -899
- package/dist/test/server.test.js.map +0 -1
- package/dist/test/signature-migration.test.d.ts +0 -2
- package/dist/test/signature-migration.test.d.ts.map +0 -1
- package/dist/test/signature-migration.test.js +0 -239
- package/dist/test/signature-migration.test.js.map +0 -1
- package/dist/test/storage.test.d.ts +0 -2
- package/dist/test/storage.test.d.ts.map +0 -1
- package/dist/test/storage.test.js +0 -523
- package/dist/test/storage.test.js.map +0 -1
- package/dist/test/utils.d.ts +0 -48
- package/dist/test/utils.d.ts.map +0 -1
- package/dist/test/utils.js +0 -133
- package/dist/test/utils.js.map +0 -1
- package/dist/test/utils.test.d.ts +0 -2
- package/dist/test/utils.test.d.ts.map +0 -1
- package/dist/test/utils.test.js +0 -89
- package/dist/test/utils.test.js.map +0 -1
- package/dist/test/vitest-setup.d.ts +0 -2
- package/dist/test/vitest-setup.d.ts.map +0 -1
- package/dist/test/vitest-setup.js +0 -5
- package/dist/test/vitest-setup.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/dist/vitest.config.d.ts +0 -3
- package/dist/vitest.config.d.ts.map +0 -1
- package/dist/vitest.config.js +0 -27
- package/dist/vitest.config.js.map +0 -1
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"split.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/split.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
import { describe, expect, it } from "vitest";
|
|
2
|
-
import { split } from "../../../document-model/src/document/utils/document-helpers.js";
|
|
3
|
-
import { buildOperation, buildOperations } from "./utils.js";
|
|
4
|
-
describe("split", () => {
|
|
5
|
-
const scenarios = [
|
|
6
|
-
{
|
|
7
|
-
title: "case 1",
|
|
8
|
-
commonOperations: buildOperations([
|
|
9
|
-
{ index: 0, skip: 0, type: "OP_0" },
|
|
10
|
-
{ index: 1, skip: 0, type: "OP_1" },
|
|
11
|
-
]),
|
|
12
|
-
targetOperations: buildOperations([
|
|
13
|
-
{ index: 2, skip: 0, type: "OP_A_2" },
|
|
14
|
-
{ index: 3, skip: 0, type: "OP_A_3" },
|
|
15
|
-
{ index: 4, skip: 0, type: "OP_A_4" },
|
|
16
|
-
{ index: 5, skip: 0, type: "OP_A_5" },
|
|
17
|
-
]),
|
|
18
|
-
mergeOperations: buildOperations([
|
|
19
|
-
{ index: 4, skip: 2, type: "OP_B_4" },
|
|
20
|
-
{ index: 5, skip: 0, type: "OP_B_5" },
|
|
21
|
-
]),
|
|
22
|
-
shuffleProperties: false,
|
|
23
|
-
},
|
|
24
|
-
{
|
|
25
|
-
title: "case 2 (shuffled property orders)",
|
|
26
|
-
commonOperations: buildOperations([
|
|
27
|
-
{ index: 0, skip: 0, type: "OP_0" },
|
|
28
|
-
{ index: 1, skip: 0, type: "OP_1" },
|
|
29
|
-
]),
|
|
30
|
-
targetOperations: buildOperations([
|
|
31
|
-
{ index: 2, skip: 0, type: "OP_A_2" },
|
|
32
|
-
{ index: 3, skip: 0, type: "OP_A_3" },
|
|
33
|
-
{ index: 4, skip: 0, type: "OP_A_4" },
|
|
34
|
-
{ index: 5, skip: 0, type: "OP_A_5" },
|
|
35
|
-
]),
|
|
36
|
-
mergeOperations: buildOperations([
|
|
37
|
-
{ index: 4, skip: 2, type: "OP_B_4" },
|
|
38
|
-
{ index: 5, skip: 0, type: "OP_B_5" },
|
|
39
|
-
]),
|
|
40
|
-
shuffleProperties: true,
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
title: "case 3 (no common operations)",
|
|
44
|
-
commonOperations: buildOperations([]),
|
|
45
|
-
targetOperations: buildOperations([
|
|
46
|
-
{ index: 0, skip: 0, type: "OP_A_0" },
|
|
47
|
-
{ index: 1, skip: 0, type: "OP_A_1" },
|
|
48
|
-
{ index: 2, skip: 0, type: "OP_A_2" },
|
|
49
|
-
]),
|
|
50
|
-
mergeOperations: buildOperations([
|
|
51
|
-
{ index: 1, skip: 1, type: "OP_B_1" },
|
|
52
|
-
{ index: 2, skip: 0, type: "OP_B_2" },
|
|
53
|
-
]),
|
|
54
|
-
shuffleProperties: false,
|
|
55
|
-
},
|
|
56
|
-
{
|
|
57
|
-
title: "case 4 (target operations and merge operations are the same)",
|
|
58
|
-
commonOperations: buildOperations([
|
|
59
|
-
{ index: 0, skip: 0, type: "OP_0" },
|
|
60
|
-
{ index: 1, skip: 0, type: "OP_1" },
|
|
61
|
-
{ index: 3, skip: 0, type: "OP_3" },
|
|
62
|
-
]),
|
|
63
|
-
targetOperations: buildOperations([]),
|
|
64
|
-
mergeOperations: buildOperations([]),
|
|
65
|
-
shuffleProperties: false,
|
|
66
|
-
},
|
|
67
|
-
{
|
|
68
|
-
title: "case 5 (empty operations)",
|
|
69
|
-
commonOperations: buildOperations([]),
|
|
70
|
-
targetOperations: buildOperations([]),
|
|
71
|
-
mergeOperations: buildOperations([]),
|
|
72
|
-
shuffleProperties: false,
|
|
73
|
-
},
|
|
74
|
-
{
|
|
75
|
-
title: "case 6",
|
|
76
|
-
commonOperations: buildOperations([
|
|
77
|
-
{ index: 1, skip: 1, type: "OP_1" },
|
|
78
|
-
{ index: 2, skip: 0, type: "OP_2" },
|
|
79
|
-
{ index: 4, skip: 1, type: "OP_4" },
|
|
80
|
-
]),
|
|
81
|
-
targetOperations: buildOperations([
|
|
82
|
-
{ index: 6, skip: 1, type: "OP_A_6" },
|
|
83
|
-
{ index: 7, skip: 0, type: "OP_A_7" },
|
|
84
|
-
]),
|
|
85
|
-
mergeOperations: buildOperations([
|
|
86
|
-
{ index: 5, skip: 0, type: "OP_B_5" },
|
|
87
|
-
{ index: 7, skip: 1, type: "OP_B_7" },
|
|
88
|
-
]),
|
|
89
|
-
shuffleProperties: false,
|
|
90
|
-
},
|
|
91
|
-
];
|
|
92
|
-
it.each(scenarios)("should split the operations: $title", (testInput) => {
|
|
93
|
-
// assumes that garbageCollect is already applied to the operations
|
|
94
|
-
const targetOperations = [
|
|
95
|
-
...testInput.commonOperations,
|
|
96
|
-
...testInput.targetOperations,
|
|
97
|
-
];
|
|
98
|
-
let commonOperationsShuffled = [];
|
|
99
|
-
if (testInput.shuffleProperties) {
|
|
100
|
-
commonOperationsShuffled = testInput.commonOperations.map((op) => buildOperation({
|
|
101
|
-
type: op.type,
|
|
102
|
-
index: op.index,
|
|
103
|
-
skip: op.skip,
|
|
104
|
-
timestamp: op.timestamp,
|
|
105
|
-
}, true));
|
|
106
|
-
}
|
|
107
|
-
else {
|
|
108
|
-
commonOperationsShuffled = testInput.commonOperations;
|
|
109
|
-
}
|
|
110
|
-
const mergeOperations = [
|
|
111
|
-
...commonOperationsShuffled,
|
|
112
|
-
...testInput.mergeOperations,
|
|
113
|
-
];
|
|
114
|
-
const result = split(targetOperations, mergeOperations);
|
|
115
|
-
expect(result.length).toBe(3);
|
|
116
|
-
expect(result[0]).toMatchObject(testInput.commonOperations);
|
|
117
|
-
expect(result[1]).toMatchObject(testInput.targetOperations);
|
|
118
|
-
expect(result[2]).toMatchObject(testInput.mergeOperations);
|
|
119
|
-
});
|
|
120
|
-
});
|
|
121
|
-
//# sourceMappingURL=split.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"split.test.js","sourceRoot":"","sources":["../../../test/document-helpers/split.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { type Operation } from "document-model";
|
|
2
|
-
export type InputOperation = Partial<Omit<Operation, "index" | "skip">> & {
|
|
3
|
-
index: number;
|
|
4
|
-
skip: number;
|
|
5
|
-
};
|
|
6
|
-
export declare const buildOperation: (input: InputOperation, shuffled?: boolean) => Operation;
|
|
7
|
-
export declare const buildOperations: (inputs: InputOperation[], shuffled?: boolean) => Operation[];
|
|
8
|
-
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,GAAG,MAAM,CAAC,CAAC,GAAG;IACxE,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,eAAO,MAAM,cAAc,GACzB,OAAO,cAAc,EACrB,kBAAgB,KACf,SAoBF,CAAC;AAEF,eAAO,MAAM,eAAe,GAC1B,QAAQ,cAAc,EAAE,EACxB,kBAAgB,KACf,SAAS,EAAoD,CAAC"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
export const buildOperation = (input, shuffled = false) => {
|
|
2
|
-
if (shuffled) {
|
|
3
|
-
return {
|
|
4
|
-
scope: "global",
|
|
5
|
-
type: "TEST",
|
|
6
|
-
timestamp: new Date().toISOString(),
|
|
7
|
-
input: {},
|
|
8
|
-
hash: `hash-${input.index}`,
|
|
9
|
-
...input,
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
return {
|
|
13
|
-
hash: `hash-${input.index}`,
|
|
14
|
-
timestamp: new Date().toISOString(),
|
|
15
|
-
input: {},
|
|
16
|
-
scope: "global",
|
|
17
|
-
type: "TEST",
|
|
18
|
-
...input,
|
|
19
|
-
};
|
|
20
|
-
};
|
|
21
|
-
export const buildOperations = (inputs, shuffled = false) => inputs.map((i) => buildOperation(i, shuffled));
|
|
22
|
-
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../test/document-helpers/utils.ts"],"names":[],"mappings":"AAOA,MAAM,CAAC,MAAM,cAAc,GAAG,CAC5B,KAAqB,EACrB,QAAQ,GAAG,KAAK,EACL,EAAE;IACb,IAAI,QAAQ,EAAE,CAAC;QACb,OAAO;YACL,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;YACnC,KAAK,EAAE,EAAE;YACT,IAAI,EAAE,QAAQ,KAAK,CAAC,KAAK,EAAE;YAC3B,GAAG,KAAK;SACT,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI,EAAE,QAAQ,KAAK,CAAC,KAAK,EAAE;QAC3B,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;QACnC,KAAK,EAAE,EAAE;QACT,KAAK,EAAE,QAAQ;QACf,IAAI,EAAE,MAAM;QACZ,GAAG,KAAK;KACT,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,MAAwB,EACxB,QAAQ,GAAG,KAAK,EACH,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,cAAc,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"drive-operations.test.d.ts","sourceRoot":"","sources":["../../test/drive-operations.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
import { documentModelDocumentModelModule, generateId, } from "document-model";
|
|
2
|
-
import { beforeEach, describe, expect, it } from "vitest";
|
|
3
|
-
import { addFolder, setAvailableOffline, } from "../src/drive-document-model/gen/creators.js";
|
|
4
|
-
import { reducer as documentDriveReducer } from "../src/drive-document-model/gen/reducer.js";
|
|
5
|
-
import { driveDocumentModelModule } from "../src/drive-document-model/module.js";
|
|
6
|
-
import { ReactorBuilder } from "../src/server/builder.js";
|
|
7
|
-
import { MemoryStorage } from "../src/storage/memory.js";
|
|
8
|
-
function buildOperation(document, action, index) {
|
|
9
|
-
const newDocument = documentDriveReducer(document, action);
|
|
10
|
-
const operation = newDocument.operations[action.scope].slice().pop();
|
|
11
|
-
return { ...operation, index: index ?? operation.index };
|
|
12
|
-
}
|
|
13
|
-
function buildOperations(document, actions) {
|
|
14
|
-
const operations = [];
|
|
15
|
-
for (const action of actions) {
|
|
16
|
-
document = documentDriveReducer(document, action);
|
|
17
|
-
const operation = document.operations[action.scope].slice().pop();
|
|
18
|
-
operations.push(operation);
|
|
19
|
-
}
|
|
20
|
-
return operations;
|
|
21
|
-
}
|
|
22
|
-
describe("Drive operations", () => {
|
|
23
|
-
const documentModels = [
|
|
24
|
-
documentModelDocumentModelModule,
|
|
25
|
-
driveDocumentModelModule,
|
|
26
|
-
];
|
|
27
|
-
const storage = new MemoryStorage();
|
|
28
|
-
let server = new ReactorBuilder(documentModels).withStorage(storage).build();
|
|
29
|
-
beforeEach(async () => {
|
|
30
|
-
server = new ReactorBuilder(documentModels).build();
|
|
31
|
-
await server.initialize();
|
|
32
|
-
});
|
|
33
|
-
it("should be able to apply an operation to the drive", async () => {
|
|
34
|
-
const id = generateId();
|
|
35
|
-
await server.addDrive({
|
|
36
|
-
id,
|
|
37
|
-
global: { name: "test" },
|
|
38
|
-
local: {
|
|
39
|
-
availableOffline: false,
|
|
40
|
-
sharingType: "PRIVATE",
|
|
41
|
-
listeners: [],
|
|
42
|
-
triggers: [],
|
|
43
|
-
},
|
|
44
|
-
});
|
|
45
|
-
const drive = await server.getDrive(id);
|
|
46
|
-
const result = await server.addDriveOperation(id, buildOperation(drive, addFolder({ id: "1", name: "test" })));
|
|
47
|
-
expect(result.status).toBe("SUCCESS");
|
|
48
|
-
});
|
|
49
|
-
it("should reject invalid operation", async () => {
|
|
50
|
-
const id = generateId();
|
|
51
|
-
await storage.clear();
|
|
52
|
-
await server.addDrive({
|
|
53
|
-
id,
|
|
54
|
-
global: { name: "test" },
|
|
55
|
-
local: {
|
|
56
|
-
availableOffline: false,
|
|
57
|
-
sharingType: "PRIVATE",
|
|
58
|
-
listeners: [],
|
|
59
|
-
triggers: [],
|
|
60
|
-
},
|
|
61
|
-
});
|
|
62
|
-
const drive = await server.getDrive(id);
|
|
63
|
-
await server.addDriveOperation(id, buildOperation(drive, addFolder({ id: "1", name: "test" })));
|
|
64
|
-
const result = await server.addDriveOperation(id, buildOperation(drive, addFolder({ id: "1", name: "test" }), 1));
|
|
65
|
-
expect(result.status).toBe("SUCCESS");
|
|
66
|
-
expect(result.operations.find((op) => op.error)?.error).toBe("Node with id 1 already exists!");
|
|
67
|
-
});
|
|
68
|
-
it("should reject operation with missing index", async () => {
|
|
69
|
-
const id = generateId();
|
|
70
|
-
await server.addDrive({
|
|
71
|
-
id,
|
|
72
|
-
global: { name: "test" },
|
|
73
|
-
local: {
|
|
74
|
-
availableOffline: false,
|
|
75
|
-
sharingType: "PRIVATE",
|
|
76
|
-
listeners: [],
|
|
77
|
-
triggers: [],
|
|
78
|
-
},
|
|
79
|
-
});
|
|
80
|
-
const drive = await server.getDrive(id);
|
|
81
|
-
await server.addDriveOperation(id, buildOperation(drive, addFolder({ id: "1", name: "test" })));
|
|
82
|
-
const result = await server.addDriveOperation(id, buildOperation(drive, addFolder({ id: "2", name: "test 2" }), 2));
|
|
83
|
-
expect(result.status).toBe("ERROR");
|
|
84
|
-
expect(result.error?.message).toBe("Missing operations: expected 1 with skip 0 or equivalent, got index 2 with skip 0");
|
|
85
|
-
});
|
|
86
|
-
it("should accept operations until invalid operation", async () => {
|
|
87
|
-
const id = generateId();
|
|
88
|
-
await server.addDrive({
|
|
89
|
-
id,
|
|
90
|
-
global: { name: "test" },
|
|
91
|
-
local: {
|
|
92
|
-
availableOffline: false,
|
|
93
|
-
sharingType: "PRIVATE",
|
|
94
|
-
listeners: [],
|
|
95
|
-
triggers: [],
|
|
96
|
-
},
|
|
97
|
-
});
|
|
98
|
-
let drive = await server.getDrive(id);
|
|
99
|
-
const result = await server.addDriveOperations(id, [
|
|
100
|
-
...buildOperations(drive, [
|
|
101
|
-
addFolder({ id: "1", name: "test 1" }),
|
|
102
|
-
addFolder({ id: "2", name: "test 2" }),
|
|
103
|
-
addFolder({ id: "3", name: "test 3" }),
|
|
104
|
-
]),
|
|
105
|
-
buildOperation(drive, addFolder({ id: "4", name: "test 4" }), 4),
|
|
106
|
-
]);
|
|
107
|
-
expect(result.status).toBe("ERROR");
|
|
108
|
-
expect(result.error?.message).toBe("Missing operations: expected 3 with skip 0 or equivalent, got index 4 with skip 0");
|
|
109
|
-
expect(result.operations.length).toBe(3);
|
|
110
|
-
drive = await server.getDrive(id);
|
|
111
|
-
expect(drive.state.global.nodes).toStrictEqual([
|
|
112
|
-
expect.objectContaining({ id: "1", name: "test 1" }),
|
|
113
|
-
expect.objectContaining({ id: "2", name: "test 2" }),
|
|
114
|
-
expect.objectContaining({ id: "3", name: "test 3" }),
|
|
115
|
-
]);
|
|
116
|
-
});
|
|
117
|
-
it("should apply operations with different scopes", async () => {
|
|
118
|
-
const id = generateId();
|
|
119
|
-
await server.addDrive({
|
|
120
|
-
id,
|
|
121
|
-
global: { name: "test" },
|
|
122
|
-
local: {
|
|
123
|
-
availableOffline: false,
|
|
124
|
-
sharingType: "PRIVATE",
|
|
125
|
-
listeners: [],
|
|
126
|
-
triggers: [],
|
|
127
|
-
},
|
|
128
|
-
});
|
|
129
|
-
let drive = await server.getDrive(id);
|
|
130
|
-
const result = await server.addDriveOperations(id, buildOperations(drive, [
|
|
131
|
-
addFolder({ id: "1", name: "test 1" }),
|
|
132
|
-
addFolder({ id: "2", name: "test 2" }),
|
|
133
|
-
setAvailableOffline({ availableOffline: true }),
|
|
134
|
-
]));
|
|
135
|
-
expect(result.status).toBe("SUCCESS");
|
|
136
|
-
expect(result.operations.length).toBe(3);
|
|
137
|
-
drive = await server.getDrive(id);
|
|
138
|
-
expect(drive.state.global.nodes).toStrictEqual([
|
|
139
|
-
expect.objectContaining({ id: "1", name: "test 1" }),
|
|
140
|
-
expect.objectContaining({ id: "2", name: "test 2" }),
|
|
141
|
-
]);
|
|
142
|
-
expect(drive.state.local.availableOffline).toBe(true);
|
|
143
|
-
});
|
|
144
|
-
});
|
|
145
|
-
//# sourceMappingURL=drive-operations.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"drive-operations.test.js","sourceRoot":"","sources":["../../test/drive-operations.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"graphql.test.d.ts","sourceRoot":"","sources":["../../test/graphql.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { describe, it } from "vitest";
|
|
2
|
-
import { driveDocumentModelModule } from "../src/drive-document-model/module.js";
|
|
3
|
-
import { generateDocumentStateQueryFields } from "../src/utils/graphql.js";
|
|
4
|
-
describe("Graphql methods", () => {
|
|
5
|
-
it("should generate document drive query", ({ expect }) => {
|
|
6
|
-
const schema = generateDocumentStateQueryFields(driveDocumentModelModule.documentModel, "");
|
|
7
|
-
expect(schema).toEqual("name nodes { ... on FolderNode { id name kind parentFolder } ... on FileNode { id name kind documentType parentFolder synchronizationUnits { syncId scope branch } } } icon");
|
|
8
|
-
});
|
|
9
|
-
});
|
|
10
|
-
//# sourceMappingURL=graphql.test.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"graphql.test.js","sourceRoot":"","sources":["../../test/graphql.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,wBAAwB,EAAE,MAAM,uCAAuC,CAAC;AACjF,OAAO,EAAE,gCAAgC,EAAE,MAAM,yBAAyB,CAAC;AAE3E,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,sCAAsC,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;QACxD,MAAM,MAAM,GAAG,gCAAgC,CAC7C,wBAAwB,CAAC,aAAa,EACtC,EAAE,CACH,CAAC;QACF,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CACpB,6KAA6K,CAC9K,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"internal-listener.test.d.ts","sourceRoot":"","sources":["../../test/internal-listener.test.ts"],"names":[],"mappings":""}
|
|
@@ -1,277 +0,0 @@
|
|
|
1
|
-
import { generateId, setModelName } from "document-model";
|
|
2
|
-
import { beforeEach, describe, expect, test, vi, vitest } from "vitest";
|
|
3
|
-
import { generateAddNodeAction } from "../src/drive-document-model/src/utils.js";
|
|
4
|
-
import { ReactorBuilder } from "../src/server/builder.js";
|
|
5
|
-
import { InternalTransmitter, } from "../src/server/listener/transmitter/internal.js";
|
|
6
|
-
import { expectUTCTimestamp, expectUUID } from "./utils.js";
|
|
7
|
-
import { documentModelDocumentModelModule } from "document-model";
|
|
8
|
-
import { driveDocumentModelModule } from "../src/drive-document-model/module.js";
|
|
9
|
-
describe("Internal Listener", () => {
|
|
10
|
-
const documentModels = [
|
|
11
|
-
documentModelDocumentModelModule,
|
|
12
|
-
driveDocumentModelModule,
|
|
13
|
-
];
|
|
14
|
-
const driveId = generateId();
|
|
15
|
-
async function buildServer(processor) {
|
|
16
|
-
const builder = new ReactorBuilder(documentModels);
|
|
17
|
-
const server = builder.build();
|
|
18
|
-
await server.initialize();
|
|
19
|
-
await server.addDrive({
|
|
20
|
-
id: driveId,
|
|
21
|
-
global: {
|
|
22
|
-
name: "Global Drive",
|
|
23
|
-
icon: "",
|
|
24
|
-
},
|
|
25
|
-
local: {
|
|
26
|
-
availableOffline: false,
|
|
27
|
-
listeners: [],
|
|
28
|
-
sharingType: "private",
|
|
29
|
-
triggers: [],
|
|
30
|
-
},
|
|
31
|
-
});
|
|
32
|
-
const listenerManager = builder.listenerManager;
|
|
33
|
-
// Create the listener and transmitter
|
|
34
|
-
const uuid = generateId();
|
|
35
|
-
const listener = {
|
|
36
|
-
driveId,
|
|
37
|
-
listenerId: uuid,
|
|
38
|
-
block: false,
|
|
39
|
-
filter: {
|
|
40
|
-
branch: ["main"],
|
|
41
|
-
documentId: ["*"],
|
|
42
|
-
documentType: ["*"],
|
|
43
|
-
scope: ["global"],
|
|
44
|
-
},
|
|
45
|
-
system: false,
|
|
46
|
-
label: `Internal #${uuid}`,
|
|
47
|
-
callInfo: {
|
|
48
|
-
data: "",
|
|
49
|
-
name: "Internal",
|
|
50
|
-
transmitterType: "Internal",
|
|
51
|
-
},
|
|
52
|
-
};
|
|
53
|
-
// TODO: circular reference
|
|
54
|
-
listener.transmitter = new InternalTransmitter(server, processor);
|
|
55
|
-
await listenerManager?.setListener(driveId, listener);
|
|
56
|
-
return server;
|
|
57
|
-
}
|
|
58
|
-
beforeEach(() => {
|
|
59
|
-
vi.setSystemTime(new Date("2024-01-01"));
|
|
60
|
-
});
|
|
61
|
-
test("should call transmit function of listener and acknowledge", async () => {
|
|
62
|
-
const transmitFn = vitest.fn(() => {
|
|
63
|
-
return Promise.resolve();
|
|
64
|
-
});
|
|
65
|
-
const server = await buildServer({
|
|
66
|
-
onStrands: transmitFn,
|
|
67
|
-
onDisconnect: () => Promise.resolve(),
|
|
68
|
-
});
|
|
69
|
-
const drive = await server.getDrive(driveId);
|
|
70
|
-
const documentId = generateId();
|
|
71
|
-
const action = generateAddNodeAction(drive.state.global, {
|
|
72
|
-
id: documentId,
|
|
73
|
-
name: "test",
|
|
74
|
-
documentType: "powerhouse/document-model",
|
|
75
|
-
}, ["global", "local"]);
|
|
76
|
-
await server.addDriveAction(driveId, action);
|
|
77
|
-
await vi.waitFor(() => expect(transmitFn).toHaveBeenCalledTimes(1));
|
|
78
|
-
const update = {
|
|
79
|
-
branch: "main",
|
|
80
|
-
documentId: driveId,
|
|
81
|
-
driveId,
|
|
82
|
-
documentType: "powerhouse/document-drive",
|
|
83
|
-
operations: [
|
|
84
|
-
{
|
|
85
|
-
hash: expect.any(String),
|
|
86
|
-
context: undefined,
|
|
87
|
-
id: expectUUID(expect),
|
|
88
|
-
index: 0,
|
|
89
|
-
input: action.input,
|
|
90
|
-
skip: 0,
|
|
91
|
-
timestamp: "2024-01-01T00:00:00.000Z",
|
|
92
|
-
type: "ADD_FILE",
|
|
93
|
-
state: {
|
|
94
|
-
icon: "",
|
|
95
|
-
name: "Global Drive",
|
|
96
|
-
nodes: [
|
|
97
|
-
{
|
|
98
|
-
documentType: "powerhouse/document-model",
|
|
99
|
-
id: documentId,
|
|
100
|
-
kind: "file",
|
|
101
|
-
name: "test",
|
|
102
|
-
parentFolder: null,
|
|
103
|
-
synchronizationUnits: [
|
|
104
|
-
{
|
|
105
|
-
branch: "main",
|
|
106
|
-
scope: "global",
|
|
107
|
-
syncId: expectUUID(expect),
|
|
108
|
-
},
|
|
109
|
-
{
|
|
110
|
-
branch: "main",
|
|
111
|
-
scope: "local",
|
|
112
|
-
syncId: expectUUID(expect),
|
|
113
|
-
},
|
|
114
|
-
],
|
|
115
|
-
},
|
|
116
|
-
],
|
|
117
|
-
},
|
|
118
|
-
previousState: {
|
|
119
|
-
icon: "",
|
|
120
|
-
name: "Global Drive",
|
|
121
|
-
nodes: [],
|
|
122
|
-
},
|
|
123
|
-
},
|
|
124
|
-
],
|
|
125
|
-
state: {
|
|
126
|
-
icon: "",
|
|
127
|
-
name: "Global Drive",
|
|
128
|
-
nodes: [
|
|
129
|
-
{
|
|
130
|
-
documentType: "powerhouse/document-model",
|
|
131
|
-
id: documentId,
|
|
132
|
-
kind: "file",
|
|
133
|
-
name: "test",
|
|
134
|
-
parentFolder: null,
|
|
135
|
-
synchronizationUnits: [
|
|
136
|
-
{
|
|
137
|
-
branch: "main",
|
|
138
|
-
scope: "global",
|
|
139
|
-
syncId: action.input.synchronizationUnits[0]?.syncId,
|
|
140
|
-
},
|
|
141
|
-
{
|
|
142
|
-
branch: "main",
|
|
143
|
-
scope: "local",
|
|
144
|
-
syncId: action.input.synchronizationUnits[1]?.syncId,
|
|
145
|
-
},
|
|
146
|
-
],
|
|
147
|
-
},
|
|
148
|
-
],
|
|
149
|
-
},
|
|
150
|
-
scope: "global",
|
|
151
|
-
};
|
|
152
|
-
expect(transmitFn).toHaveBeenCalledWith([update]);
|
|
153
|
-
await server.addAction(driveId, documentId, setModelName({ name: "test" }));
|
|
154
|
-
await vi.waitFor(() => expect(transmitFn).toHaveBeenCalledTimes(2));
|
|
155
|
-
const state = {
|
|
156
|
-
author: {
|
|
157
|
-
name: "",
|
|
158
|
-
website: "",
|
|
159
|
-
},
|
|
160
|
-
description: "",
|
|
161
|
-
extension: "",
|
|
162
|
-
id: "",
|
|
163
|
-
name: "test",
|
|
164
|
-
specifications: [
|
|
165
|
-
{
|
|
166
|
-
changeLog: [],
|
|
167
|
-
modules: [],
|
|
168
|
-
state: {
|
|
169
|
-
global: {
|
|
170
|
-
examples: [],
|
|
171
|
-
initialValue: "",
|
|
172
|
-
schema: "",
|
|
173
|
-
},
|
|
174
|
-
local: {
|
|
175
|
-
examples: [],
|
|
176
|
-
initialValue: "",
|
|
177
|
-
schema: "",
|
|
178
|
-
},
|
|
179
|
-
},
|
|
180
|
-
version: 1,
|
|
181
|
-
},
|
|
182
|
-
],
|
|
183
|
-
};
|
|
184
|
-
expect(transmitFn).toHaveBeenLastCalledWith([
|
|
185
|
-
{
|
|
186
|
-
branch: "main",
|
|
187
|
-
documentId,
|
|
188
|
-
driveId,
|
|
189
|
-
documentType: "powerhouse/document-model",
|
|
190
|
-
operations: [
|
|
191
|
-
{
|
|
192
|
-
hash: "nWKpqR6ns0l8C/Khwrl+SyKy0sA=",
|
|
193
|
-
context: undefined,
|
|
194
|
-
id: expectUUID(expect),
|
|
195
|
-
index: 0,
|
|
196
|
-
input: {
|
|
197
|
-
name: "test",
|
|
198
|
-
},
|
|
199
|
-
skip: 0,
|
|
200
|
-
timestamp: expectUTCTimestamp(expect),
|
|
201
|
-
type: "SET_MODEL_NAME",
|
|
202
|
-
previousState: { ...state, name: "" },
|
|
203
|
-
state,
|
|
204
|
-
},
|
|
205
|
-
],
|
|
206
|
-
state,
|
|
207
|
-
scope: "global",
|
|
208
|
-
},
|
|
209
|
-
]);
|
|
210
|
-
await server.addAction(driveId, documentId, setModelName({ name: "test 2" }));
|
|
211
|
-
await vi.waitFor(() => expect(transmitFn).toHaveBeenCalledTimes(3));
|
|
212
|
-
expect(transmitFn).toHaveBeenLastCalledWith([
|
|
213
|
-
{
|
|
214
|
-
branch: "main",
|
|
215
|
-
documentId,
|
|
216
|
-
driveId,
|
|
217
|
-
documentType: "powerhouse/document-model",
|
|
218
|
-
operations: [
|
|
219
|
-
{
|
|
220
|
-
hash: "s7RBcer0JqjSGvNb12gqpeeJGRY=",
|
|
221
|
-
context: undefined,
|
|
222
|
-
id: expectUUID(expect),
|
|
223
|
-
index: 1,
|
|
224
|
-
input: {
|
|
225
|
-
name: "test 2",
|
|
226
|
-
},
|
|
227
|
-
skip: 0,
|
|
228
|
-
timestamp: expectUTCTimestamp(expect),
|
|
229
|
-
type: "SET_MODEL_NAME",
|
|
230
|
-
previousState: state,
|
|
231
|
-
state: { ...state, name: "test 2" },
|
|
232
|
-
},
|
|
233
|
-
],
|
|
234
|
-
state: {
|
|
235
|
-
author: {
|
|
236
|
-
name: "",
|
|
237
|
-
website: "",
|
|
238
|
-
},
|
|
239
|
-
description: "",
|
|
240
|
-
extension: "",
|
|
241
|
-
id: "",
|
|
242
|
-
name: "test 2",
|
|
243
|
-
specifications: [
|
|
244
|
-
{
|
|
245
|
-
changeLog: [],
|
|
246
|
-
modules: [],
|
|
247
|
-
state: {
|
|
248
|
-
global: {
|
|
249
|
-
examples: [],
|
|
250
|
-
initialValue: "",
|
|
251
|
-
schema: "",
|
|
252
|
-
},
|
|
253
|
-
local: {
|
|
254
|
-
examples: [],
|
|
255
|
-
initialValue: "",
|
|
256
|
-
schema: "",
|
|
257
|
-
},
|
|
258
|
-
},
|
|
259
|
-
version: 1,
|
|
260
|
-
},
|
|
261
|
-
],
|
|
262
|
-
},
|
|
263
|
-
scope: "global",
|
|
264
|
-
},
|
|
265
|
-
]);
|
|
266
|
-
});
|
|
267
|
-
test("should call disconnect function of processor", async () => {
|
|
268
|
-
const disconnectFn = vitest.fn(() => Promise.resolve());
|
|
269
|
-
const server = await buildServer({
|
|
270
|
-
onStrands: () => Promise.resolve(),
|
|
271
|
-
onDisconnect: disconnectFn,
|
|
272
|
-
});
|
|
273
|
-
await server.deleteDrive(driveId);
|
|
274
|
-
expect(disconnectFn).toHaveBeenCalled();
|
|
275
|
-
});
|
|
276
|
-
});
|
|
277
|
-
//# sourceMappingURL=internal-listener.test.js.map
|