document-drive 1.29.12-dev.0 → 1.29.12-dev.10

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.
Files changed (286) hide show
  1. package/README.md +6 -6
  2. package/dist/index.d.ts +5 -3
  3. package/dist/index.d.ts.map +1 -1
  4. package/dist/index.js +4 -3
  5. package/dist/index.js.map +1 -1
  6. package/dist/src/cache/memory.js +1 -1
  7. package/dist/src/cache/memory.js.map +1 -1
  8. package/dist/src/cache/redis.js +1 -1
  9. package/dist/src/cache/redis.js.map +1 -1
  10. package/dist/src/cache/util.d.ts.map +1 -1
  11. package/dist/src/drive-document-model/constants.d.ts +1 -1
  12. package/dist/src/drive-document-model/constants.d.ts.map +1 -1
  13. package/dist/src/drive-document-model/constants.js +2 -1
  14. package/dist/src/drive-document-model/constants.js.map +1 -1
  15. package/dist/src/drive-document-model/gen/actions.d.ts +4 -5
  16. package/dist/src/drive-document-model/gen/actions.d.ts.map +1 -1
  17. package/dist/src/drive-document-model/gen/actions.js +1 -1
  18. package/dist/src/drive-document-model/gen/actions.js.map +1 -1
  19. package/dist/src/drive-document-model/gen/creators.d.ts +1 -1
  20. package/dist/src/drive-document-model/gen/creators.d.ts.map +1 -1
  21. package/dist/src/drive-document-model/gen/creators.js +1 -1
  22. package/dist/src/drive-document-model/gen/creators.js.map +1 -1
  23. package/dist/src/drive-document-model/gen/document-model.d.ts +1 -1
  24. package/dist/src/drive-document-model/gen/document-model.d.ts.map +1 -1
  25. package/dist/src/drive-document-model/gen/document-model.js +7 -8
  26. package/dist/src/drive-document-model/gen/document-model.js.map +1 -1
  27. package/dist/src/drive-document-model/gen/drive/actions.d.ts +2 -2
  28. package/dist/src/drive-document-model/gen/drive/actions.d.ts.map +1 -1
  29. package/dist/src/drive-document-model/gen/drive/creators.d.ts +2 -2
  30. package/dist/src/drive-document-model/gen/drive/creators.d.ts.map +1 -1
  31. package/dist/src/drive-document-model/gen/drive/creators.js +9 -9
  32. package/dist/src/drive-document-model/gen/drive/creators.js.map +1 -1
  33. package/dist/src/drive-document-model/gen/drive/object.d.ts +2 -2
  34. package/dist/src/drive-document-model/gen/drive/object.d.ts.map +1 -1
  35. package/dist/src/drive-document-model/gen/drive/object.js +1 -1
  36. package/dist/src/drive-document-model/gen/drive/object.js.map +1 -1
  37. package/dist/src/drive-document-model/gen/drive/operations.d.ts +3 -3
  38. package/dist/src/drive-document-model/gen/drive/operations.d.ts.map +1 -1
  39. package/dist/src/drive-document-model/gen/index.d.ts +6 -0
  40. package/dist/src/drive-document-model/gen/index.d.ts.map +1 -0
  41. package/dist/src/drive-document-model/gen/index.js +6 -0
  42. package/dist/src/drive-document-model/gen/index.js.map +1 -0
  43. package/dist/src/drive-document-model/gen/node/actions.d.ts +2 -2
  44. package/dist/src/drive-document-model/gen/node/actions.d.ts.map +1 -1
  45. package/dist/src/drive-document-model/gen/node/creators.d.ts +2 -2
  46. package/dist/src/drive-document-model/gen/node/creators.d.ts.map +1 -1
  47. package/dist/src/drive-document-model/gen/node/creators.js +8 -8
  48. package/dist/src/drive-document-model/gen/node/creators.js.map +1 -1
  49. package/dist/src/drive-document-model/gen/node/object.d.ts +2 -2
  50. package/dist/src/drive-document-model/gen/node/object.d.ts.map +1 -1
  51. package/dist/src/drive-document-model/gen/node/object.js +1 -1
  52. package/dist/src/drive-document-model/gen/node/object.js.map +1 -1
  53. package/dist/src/drive-document-model/gen/node/operations.d.ts +3 -3
  54. package/dist/src/drive-document-model/gen/node/operations.d.ts.map +1 -1
  55. package/dist/src/drive-document-model/gen/object.d.ts +11 -14
  56. package/dist/src/drive-document-model/gen/object.d.ts.map +1 -1
  57. package/dist/src/drive-document-model/gen/object.js +11 -12
  58. package/dist/src/drive-document-model/gen/object.js.map +1 -1
  59. package/dist/src/drive-document-model/gen/reducer.d.ts +1 -1
  60. package/dist/src/drive-document-model/gen/reducer.d.ts.map +1 -1
  61. package/dist/src/drive-document-model/gen/reducer.js +16 -16
  62. package/dist/src/drive-document-model/gen/reducer.js.map +1 -1
  63. package/dist/src/drive-document-model/gen/schema/index.d.ts +3 -0
  64. package/dist/src/drive-document-model/gen/schema/index.d.ts.map +1 -0
  65. package/dist/src/drive-document-model/gen/schema/index.js +3 -0
  66. package/dist/src/drive-document-model/gen/schema/index.js.map +1 -0
  67. package/dist/src/drive-document-model/gen/schema/types.d.ts +88 -1
  68. package/dist/src/drive-document-model/gen/schema/types.d.ts.map +1 -1
  69. package/dist/src/drive-document-model/gen/schema/zod.d.ts +1 -1
  70. package/dist/src/drive-document-model/gen/schema/zod.d.ts.map +1 -1
  71. package/dist/src/drive-document-model/gen/schema/zod.js +0 -2
  72. package/dist/src/drive-document-model/gen/schema/zod.js.map +1 -1
  73. package/dist/src/drive-document-model/gen/types.d.ts +5 -4
  74. package/dist/src/drive-document-model/gen/types.d.ts.map +1 -1
  75. package/dist/src/drive-document-model/gen/types.js +1 -1
  76. package/dist/src/drive-document-model/gen/types.js.map +1 -1
  77. package/dist/src/drive-document-model/gen/utils.d.ts +9 -9
  78. package/dist/src/drive-document-model/gen/utils.d.ts.map +1 -1
  79. package/dist/src/drive-document-model/gen/utils.js +39 -23
  80. package/dist/src/drive-document-model/gen/utils.js.map +1 -1
  81. package/dist/src/drive-document-model/module.d.ts +26 -2
  82. package/dist/src/drive-document-model/module.d.ts.map +1 -1
  83. package/dist/src/drive-document-model/module.js +14 -8
  84. package/dist/src/drive-document-model/module.js.map +1 -1
  85. package/dist/src/drive-document-model/src/tests/actions.test.d.ts +2 -0
  86. package/dist/src/drive-document-model/src/tests/actions.test.d.ts.map +1 -0
  87. package/dist/src/drive-document-model/src/tests/actions.test.js +221 -0
  88. package/dist/src/drive-document-model/src/tests/actions.test.js.map +1 -0
  89. package/dist/src/drive-document-model/src/tests/base.test.d.ts +2 -0
  90. package/dist/src/drive-document-model/src/tests/base.test.d.ts.map +1 -0
  91. package/dist/src/drive-document-model/src/tests/base.test.js +116 -0
  92. package/dist/src/drive-document-model/src/tests/base.test.js.map +1 -0
  93. package/dist/src/drive-document-model/src/tests/document-model.test.d.ts +6 -0
  94. package/dist/src/drive-document-model/src/tests/document-model.test.d.ts.map +1 -0
  95. package/dist/src/drive-document-model/src/tests/document-model.test.js +19 -0
  96. package/dist/src/drive-document-model/src/tests/document-model.test.js.map +1 -0
  97. package/dist/src/drive-document-model/src/tests/drive.test.d.ts +6 -0
  98. package/dist/src/drive-document-model/src/tests/drive.test.d.ts.map +1 -0
  99. package/dist/src/drive-document-model/src/tests/drive.test.js +41 -0
  100. package/dist/src/drive-document-model/src/tests/drive.test.js.map +1 -0
  101. package/dist/src/drive-document-model/src/tests/node.test.d.ts +6 -0
  102. package/dist/src/drive-document-model/src/tests/node.test.d.ts.map +1 -0
  103. package/dist/src/drive-document-model/src/tests/node.test.js +376 -0
  104. package/dist/src/drive-document-model/src/tests/node.test.js.map +1 -0
  105. package/dist/src/drive-document-model/src/tests/utils.test.d.ts +2 -0
  106. package/dist/src/drive-document-model/src/tests/utils.test.d.ts.map +1 -0
  107. package/dist/src/drive-document-model/src/tests/utils.test.js +262 -0
  108. package/dist/src/drive-document-model/src/tests/utils.test.js.map +1 -0
  109. package/dist/src/read-mode/service.d.ts.map +1 -1
  110. package/dist/src/read-mode/service.js +8 -1
  111. package/dist/src/read-mode/service.js.map +1 -1
  112. package/dist/src/server/base-server.d.ts +6 -3
  113. package/dist/src/server/base-server.d.ts.map +1 -1
  114. package/dist/src/server/base-server.js +51 -20
  115. package/dist/src/server/base-server.js.map +1 -1
  116. package/dist/src/server/listener/listener-manager.d.ts +2 -0
  117. package/dist/src/server/listener/listener-manager.d.ts.map +1 -1
  118. package/dist/src/server/listener/listener-manager.js +4 -0
  119. package/dist/src/server/listener/listener-manager.js.map +1 -1
  120. package/dist/src/server/listener/transmitter/factory.d.ts.map +1 -1
  121. package/dist/src/server/listener/transmitter/factory.js +1 -1
  122. package/dist/src/server/listener/transmitter/factory.js.map +1 -1
  123. package/dist/src/server/listener/transmitter/pull-responder.d.ts +7 -5
  124. package/dist/src/server/listener/transmitter/pull-responder.d.ts.map +1 -1
  125. package/dist/src/server/listener/transmitter/pull-responder.js +145 -17
  126. package/dist/src/server/listener/transmitter/pull-responder.js.map +1 -1
  127. package/dist/src/server/listener/transmitter/switchboard-push.d.ts +5 -2
  128. package/dist/src/server/listener/transmitter/switchboard-push.d.ts.map +1 -1
  129. package/dist/src/server/listener/transmitter/switchboard-push.js +37 -6
  130. package/dist/src/server/listener/transmitter/switchboard-push.js.map +1 -1
  131. package/dist/src/server/listener/util.d.ts.map +1 -1
  132. package/dist/src/server/types.d.ts +16 -5
  133. package/dist/src/server/types.d.ts.map +1 -1
  134. package/dist/src/server/types.js.map +1 -1
  135. package/dist/src/storage/browser.d.ts +1 -1
  136. package/dist/src/storage/browser.d.ts.map +1 -1
  137. package/dist/src/storage/browser.js +2 -1
  138. package/dist/src/storage/browser.js.map +1 -1
  139. package/dist/src/storage/filesystem.d.ts +1 -1
  140. package/dist/src/storage/filesystem.d.ts.map +1 -1
  141. package/dist/src/storage/filesystem.js +2 -1
  142. package/dist/src/storage/filesystem.js.map +1 -1
  143. package/dist/src/storage/ipfs.d.ts +1 -1
  144. package/dist/src/storage/ipfs.d.ts.map +1 -1
  145. package/dist/src/storage/ipfs.js +2 -1
  146. package/dist/src/storage/ipfs.js.map +1 -1
  147. package/dist/src/storage/memory.d.ts +1 -1
  148. package/dist/src/storage/memory.d.ts.map +1 -1
  149. package/dist/src/storage/memory.js +2 -1
  150. package/dist/src/storage/memory.js.map +1 -1
  151. package/dist/src/storage/prisma/prisma.d.ts +1 -1
  152. package/dist/src/storage/prisma/prisma.d.ts.map +1 -1
  153. package/dist/src/storage/prisma/prisma.js +5 -3
  154. package/dist/src/storage/prisma/prisma.js.map +1 -1
  155. package/dist/src/storage/types.d.ts +1 -1
  156. package/dist/src/storage/types.d.ts.map +1 -1
  157. package/dist/src/storage/utils.d.ts +2 -2
  158. package/dist/src/storage/utils.d.ts.map +1 -1
  159. package/dist/src/storage/utils.js +2 -2
  160. package/dist/src/storage/utils.js.map +1 -1
  161. package/dist/src/utils/default-drives-manager.d.ts.map +1 -1
  162. package/dist/src/utils/default-drives-manager.js +11 -9
  163. package/dist/src/utils/default-drives-manager.js.map +1 -1
  164. package/dist/src/utils/graphql.d.ts +8 -4
  165. package/dist/src/utils/graphql.d.ts.map +1 -1
  166. package/dist/src/utils/graphql.js +27 -14
  167. package/dist/src/utils/graphql.js.map +1 -1
  168. package/dist/src/utils/logger.d.ts.map +1 -1
  169. package/dist/test/cache.test.d.ts +2 -0
  170. package/dist/test/cache.test.d.ts.map +1 -0
  171. package/dist/test/cache.test.js +281 -0
  172. package/dist/test/cache.test.js.map +1 -0
  173. package/dist/test/default-remote-drives.test.d.ts +2 -0
  174. package/dist/test/default-remote-drives.test.d.ts.map +1 -0
  175. package/dist/test/default-remote-drives.test.js +446 -0
  176. package/dist/test/default-remote-drives.test.js.map +1 -0
  177. package/dist/test/document-helpers/addUndo.test.d.ts +2 -0
  178. package/dist/test/document-helpers/addUndo.test.d.ts.map +1 -0
  179. package/dist/test/document-helpers/addUndo.test.js +120 -0
  180. package/dist/test/document-helpers/addUndo.test.js.map +1 -0
  181. package/dist/test/document-helpers/attachBranch.test.d.ts +2 -0
  182. package/dist/test/document-helpers/attachBranch.test.d.ts.map +1 -0
  183. package/dist/test/document-helpers/attachBranch.test.js +333 -0
  184. package/dist/test/document-helpers/attachBranch.test.js.map +1 -0
  185. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts +2 -0
  186. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts.map +1 -0
  187. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js +252 -0
  188. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js.map +1 -0
  189. package/dist/test/document-helpers/garbageCollect.test.d.ts +2 -0
  190. package/dist/test/document-helpers/garbageCollect.test.d.ts.map +1 -0
  191. package/dist/test/document-helpers/garbageCollect.test.js +136 -0
  192. package/dist/test/document-helpers/garbageCollect.test.js.map +1 -0
  193. package/dist/test/document-helpers/groupOperationsByScope.test.d.ts +2 -0
  194. package/dist/test/document-helpers/groupOperationsByScope.test.d.ts.map +1 -0
  195. package/dist/test/document-helpers/groupOperationsByScope.test.js +98 -0
  196. package/dist/test/document-helpers/groupOperationsByScope.test.js.map +1 -0
  197. package/dist/test/document-helpers/merge.test.d.ts +2 -0
  198. package/dist/test/document-helpers/merge.test.d.ts.map +1 -0
  199. package/dist/test/document-helpers/merge.test.js +757 -0
  200. package/dist/test/document-helpers/merge.test.js.map +1 -0
  201. package/dist/test/document-helpers/nextSkipNumber.test.d.ts +2 -0
  202. package/dist/test/document-helpers/nextSkipNumber.test.d.ts.map +1 -0
  203. package/dist/test/document-helpers/nextSkipNumber.test.js +123 -0
  204. package/dist/test/document-helpers/nextSkipNumber.test.js.map +1 -0
  205. package/dist/test/document-helpers/prepareOperations.test.d.ts +2 -0
  206. package/dist/test/document-helpers/prepareOperations.test.d.ts.map +1 -0
  207. package/dist/test/document-helpers/prepareOperations.test.js +304 -0
  208. package/dist/test/document-helpers/prepareOperations.test.js.map +1 -0
  209. package/dist/test/document-helpers/removeExistingOperations.test.d.ts +2 -0
  210. package/dist/test/document-helpers/removeExistingOperations.test.d.ts.map +1 -0
  211. package/dist/test/document-helpers/removeExistingOperations.test.js +150 -0
  212. package/dist/test/document-helpers/removeExistingOperations.test.js.map +1 -0
  213. package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts +2 -0
  214. package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts.map +1 -0
  215. package/dist/test/document-helpers/reshuffleByTimestamp.test.js +148 -0
  216. package/dist/test/document-helpers/reshuffleByTimestamp.test.js.map +1 -0
  217. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts +2 -0
  218. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts.map +1 -0
  219. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js +200 -0
  220. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js.map +1 -0
  221. package/dist/test/document-helpers/sortOperations.test.d.ts +2 -0
  222. package/dist/test/document-helpers/sortOperations.test.d.ts.map +1 -0
  223. package/dist/test/document-helpers/sortOperations.test.js +101 -0
  224. package/dist/test/document-helpers/sortOperations.test.js.map +1 -0
  225. package/dist/test/document-helpers/split.test.d.ts +2 -0
  226. package/dist/test/document-helpers/split.test.d.ts.map +1 -0
  227. package/dist/test/document-helpers/split.test.js +121 -0
  228. package/dist/test/document-helpers/split.test.js.map +1 -0
  229. package/dist/test/document-helpers/utils.d.ts.map +1 -1
  230. package/dist/test/drive-operations.test.d.ts +2 -0
  231. package/dist/test/drive-operations.test.d.ts.map +1 -0
  232. package/dist/test/drive-operations.test.js +145 -0
  233. package/dist/test/drive-operations.test.js.map +1 -0
  234. package/dist/test/graphql.test.d.ts +2 -0
  235. package/dist/test/graphql.test.d.ts.map +1 -0
  236. package/dist/test/graphql.test.js +10 -0
  237. package/dist/test/graphql.test.js.map +1 -0
  238. package/dist/test/internal-listener.test.d.ts +2 -0
  239. package/dist/test/internal-listener.test.d.ts.map +1 -0
  240. package/dist/test/internal-listener.test.js +274 -0
  241. package/dist/test/internal-listener.test.js.map +1 -0
  242. package/dist/test/queue.test.d.ts +2 -0
  243. package/dist/test/queue.test.d.ts.map +1 -0
  244. package/dist/test/queue.test.js +338 -0
  245. package/dist/test/queue.test.js.map +1 -0
  246. package/dist/test/read-mode.test.d.ts +2 -0
  247. package/dist/test/read-mode.test.d.ts.map +1 -0
  248. package/dist/test/read-mode.test.js +566 -0
  249. package/dist/test/read-mode.test.js.map +1 -0
  250. package/dist/test/server/driveOperationsConflictResolution.test.d.ts +2 -0
  251. package/dist/test/server/driveOperationsConflictResolution.test.d.ts.map +1 -0
  252. package/dist/test/server/driveOperationsConflictResolution.test.js +389 -0
  253. package/dist/test/server/driveOperationsConflictResolution.test.js.map +1 -0
  254. package/dist/test/server/mergeOperations.test.d.ts +2 -0
  255. package/dist/test/server/mergeOperations.test.d.ts.map +1 -0
  256. package/dist/test/server/mergeOperations.test.js +107 -0
  257. package/dist/test/server/mergeOperations.test.js.map +1 -0
  258. package/dist/test/server/processOperations.test.d.ts +2 -0
  259. package/dist/test/server/processOperations.test.d.ts.map +1 -0
  260. package/dist/test/server/processOperations.test.js +380 -0
  261. package/dist/test/server/processOperations.test.js.map +1 -0
  262. package/dist/test/server.test.d.ts +2 -0
  263. package/dist/test/server.test.d.ts.map +1 -0
  264. package/dist/test/server.test.js +826 -0
  265. package/dist/test/server.test.js.map +1 -0
  266. package/dist/test/signature-migration.test.d.ts +2 -0
  267. package/dist/test/signature-migration.test.d.ts.map +1 -0
  268. package/dist/test/signature-migration.test.js +235 -0
  269. package/dist/test/signature-migration.test.js.map +1 -0
  270. package/dist/test/storage.test.d.ts +2 -0
  271. package/dist/test/storage.test.d.ts.map +1 -0
  272. package/dist/test/storage.test.js +476 -0
  273. package/dist/test/storage.test.js.map +1 -0
  274. package/dist/test/utils.test.d.ts +2 -0
  275. package/dist/test/utils.test.d.ts.map +1 -0
  276. package/dist/test/utils.test.js +89 -0
  277. package/dist/test/utils.test.js.map +1 -0
  278. package/dist/tsconfig.tsbuildinfo +1 -1
  279. package/dist/vitest.config.d.ts.map +1 -1
  280. package/dist/vitest.config.js +3 -0
  281. package/dist/vitest.config.js.map +1 -1
  282. package/package.json +12 -13
  283. package/dist/src/drive-document-model/gen/constants.d.ts +0 -7
  284. package/dist/src/drive-document-model/gen/constants.d.ts.map +0 -1
  285. package/dist/src/drive-document-model/gen/constants.js +0 -16
  286. package/dist/src/drive-document-model/gen/constants.js.map +0 -1
@@ -0,0 +1,136 @@
1
+ import { garbageCollect } from "document-model";
2
+ import { describe, expect, it } from "vitest";
3
+ import { buildOperation, buildOperations } from "./utils.js";
4
+ describe("garbageCollect", () => {
5
+ it("should return the same list of operations if there is no issues or removals", () => {
6
+ // 0:0 1:0 2:0 => 0:0 1:0 2:0, removals 0, no issues
7
+ const operations = buildOperations([
8
+ { index: 0, skip: 0 },
9
+ { index: 1, skip: 0 },
10
+ { index: 2, skip: 0 },
11
+ ]);
12
+ const result = garbageCollect(operations);
13
+ expect(result.length).toBe(operations.length);
14
+ expect(result).toMatchObject(operations);
15
+ });
16
+ it("should remove a single skipped operation", () => {
17
+ // 0:0 1:1 2:0 => 1:1 2:0, removals 1, no issues
18
+ const op0 = buildOperation({ index: 0, skip: 0 });
19
+ const op1 = buildOperation({ index: 1, skip: 1 });
20
+ const op2 = buildOperation({ index: 2, skip: 0 });
21
+ const operations = [op0, op1, op2];
22
+ const result = garbageCollect(operations);
23
+ expect(result.length).toBe(2);
24
+ expect(result).toMatchObject([op1, op2]);
25
+ });
26
+ it("should remove all the skipped operations", () => {
27
+ // 0:0 1:1 2:0 3:1 => 1:1 3:1, removals 2, no issues
28
+ const op0 = buildOperation({ index: 0, skip: 0 });
29
+ const op1 = buildOperation({ index: 1, skip: 1 });
30
+ const op2 = buildOperation({ index: 2, skip: 0 });
31
+ const op3 = buildOperation({ index: 3, skip: 1 });
32
+ const operations = [op0, op1, op2, op3];
33
+ const result = garbageCollect(operations);
34
+ expect(result.length).toBe(2);
35
+ expect(result).toMatchObject([op1, op3]);
36
+ });
37
+ it("should keep only the last operation when it skips all the previous operations", () => {
38
+ // 0:0 1:1 2:0 3:3 => 3:3
39
+ const op0 = buildOperation({ index: 0, skip: 0 });
40
+ const op1 = buildOperation({ index: 1, skip: 1 });
41
+ const op2 = buildOperation({ index: 2, skip: 0 });
42
+ const op3 = buildOperation({ index: 3, skip: 3 });
43
+ const operations = [op0, op1, op2, op3];
44
+ const result = garbageCollect(operations);
45
+ expect(result.length).toBe(1);
46
+ expect(result).toMatchObject([op3]);
47
+ });
48
+ it("should not increase removals if an skipped operation is not present", () => {
49
+ // 1:1 2:0 3:0 => 1:1 2:0 3:0, removals 0, no issues
50
+ const op0 = buildOperation({ index: 1, skip: 1 });
51
+ const op1 = buildOperation({ index: 2, skip: 0 });
52
+ const op2 = buildOperation({ index: 3, skip: 0 });
53
+ const operations = [op0, op1, op2];
54
+ const result = garbageCollect(operations);
55
+ expect(result.length).toBe(3);
56
+ expect(result).toMatchObject(operations);
57
+ });
58
+ it("should return an empty array if there is no operations", () => {
59
+ const result = garbageCollect([]);
60
+ expect(result).toMatchObject([]);
61
+ });
62
+ it("should return the same single operation if there is no skip value", () => {
63
+ // 0:0 => 0:0
64
+ const op0 = buildOperation({ index: 0, skip: 0 });
65
+ const operations = [op0];
66
+ const result = garbageCollect(operations);
67
+ expect(result.length).toBe(1);
68
+ expect(result).toMatchObject(operations);
69
+ });
70
+ it("should return the same single operation if the index and skip value are valid", () => {
71
+ // 1:1 => 1:1
72
+ const op0 = buildOperation({ index: 1, skip: 1 });
73
+ const operations = [op0];
74
+ const result = garbageCollect(operations);
75
+ expect(result.length).toBe(1);
76
+ expect(result).toMatchObject(operations);
77
+ });
78
+ it("should return only the latest opeartion if all the previous ones are skipped", () => {
79
+ // [0:0 1:0 2:0 2:1 2:2] => -1
80
+ const op0 = buildOperation({ index: 0, skip: 0 });
81
+ const op1 = buildOperation({ index: 1, skip: 0 });
82
+ const op2 = buildOperation({ index: 1, skip: 1 });
83
+ const op3 = buildOperation({ index: 2, skip: 0 });
84
+ const op4 = buildOperation({ index: 2, skip: 1 });
85
+ const op5 = buildOperation({ index: 2, skip: 2 });
86
+ const operations = [op0, op1, op2, op3, op4, op5];
87
+ const result = garbageCollect(operations);
88
+ expect(result.length).toBe(1);
89
+ expect(result).toMatchObject([op5]);
90
+ });
91
+ it("should be indifferent to missing skipped operations", () => {
92
+ const op0_x = buildOperation({ index: 0, skip: 0 });
93
+ const op1_v = buildOperation({ index: 1, skip: 1 });
94
+ const op2_x = buildOperation({ index: 2, skip: 0 });
95
+ const op3_x = buildOperation({ index: 3, skip: 0 });
96
+ const op4_x = buildOperation({ index: 4, skip: 0 });
97
+ const op5_x = buildOperation({ index: 4, skip: 1 });
98
+ const op6_v = buildOperation({ index: 4, skip: 2 });
99
+ const equivalentSets = [
100
+ [op0_x, op1_v, op2_x, op3_x, op4_x, op5_x, op6_v],
101
+ [op1_v, op2_x, op3_x, op4_x, op5_x, op6_v],
102
+ [op0_x, op1_v, op3_x, op4_x, op5_x, op6_v],
103
+ [op0_x, op1_v, op2_x, op4_x, op5_x, op6_v],
104
+ [op0_x, op1_v, op2_x, op3_x, op5_x, op6_v],
105
+ [op0_x, op1_v, op2_x, op3_x, op4_x, op6_v],
106
+ [op1_v, op2_x, op4_x, op5_x, op6_v],
107
+ [op0_x, op1_v, op4_x, op5_x, op6_v],
108
+ [op0_x, op1_v, op2_x, op5_x, op6_v],
109
+ [op0_x, op1_v, op2_x, op4_x, op6_v],
110
+ [op1_v, op4_x, op5_x, op6_v],
111
+ [op0_x, op1_v, op5_x, op6_v],
112
+ [op0_x, op1_v, op4_x, op6_v],
113
+ [op1_v, op5_x, op6_v],
114
+ [op0_x, op1_v, op6_v],
115
+ [op1_v, op6_v],
116
+ ];
117
+ for (const set of equivalentSets) {
118
+ expect(garbageCollect(set)).toEqual([op1_v, op6_v]);
119
+ }
120
+ });
121
+ it("should be idempotent", () => {
122
+ const op0 = buildOperation({ index: 0, skip: 0 });
123
+ const op1 = buildOperation({ index: 1, skip: 1 });
124
+ const op2 = buildOperation({ index: 2, skip: 0 });
125
+ const op3 = buildOperation({ index: 3, skip: 0 });
126
+ const op4 = buildOperation({ index: 4, skip: 0 });
127
+ const op5 = buildOperation({ index: 4, skip: 2 });
128
+ const operations = [op0, op1, op2, op3, op4, op5];
129
+ const result = garbageCollect(operations);
130
+ expect(result).toHaveLength(2);
131
+ expect(result).toEqual([op1, op5]);
132
+ const result2 = garbageCollect(result);
133
+ expect(result2).toEqual(result);
134
+ });
135
+ });
136
+ //# sourceMappingURL=garbageCollect.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"garbageCollect.test.js","sourceRoot":"","sources":["../../../test/document-helpers/garbageCollect.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=groupOperationsByScope.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"groupOperationsByScope.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/groupOperationsByScope.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,98 @@
1
+ import { groupOperationsByScope } from "document-model";
2
+ import { describe, expect, it } from "vitest";
3
+ import { buildOperations } from "./utils.js";
4
+ describe("groupOperationsByScope", () => {
5
+ const scenarios = [
6
+ {
7
+ title: "case 1",
8
+ operations: [
9
+ { index: 0, skip: 0, scope: "global", hash: "hash1" },
10
+ { index: 1, skip: 0, scope: "global", hash: "hash2" },
11
+ { index: 2, skip: 0, scope: "global", hash: "hash3" },
12
+ { index: 0, skip: 0, scope: "local", hash: "hash4" },
13
+ { index: 1, skip: 0, scope: "local", hash: "hash5" },
14
+ ],
15
+ expected: {
16
+ global: [
17
+ { index: 0, skip: 0, scope: "global", hash: "hash1" },
18
+ { index: 1, skip: 0, scope: "global", hash: "hash2" },
19
+ { index: 2, skip: 0, scope: "global", hash: "hash3" },
20
+ ],
21
+ local: [
22
+ { index: 0, skip: 0, scope: "local", hash: "hash4" },
23
+ { index: 1, skip: 0, scope: "local", hash: "hash5" },
24
+ ],
25
+ },
26
+ },
27
+ {
28
+ title: "case 2",
29
+ operations: [
30
+ { index: 0, skip: 0, scope: "global", hash: "hash1" },
31
+ { index: 1, skip: 0, scope: "global", hash: "hash2" },
32
+ { index: 0, skip: 0, scope: "local", hash: "hash4" },
33
+ { index: 2, skip: 0, scope: "global", hash: "hash3" },
34
+ { index: 1, skip: 0, scope: "local", hash: "hash5" },
35
+ { index: 3, skip: 0, scope: "global", hash: "hash6" },
36
+ { index: 3, skip: 0, scope: "local", hash: "hash10" },
37
+ { index: 4, skip: 0, scope: "global", hash: "hash7" },
38
+ { index: 5, skip: 0, scope: "global", hash: "hash8" },
39
+ { index: 2, skip: 0, scope: "local", hash: "hash9" },
40
+ ],
41
+ expected: {
42
+ global: [
43
+ { index: 0, skip: 0, scope: "global", hash: "hash1" },
44
+ { index: 1, skip: 0, scope: "global", hash: "hash2" },
45
+ { index: 2, skip: 0, scope: "global", hash: "hash3" },
46
+ { index: 3, skip: 0, scope: "global", hash: "hash6" },
47
+ { index: 4, skip: 0, scope: "global", hash: "hash7" },
48
+ { index: 5, skip: 0, scope: "global", hash: "hash8" },
49
+ ],
50
+ local: [
51
+ { index: 0, skip: 0, scope: "local", hash: "hash4" },
52
+ { index: 1, skip: 0, scope: "local", hash: "hash5" },
53
+ { index: 3, skip: 0, scope: "local", hash: "hash10" },
54
+ { index: 2, skip: 0, scope: "local", hash: "hash9" },
55
+ ],
56
+ },
57
+ },
58
+ {
59
+ title: "case 3 (only global operations)",
60
+ operations: [
61
+ { index: 0, skip: 0, scope: "global", hash: "hash1" },
62
+ { index: 1, skip: 0, scope: "global", hash: "hash2" },
63
+ { index: 2, skip: 0, scope: "global", hash: "hash3" },
64
+ ],
65
+ expected: {
66
+ global: [
67
+ { index: 0, skip: 0, scope: "global", hash: "hash1" },
68
+ { index: 1, skip: 0, scope: "global", hash: "hash2" },
69
+ { index: 2, skip: 0, scope: "global", hash: "hash3" },
70
+ ],
71
+ },
72
+ },
73
+ {
74
+ title: "case 4 (empty operations)",
75
+ operations: [],
76
+ expected: {},
77
+ },
78
+ {
79
+ title: "case 5 (only local operations)",
80
+ operations: [
81
+ { index: 0, skip: 0, scope: "local", hash: "hash1" },
82
+ { index: 1, skip: 0, scope: "local", hash: "hash2" },
83
+ ],
84
+ expected: {
85
+ local: [
86
+ { index: 0, skip: 0, scope: "local", hash: "hash1" },
87
+ { index: 1, skip: 0, scope: "local", hash: "hash2" },
88
+ ],
89
+ },
90
+ },
91
+ ];
92
+ it.each(scenarios)("should group operations by scope: $title", (testInput) => {
93
+ const operations = buildOperations(testInput.operations);
94
+ const result = groupOperationsByScope(operations);
95
+ expect(result).toMatchObject(testInput.expected);
96
+ });
97
+ });
98
+ //# sourceMappingURL=groupOperationsByScope.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"groupOperationsByScope.test.js","sourceRoot":"","sources":["../../../test/document-helpers/groupOperationsByScope.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=merge.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"merge.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/merge.test.ts"],"names":[],"mappings":""}