document-drive 1.30.2 → 2.5.0-dev.0

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 (328) hide show
  1. package/README.md +6 -6
  2. package/dist/index.d.ts +6 -4
  3. package/dist/index.d.ts.map +1 -1
  4. package/dist/index.js +5 -4
  5. package/dist/index.js.map +1 -1
  6. package/dist/prisma/schema.prisma +2 -0
  7. package/dist/src/cache/lru.d.ts +34 -0
  8. package/dist/src/cache/lru.d.ts.map +1 -0
  9. package/dist/src/cache/lru.js +41 -0
  10. package/dist/src/cache/lru.js.map +1 -0
  11. package/dist/src/cache/memory.d.ts +19 -1
  12. package/dist/src/cache/memory.d.ts.map +1 -1
  13. package/dist/src/cache/memory.js +49 -9
  14. package/dist/src/cache/memory.js.map +1 -1
  15. package/dist/src/cache/redis.d.ts.map +1 -1
  16. package/dist/src/cache/redis.js +3 -4
  17. package/dist/src/cache/redis.js.map +1 -1
  18. package/dist/src/drive-document-model/constants.d.ts +1 -1
  19. package/dist/src/drive-document-model/constants.d.ts.map +1 -1
  20. package/dist/src/drive-document-model/constants.js +2 -1
  21. package/dist/src/drive-document-model/constants.js.map +1 -1
  22. package/dist/src/drive-document-model/gen/actions.d.ts +4 -5
  23. package/dist/src/drive-document-model/gen/actions.d.ts.map +1 -1
  24. package/dist/src/drive-document-model/gen/actions.js +1 -1
  25. package/dist/src/drive-document-model/gen/actions.js.map +1 -1
  26. package/dist/src/drive-document-model/gen/creators.d.ts +1 -1
  27. package/dist/src/drive-document-model/gen/creators.d.ts.map +1 -1
  28. package/dist/src/drive-document-model/gen/creators.js +1 -1
  29. package/dist/src/drive-document-model/gen/creators.js.map +1 -1
  30. package/dist/src/drive-document-model/gen/document-model.d.ts +1 -1
  31. package/dist/src/drive-document-model/gen/document-model.d.ts.map +1 -1
  32. package/dist/src/drive-document-model/gen/document-model.js +7 -8
  33. package/dist/src/drive-document-model/gen/document-model.js.map +1 -1
  34. package/dist/src/drive-document-model/gen/drive/actions.d.ts +2 -2
  35. package/dist/src/drive-document-model/gen/drive/actions.d.ts.map +1 -1
  36. package/dist/src/drive-document-model/gen/drive/creators.d.ts +2 -2
  37. package/dist/src/drive-document-model/gen/drive/creators.d.ts.map +1 -1
  38. package/dist/src/drive-document-model/gen/drive/creators.js +9 -9
  39. package/dist/src/drive-document-model/gen/drive/creators.js.map +1 -1
  40. package/dist/src/drive-document-model/gen/drive/object.d.ts +2 -2
  41. package/dist/src/drive-document-model/gen/drive/object.d.ts.map +1 -1
  42. package/dist/src/drive-document-model/gen/drive/object.js +1 -1
  43. package/dist/src/drive-document-model/gen/drive/object.js.map +1 -1
  44. package/dist/src/drive-document-model/gen/drive/operations.d.ts +3 -3
  45. package/dist/src/drive-document-model/gen/drive/operations.d.ts.map +1 -1
  46. package/dist/src/drive-document-model/gen/index.d.ts +6 -0
  47. package/dist/src/drive-document-model/gen/index.d.ts.map +1 -0
  48. package/dist/src/drive-document-model/gen/index.js +6 -0
  49. package/dist/src/drive-document-model/gen/index.js.map +1 -0
  50. package/dist/src/drive-document-model/gen/node/actions.d.ts +2 -2
  51. package/dist/src/drive-document-model/gen/node/actions.d.ts.map +1 -1
  52. package/dist/src/drive-document-model/gen/node/creators.d.ts +2 -2
  53. package/dist/src/drive-document-model/gen/node/creators.d.ts.map +1 -1
  54. package/dist/src/drive-document-model/gen/node/creators.js +8 -8
  55. package/dist/src/drive-document-model/gen/node/creators.js.map +1 -1
  56. package/dist/src/drive-document-model/gen/node/object.d.ts +2 -2
  57. package/dist/src/drive-document-model/gen/node/object.d.ts.map +1 -1
  58. package/dist/src/drive-document-model/gen/node/object.js +1 -1
  59. package/dist/src/drive-document-model/gen/node/object.js.map +1 -1
  60. package/dist/src/drive-document-model/gen/node/operations.d.ts +3 -3
  61. package/dist/src/drive-document-model/gen/node/operations.d.ts.map +1 -1
  62. package/dist/src/drive-document-model/gen/object.d.ts +11 -14
  63. package/dist/src/drive-document-model/gen/object.d.ts.map +1 -1
  64. package/dist/src/drive-document-model/gen/object.js +11 -12
  65. package/dist/src/drive-document-model/gen/object.js.map +1 -1
  66. package/dist/src/drive-document-model/gen/reducer.d.ts +1 -1
  67. package/dist/src/drive-document-model/gen/reducer.d.ts.map +1 -1
  68. package/dist/src/drive-document-model/gen/reducer.js +16 -16
  69. package/dist/src/drive-document-model/gen/reducer.js.map +1 -1
  70. package/dist/src/drive-document-model/gen/schema/index.d.ts +3 -0
  71. package/dist/src/drive-document-model/gen/schema/index.d.ts.map +1 -0
  72. package/dist/src/drive-document-model/gen/schema/index.js +3 -0
  73. package/dist/src/drive-document-model/gen/schema/index.js.map +1 -0
  74. package/dist/src/drive-document-model/gen/schema/types.d.ts +88 -2
  75. package/dist/src/drive-document-model/gen/schema/types.d.ts.map +1 -1
  76. package/dist/src/drive-document-model/gen/schema/zod.d.ts +1 -1
  77. package/dist/src/drive-document-model/gen/schema/zod.d.ts.map +1 -1
  78. package/dist/src/drive-document-model/gen/schema/zod.js +0 -2
  79. package/dist/src/drive-document-model/gen/schema/zod.js.map +1 -1
  80. package/dist/src/drive-document-model/gen/types.d.ts +5 -4
  81. package/dist/src/drive-document-model/gen/types.d.ts.map +1 -1
  82. package/dist/src/drive-document-model/gen/types.js +1 -1
  83. package/dist/src/drive-document-model/gen/types.js.map +1 -1
  84. package/dist/src/drive-document-model/gen/utils.d.ts +9 -9
  85. package/dist/src/drive-document-model/gen/utils.d.ts.map +1 -1
  86. package/dist/src/drive-document-model/gen/utils.js +39 -23
  87. package/dist/src/drive-document-model/gen/utils.js.map +1 -1
  88. package/dist/src/drive-document-model/module.d.ts +26 -2
  89. package/dist/src/drive-document-model/module.d.ts.map +1 -1
  90. package/dist/src/drive-document-model/module.js +14 -8
  91. package/dist/src/drive-document-model/module.js.map +1 -1
  92. package/dist/src/drive-document-model/src/reducers/node.d.ts.map +1 -1
  93. package/dist/src/drive-document-model/src/reducers/node.js +10 -1
  94. package/dist/src/drive-document-model/src/reducers/node.js.map +1 -1
  95. package/dist/src/drive-document-model/src/tests/actions.test.d.ts +2 -0
  96. package/dist/src/drive-document-model/src/tests/actions.test.d.ts.map +1 -0
  97. package/dist/src/drive-document-model/src/tests/actions.test.js +221 -0
  98. package/dist/src/drive-document-model/src/tests/actions.test.js.map +1 -0
  99. package/dist/src/drive-document-model/src/tests/base.test.d.ts +2 -0
  100. package/dist/src/drive-document-model/src/tests/base.test.d.ts.map +1 -0
  101. package/dist/src/drive-document-model/src/tests/base.test.js +116 -0
  102. package/dist/src/drive-document-model/src/tests/base.test.js.map +1 -0
  103. package/dist/src/drive-document-model/src/tests/document-model.test.d.ts +6 -0
  104. package/dist/src/drive-document-model/src/tests/document-model.test.d.ts.map +1 -0
  105. package/dist/src/drive-document-model/src/tests/document-model.test.js +19 -0
  106. package/dist/src/drive-document-model/src/tests/document-model.test.js.map +1 -0
  107. package/dist/src/drive-document-model/src/tests/drive.test.d.ts +6 -0
  108. package/dist/src/drive-document-model/src/tests/drive.test.d.ts.map +1 -0
  109. package/dist/src/drive-document-model/src/tests/drive.test.js +41 -0
  110. package/dist/src/drive-document-model/src/tests/drive.test.js.map +1 -0
  111. package/dist/src/drive-document-model/src/tests/node.test.d.ts +6 -0
  112. package/dist/src/drive-document-model/src/tests/node.test.d.ts.map +1 -0
  113. package/dist/src/drive-document-model/src/tests/node.test.js +376 -0
  114. package/dist/src/drive-document-model/src/tests/node.test.js.map +1 -0
  115. package/dist/src/drive-document-model/src/tests/utils.test.d.ts +2 -0
  116. package/dist/src/drive-document-model/src/tests/utils.test.d.ts.map +1 -0
  117. package/dist/src/drive-document-model/src/tests/utils.test.js +262 -0
  118. package/dist/src/drive-document-model/src/tests/utils.test.js.map +1 -0
  119. package/dist/src/drive-document-model/src/utils.d.ts.map +1 -1
  120. package/dist/src/drive-document-model/src/utils.js +2 -2
  121. package/dist/src/drive-document-model/src/utils.js.map +1 -1
  122. package/dist/src/processors/processor-manager.d.ts.map +1 -1
  123. package/dist/src/processors/processor-manager.js +14 -4
  124. package/dist/src/processors/processor-manager.js.map +1 -1
  125. package/dist/src/queue/base.js +3 -2
  126. package/dist/src/queue/base.js.map +1 -1
  127. package/dist/src/read-mode/service.d.ts.map +1 -1
  128. package/dist/src/read-mode/service.js +9 -2
  129. package/dist/src/read-mode/service.js.map +1 -1
  130. package/dist/src/server/base-server.d.ts +9 -6
  131. package/dist/src/server/base-server.d.ts.map +1 -1
  132. package/dist/src/server/base-server.js +84 -41
  133. package/dist/src/server/base-server.js.map +1 -1
  134. package/dist/src/server/builder.d.ts +3 -3
  135. package/dist/src/server/builder.d.ts.map +1 -1
  136. package/dist/src/server/builder.js.map +1 -1
  137. package/dist/src/server/error.d.ts +6 -0
  138. package/dist/src/server/error.d.ts.map +1 -1
  139. package/dist/src/server/error.js +11 -1
  140. package/dist/src/server/error.js.map +1 -1
  141. package/dist/src/server/listener/listener-manager.d.ts +3 -0
  142. package/dist/src/server/listener/listener-manager.d.ts.map +1 -1
  143. package/dist/src/server/listener/listener-manager.js +7 -0
  144. package/dist/src/server/listener/listener-manager.js.map +1 -1
  145. package/dist/src/server/listener/transmitter/factory.d.ts.map +1 -1
  146. package/dist/src/server/listener/transmitter/factory.js +1 -1
  147. package/dist/src/server/listener/transmitter/factory.js.map +1 -1
  148. package/dist/src/server/listener/transmitter/internal.js +1 -1
  149. package/dist/src/server/listener/transmitter/internal.js.map +1 -1
  150. package/dist/src/server/listener/transmitter/pull-responder.d.ts +7 -5
  151. package/dist/src/server/listener/transmitter/pull-responder.d.ts.map +1 -1
  152. package/dist/src/server/listener/transmitter/pull-responder.js +148 -20
  153. package/dist/src/server/listener/transmitter/pull-responder.js.map +1 -1
  154. package/dist/src/server/listener/transmitter/switchboard-push.d.ts +5 -2
  155. package/dist/src/server/listener/transmitter/switchboard-push.d.ts.map +1 -1
  156. package/dist/src/server/listener/transmitter/switchboard-push.js +37 -6
  157. package/dist/src/server/listener/transmitter/switchboard-push.js.map +1 -1
  158. package/dist/src/server/sync-manager.d.ts +2 -2
  159. package/dist/src/server/sync-manager.d.ts.map +1 -1
  160. package/dist/src/server/sync-manager.js.map +1 -1
  161. package/dist/src/server/types.d.ts +21 -7
  162. package/dist/src/server/types.d.ts.map +1 -1
  163. package/dist/src/server/types.js.map +1 -1
  164. package/dist/src/storage/browser.d.ts +9 -8
  165. package/dist/src/storage/browser.d.ts.map +1 -1
  166. package/dist/src/storage/browser.js +116 -40
  167. package/dist/src/storage/browser.js.map +1 -1
  168. package/dist/src/storage/filesystem.d.ts +10 -8
  169. package/dist/src/storage/filesystem.d.ts.map +1 -1
  170. package/dist/src/storage/filesystem.js +112 -41
  171. package/dist/src/storage/filesystem.js.map +1 -1
  172. package/dist/src/storage/ipfs.d.ts +8 -5
  173. package/dist/src/storage/ipfs.d.ts.map +1 -1
  174. package/dist/src/storage/ipfs.js +133 -79
  175. package/dist/src/storage/ipfs.js.map +1 -1
  176. package/dist/src/storage/memory.d.ts +9 -7
  177. package/dist/src/storage/memory.d.ts.map +1 -1
  178. package/dist/src/storage/memory.js +97 -51
  179. package/dist/src/storage/memory.js.map +1 -1
  180. package/dist/src/storage/prisma/client/edge.js +4 -3
  181. package/dist/src/storage/prisma/client/index-browser.js +1 -0
  182. package/dist/src/storage/prisma/client/index.d.ts +150 -71
  183. package/dist/src/storage/prisma/client/index.js +4 -3
  184. package/dist/src/storage/prisma/client/package.json +1 -1
  185. package/dist/src/storage/prisma/client/schema.prisma +2 -0
  186. package/dist/src/storage/prisma/client/wasm.js +1 -0
  187. package/dist/src/storage/prisma/prisma.d.ts +8 -6
  188. package/dist/src/storage/prisma/prisma.d.ts.map +1 -1
  189. package/dist/src/storage/prisma/prisma.js +96 -49
  190. package/dist/src/storage/prisma/prisma.js.map +1 -1
  191. package/dist/src/storage/types.d.ts +40 -19
  192. package/dist/src/storage/types.d.ts.map +1 -1
  193. package/dist/src/storage/utils.d.ts +3 -0
  194. package/dist/src/storage/utils.d.ts.map +1 -0
  195. package/dist/src/storage/utils.js +3 -0
  196. package/dist/src/storage/utils.js.map +1 -0
  197. package/dist/src/utils/default-drives-manager.d.ts.map +1 -1
  198. package/dist/src/utils/default-drives-manager.js +13 -11
  199. package/dist/src/utils/default-drives-manager.js.map +1 -1
  200. package/dist/src/utils/graphql.d.ts +8 -4
  201. package/dist/src/utils/graphql.d.ts.map +1 -1
  202. package/dist/src/utils/graphql.js +27 -14
  203. package/dist/src/utils/graphql.js.map +1 -1
  204. package/dist/src/utils/logger.d.ts +2 -2
  205. package/dist/src/utils/logger.d.ts.map +1 -1
  206. package/dist/src/utils/logger.js +21 -19
  207. package/dist/src/utils/logger.js.map +1 -1
  208. package/dist/src/utils/misc.d.ts +0 -1
  209. package/dist/src/utils/misc.d.ts.map +1 -1
  210. package/dist/src/utils/misc.js +0 -4
  211. package/dist/src/utils/misc.js.map +1 -1
  212. package/dist/test/cache.test.d.ts +2 -0
  213. package/dist/test/cache.test.d.ts.map +1 -0
  214. package/dist/test/cache.test.js +281 -0
  215. package/dist/test/cache.test.js.map +1 -0
  216. package/dist/test/default-remote-drives.test.d.ts +2 -0
  217. package/dist/test/default-remote-drives.test.d.ts.map +1 -0
  218. package/dist/test/default-remote-drives.test.js +446 -0
  219. package/dist/test/default-remote-drives.test.js.map +1 -0
  220. package/dist/test/document-helpers/addUndo.test.d.ts +2 -0
  221. package/dist/test/document-helpers/addUndo.test.d.ts.map +1 -0
  222. package/dist/test/document-helpers/addUndo.test.js +120 -0
  223. package/dist/test/document-helpers/addUndo.test.js.map +1 -0
  224. package/dist/test/document-helpers/attachBranch.test.d.ts +2 -0
  225. package/dist/test/document-helpers/attachBranch.test.d.ts.map +1 -0
  226. package/dist/test/document-helpers/attachBranch.test.js +333 -0
  227. package/dist/test/document-helpers/attachBranch.test.js.map +1 -0
  228. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts +2 -0
  229. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.d.ts.map +1 -0
  230. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js +252 -0
  231. package/dist/test/document-helpers/checkCleanedOperationsIntegrity.test.js.map +1 -0
  232. package/dist/test/document-helpers/garbageCollect.test.d.ts +2 -0
  233. package/dist/test/document-helpers/garbageCollect.test.d.ts.map +1 -0
  234. package/dist/test/document-helpers/garbageCollect.test.js +136 -0
  235. package/dist/test/document-helpers/garbageCollect.test.js.map +1 -0
  236. package/dist/test/document-helpers/groupOperationsByScope.test.d.ts +2 -0
  237. package/dist/test/document-helpers/groupOperationsByScope.test.d.ts.map +1 -0
  238. package/dist/test/document-helpers/groupOperationsByScope.test.js +98 -0
  239. package/dist/test/document-helpers/groupOperationsByScope.test.js.map +1 -0
  240. package/dist/test/document-helpers/merge.test.d.ts +2 -0
  241. package/dist/test/document-helpers/merge.test.d.ts.map +1 -0
  242. package/dist/test/document-helpers/merge.test.js +757 -0
  243. package/dist/test/document-helpers/merge.test.js.map +1 -0
  244. package/dist/test/document-helpers/nextSkipNumber.test.d.ts +2 -0
  245. package/dist/test/document-helpers/nextSkipNumber.test.d.ts.map +1 -0
  246. package/dist/test/document-helpers/nextSkipNumber.test.js +123 -0
  247. package/dist/test/document-helpers/nextSkipNumber.test.js.map +1 -0
  248. package/dist/test/document-helpers/prepareOperations.test.d.ts +2 -0
  249. package/dist/test/document-helpers/prepareOperations.test.d.ts.map +1 -0
  250. package/dist/test/document-helpers/prepareOperations.test.js +304 -0
  251. package/dist/test/document-helpers/prepareOperations.test.js.map +1 -0
  252. package/dist/test/document-helpers/removeExistingOperations.test.d.ts +2 -0
  253. package/dist/test/document-helpers/removeExistingOperations.test.d.ts.map +1 -0
  254. package/dist/test/document-helpers/removeExistingOperations.test.js +150 -0
  255. package/dist/test/document-helpers/removeExistingOperations.test.js.map +1 -0
  256. package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts +2 -0
  257. package/dist/test/document-helpers/reshuffleByTimestamp.test.d.ts.map +1 -0
  258. package/dist/test/document-helpers/reshuffleByTimestamp.test.js +148 -0
  259. package/dist/test/document-helpers/reshuffleByTimestamp.test.js.map +1 -0
  260. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts +2 -0
  261. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.d.ts.map +1 -0
  262. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js +200 -0
  263. package/dist/test/document-helpers/reshuffleByTimestampAndIndex.test.js.map +1 -0
  264. package/dist/test/document-helpers/sortOperations.test.d.ts +2 -0
  265. package/dist/test/document-helpers/sortOperations.test.d.ts.map +1 -0
  266. package/dist/test/document-helpers/sortOperations.test.js +101 -0
  267. package/dist/test/document-helpers/sortOperations.test.js.map +1 -0
  268. package/dist/test/document-helpers/split.test.d.ts +2 -0
  269. package/dist/test/document-helpers/split.test.d.ts.map +1 -0
  270. package/dist/test/document-helpers/split.test.js +121 -0
  271. package/dist/test/document-helpers/split.test.js.map +1 -0
  272. package/dist/test/drive-operations.test.d.ts +2 -0
  273. package/dist/test/drive-operations.test.d.ts.map +1 -0
  274. package/dist/test/drive-operations.test.js +145 -0
  275. package/dist/test/drive-operations.test.js.map +1 -0
  276. package/dist/test/graphql.test.d.ts +2 -0
  277. package/dist/test/graphql.test.d.ts.map +1 -0
  278. package/dist/test/graphql.test.js +10 -0
  279. package/dist/test/graphql.test.js.map +1 -0
  280. package/dist/test/internal-listener.test.d.ts +2 -0
  281. package/dist/test/internal-listener.test.d.ts.map +1 -0
  282. package/dist/test/internal-listener.test.js +274 -0
  283. package/dist/test/internal-listener.test.js.map +1 -0
  284. package/dist/test/queue.test.d.ts +2 -0
  285. package/dist/test/queue.test.d.ts.map +1 -0
  286. package/dist/test/queue.test.js +338 -0
  287. package/dist/test/queue.test.js.map +1 -0
  288. package/dist/test/read-mode.test.d.ts +2 -0
  289. package/dist/test/read-mode.test.d.ts.map +1 -0
  290. package/dist/test/read-mode.test.js +566 -0
  291. package/dist/test/read-mode.test.js.map +1 -0
  292. package/dist/test/server/driveOperationsConflictResolution.test.d.ts +2 -0
  293. package/dist/test/server/driveOperationsConflictResolution.test.d.ts.map +1 -0
  294. package/dist/test/server/driveOperationsConflictResolution.test.js +389 -0
  295. package/dist/test/server/driveOperationsConflictResolution.test.js.map +1 -0
  296. package/dist/test/server/mergeOperations.test.d.ts +2 -0
  297. package/dist/test/server/mergeOperations.test.d.ts.map +1 -0
  298. package/dist/test/server/mergeOperations.test.js +107 -0
  299. package/dist/test/server/mergeOperations.test.js.map +1 -0
  300. package/dist/test/server/processOperations.test.d.ts +2 -0
  301. package/dist/test/server/processOperations.test.d.ts.map +1 -0
  302. package/dist/test/server/processOperations.test.js +380 -0
  303. package/dist/test/server/processOperations.test.js.map +1 -0
  304. package/dist/test/server.test.d.ts +2 -0
  305. package/dist/test/server.test.d.ts.map +1 -0
  306. package/dist/test/server.test.js +826 -0
  307. package/dist/test/server.test.js.map +1 -0
  308. package/dist/test/signature-migration.test.d.ts +2 -0
  309. package/dist/test/signature-migration.test.d.ts.map +1 -0
  310. package/dist/test/signature-migration.test.js +235 -0
  311. package/dist/test/signature-migration.test.js.map +1 -0
  312. package/dist/test/storage.test.d.ts +2 -0
  313. package/dist/test/storage.test.d.ts.map +1 -0
  314. package/dist/test/storage.test.js +476 -0
  315. package/dist/test/storage.test.js.map +1 -0
  316. package/dist/test/utils.test.d.ts +2 -0
  317. package/dist/test/utils.test.d.ts.map +1 -0
  318. package/dist/test/utils.test.js +89 -0
  319. package/dist/test/utils.test.js.map +1 -0
  320. package/dist/tsconfig.tsbuildinfo +1 -1
  321. package/dist/vitest.config.d.ts.map +1 -1
  322. package/dist/vitest.config.js +7 -1
  323. package/dist/vitest.config.js.map +1 -1
  324. package/package.json +17 -11
  325. package/dist/src/drive-document-model/gen/constants.d.ts +0 -7
  326. package/dist/src/drive-document-model/gen/constants.d.ts.map +0 -1
  327. package/dist/src/drive-document-model/gen/constants.js +0 -17
  328. package/dist/src/drive-document-model/gen/constants.js.map +0 -1
@@ -0,0 +1,150 @@
1
+ import { removeExistingOperations } from "document-model";
2
+ import { describe, expect, it } from "vitest";
3
+ import { buildOperations } from "./utils.js";
4
+ describe("removeExistingOperations", () => {
5
+ const scenarios = [
6
+ {
7
+ title: "case 1: all new operations should be applied",
8
+ operationsHistory: [
9
+ { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
10
+ { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
11
+ { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
12
+ ],
13
+ newOperations: [
14
+ { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
15
+ { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
16
+ { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
17
+ ],
18
+ expected: [
19
+ { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
20
+ { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
21
+ { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
22
+ ],
23
+ },
24
+ {
25
+ title: "case 2: return no operations, all of them already exist in the history",
26
+ operationsHistory: [
27
+ { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
28
+ { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
29
+ { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
30
+ ],
31
+ newOperations: [
32
+ { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
33
+ { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
34
+ { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
35
+ ],
36
+ expected: [],
37
+ },
38
+ {
39
+ title: "case 3: return only operation that does not exist in the history",
40
+ operationsHistory: [
41
+ { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
42
+ { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
43
+ { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
44
+ { index: 3, skip: 0, type: "OP_3", hash: "hash_3" },
45
+ { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
46
+ { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
47
+ ],
48
+ newOperations: [
49
+ { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
50
+ { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
51
+ { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
52
+ { index: 7, skip: 0, type: "OP_7", hash: "hash_7" },
53
+ ],
54
+ expected: [
55
+ { index: 6, skip: 0, type: "OP_6", hash: "hash_6" },
56
+ { index: 7, skip: 0, type: "OP_7", hash: "hash_7" },
57
+ ],
58
+ },
59
+ {
60
+ title: "case 4: return only operation that does not exist in the history",
61
+ operationsHistory: [
62
+ { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
63
+ { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
64
+ { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
65
+ ],
66
+ newOperations: [
67
+ { index: 0, skip: 0, type: "OP_0", hash: "hash_0" },
68
+ { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
69
+ { index: 2, skip: 0, type: "OP_2", hash: "hash_2" },
70
+ { index: 3, skip: 0, type: "OP_3", hash: "hash_3" },
71
+ { index: 4, skip: 0, type: "OP_4", hash: "hash_4" },
72
+ { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
73
+ ],
74
+ expected: [
75
+ { index: 1, skip: 0, type: "OP_1", hash: "hash_1" },
76
+ { index: 3, skip: 0, type: "OP_3", hash: "hash_3" },
77
+ { index: 5, skip: 0, type: "OP_5", hash: "hash_5" },
78
+ ],
79
+ },
80
+ ];
81
+ it.each(scenarios)("$title", (testInput) => {
82
+ const newOperations = buildOperations(testInput.newOperations);
83
+ const operationsHistory = buildOperations(testInput.operationsHistory);
84
+ const result = removeExistingOperations(newOperations, operationsHistory);
85
+ expect(result).toMatchObject(testInput.expected);
86
+ });
87
+ it("should not consider operations skipped", () => {
88
+ const existingOperations = [
89
+ {
90
+ type: "NOOP",
91
+ input: {},
92
+ scope: "global",
93
+ index: 0,
94
+ timestamp: "2024-04-22T18:33:20.624Z",
95
+ hash: "pLimr2HqW//d6upWCv4tGfI0W4c=",
96
+ skip: 0,
97
+ },
98
+ {
99
+ type: "ADD_FOLDER",
100
+ input: { id: "1", name: "test1" },
101
+ scope: "global",
102
+ index: 1,
103
+ timestamp: "2024-04-22T18:33:20.631Z",
104
+ hash: "P6p5OmHl7FpHRN9ftOS0k+eaU4E=",
105
+ skip: 1,
106
+ },
107
+ {
108
+ type: "ADD_FOLDER",
109
+ input: { id: "2", name: "test2" },
110
+ scope: "global",
111
+ index: 2,
112
+ timestamp: "2024-04-22T18:33:20.631Z",
113
+ hash: "5XOFEY2NKrHVyOA3c3oXDibrjwM=",
114
+ skip: 0,
115
+ },
116
+ ];
117
+ const operationsHistory = [
118
+ {
119
+ type: "ADD_FOLDER",
120
+ input: { id: "1", name: "test1" },
121
+ scope: "global",
122
+ index: 0,
123
+ timestamp: "2024-04-22T18:33:20.628Z",
124
+ hash: "P6p5OmHl7FpHRN9ftOS0k+eaU4E=",
125
+ skip: 0,
126
+ },
127
+ {
128
+ type: "ADD_FOLDER",
129
+ input: { id: "1", name: "test1" },
130
+ scope: "global",
131
+ index: 1,
132
+ timestamp: "2024-04-22T18:33:20.630Z",
133
+ hash: "P6p5OmHl7FpHRN9ftOS0k+eaU4E=",
134
+ skip: 1,
135
+ },
136
+ {
137
+ type: "ADD_FOLDER",
138
+ input: { id: "2", name: "test2" },
139
+ scope: "global",
140
+ index: 2,
141
+ timestamp: "2024-04-22T18:33:20.630Z",
142
+ hash: "5XOFEY2NKrHVyOA3c3oXDibrjwM=",
143
+ skip: 0,
144
+ },
145
+ ];
146
+ const result = removeExistingOperations(existingOperations, operationsHistory);
147
+ expect(result).toMatchObject([]);
148
+ });
149
+ });
150
+ //# sourceMappingURL=removeExistingOperations.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"removeExistingOperations.test.js","sourceRoot":"","sources":["../../../test/document-helpers/removeExistingOperations.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=reshuffleByTimestamp.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reshuffleByTimestamp.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestamp.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,148 @@
1
+ import { reshuffleByTimestamp } from "document-model";
2
+ import { describe, expect, it } from "vitest";
3
+ import { buildOperations } from "./utils.js";
4
+ describe("reshuffleByTimestamp", () => {
5
+ const scenarios = [
6
+ {
7
+ title: "case 1",
8
+ startIndex: { index: 6, skip: 2 },
9
+ operationsA: buildOperations([
10
+ {
11
+ index: 4,
12
+ skip: 0,
13
+ type: "OP_A_4",
14
+ timestamp: "2021-01-01T00:00:00.000Z",
15
+ },
16
+ {
17
+ index: 5,
18
+ skip: 0,
19
+ type: "OP_A_5",
20
+ timestamp: "2021-01-04T00:00:00.000Z",
21
+ },
22
+ {
23
+ index: 6,
24
+ skip: 0,
25
+ type: "OP_A_6",
26
+ timestamp: "2021-01-05T00:00:00.000Z",
27
+ },
28
+ ]),
29
+ operationsB: buildOperations([
30
+ {
31
+ index: 4,
32
+ skip: 0,
33
+ type: "OP_B_4",
34
+ timestamp: "2021-01-02T00:00:00.000Z",
35
+ },
36
+ {
37
+ index: 5,
38
+ skip: 0,
39
+ type: "OP_B_5",
40
+ timestamp: "2021-01-03T00:00:00.000Z",
41
+ },
42
+ ]),
43
+ expected: [
44
+ { index: 6, skip: 2, type: "OP_A_4" },
45
+ { index: 7, skip: 0, type: "OP_B_4" },
46
+ { index: 8, skip: 0, type: "OP_B_5" },
47
+ { index: 9, skip: 0, type: "OP_A_5" },
48
+ { index: 10, skip: 0, type: "OP_A_6" },
49
+ ],
50
+ },
51
+ {
52
+ title: "case 2 (remove skip from operations)",
53
+ startIndex: { index: 3, skip: 1 },
54
+ operationsA: buildOperations([
55
+ {
56
+ index: 2,
57
+ skip: 0,
58
+ type: "OP_A_2",
59
+ timestamp: "2021-01-01T00:00:00.000Z",
60
+ },
61
+ {
62
+ index: 3,
63
+ skip: 0,
64
+ type: "OP_A_3",
65
+ timestamp: "2021-01-03T00:00:00.000Z",
66
+ },
67
+ {
68
+ index: 4,
69
+ skip: 0,
70
+ type: "OP_A_4",
71
+ timestamp: "2021-01-04T00:00:00.000Z",
72
+ },
73
+ ]),
74
+ operationsB: buildOperations([
75
+ {
76
+ index: 3,
77
+ skip: 0,
78
+ type: "OP_B_3",
79
+ timestamp: "2021-01-02T00:00:00.000Z",
80
+ },
81
+ {
82
+ index: 5,
83
+ skip: 1,
84
+ type: "OP_B_5",
85
+ timestamp: "2021-01-05T00:00:00.000Z",
86
+ },
87
+ ]),
88
+ expected: [
89
+ { index: 3, skip: 1, type: "OP_A_2" },
90
+ { index: 4, skip: 0, type: "OP_B_3" },
91
+ { index: 5, skip: 0, type: "OP_A_3" },
92
+ { index: 6, skip: 0, type: "OP_A_4" },
93
+ { index: 7, skip: 0, type: "OP_B_5" },
94
+ ],
95
+ },
96
+ {
97
+ title: "case 3 (should not consider index when sorting operations)",
98
+ startIndex: { index: 3, skip: 1 },
99
+ operationsA: buildOperations([
100
+ {
101
+ index: 2,
102
+ skip: 0,
103
+ type: "OP_A_2",
104
+ timestamp: "2021-01-01T00:00:00.000Z",
105
+ },
106
+ {
107
+ index: 3,
108
+ skip: 0,
109
+ type: "OP_A_3",
110
+ timestamp: "2021-01-03T00:00:00.000Z",
111
+ },
112
+ {
113
+ index: 4,
114
+ skip: 0,
115
+ type: "OP_A_4",
116
+ timestamp: "2021-01-05T00:00:00.000Z",
117
+ },
118
+ ]),
119
+ operationsB: buildOperations([
120
+ {
121
+ index: 3,
122
+ skip: 0,
123
+ type: "OP_B_3",
124
+ timestamp: "2021-01-02T00:00:00.000Z",
125
+ },
126
+ {
127
+ index: 5,
128
+ skip: 1,
129
+ type: "OP_B_5",
130
+ timestamp: "2021-01-04T00:00:00.000Z",
131
+ },
132
+ ]),
133
+ expected: [
134
+ { index: 3, skip: 1, type: "OP_A_2" },
135
+ { index: 4, skip: 0, type: "OP_B_3" },
136
+ { index: 5, skip: 0, type: "OP_A_3" },
137
+ { index: 6, skip: 0, type: "OP_B_5" },
138
+ { index: 7, skip: 0, type: "OP_A_4" },
139
+ ],
140
+ },
141
+ ];
142
+ it.each(scenarios)("should reshuffle the operations: $title", (testInput) => {
143
+ const result = reshuffleByTimestamp(testInput.startIndex, testInput.operationsA, testInput.operationsB);
144
+ expect(result.length).toBe(testInput.expected.length);
145
+ expect(result).toMatchObject(testInput.expected);
146
+ });
147
+ });
148
+ //# sourceMappingURL=reshuffleByTimestamp.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reshuffleByTimestamp.test.js","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestamp.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=reshuffleByTimestampAndIndex.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reshuffleByTimestampAndIndex.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestampAndIndex.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,200 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { reshuffleByTimestampAndIndex } from "../../../document-model/src/document/utils/document-helpers.js";
3
+ import { buildOperations } from "./utils.js";
4
+ describe("reshuffleByTimestamp", () => {
5
+ const scenarios = [
6
+ {
7
+ title: "case 1",
8
+ startIndex: { index: 6, skip: 2 },
9
+ operationsA: buildOperations([
10
+ {
11
+ index: 4,
12
+ skip: 0,
13
+ type: "OP_A_4",
14
+ timestamp: "2021-01-01T00:00:00.000Z",
15
+ },
16
+ {
17
+ index: 5,
18
+ skip: 0,
19
+ type: "OP_A_5",
20
+ timestamp: "2021-01-04T00:00:00.000Z",
21
+ },
22
+ {
23
+ index: 6,
24
+ skip: 0,
25
+ type: "OP_A_6",
26
+ timestamp: "2021-01-05T00:00:00.000Z",
27
+ },
28
+ ]),
29
+ operationsB: buildOperations([
30
+ {
31
+ index: 4,
32
+ skip: 0,
33
+ type: "OP_B_4",
34
+ timestamp: "2021-01-02T00:00:00.000Z",
35
+ },
36
+ {
37
+ index: 5,
38
+ skip: 0,
39
+ type: "OP_B_5",
40
+ timestamp: "2021-01-03T00:00:00.000Z",
41
+ },
42
+ ]),
43
+ expected: [
44
+ { index: 6, skip: 2, type: "OP_A_4" },
45
+ { index: 7, skip: 0, type: "OP_B_4" },
46
+ { index: 8, skip: 0, type: "OP_B_5" },
47
+ { index: 9, skip: 0, type: "OP_A_5" },
48
+ { index: 10, skip: 0, type: "OP_A_6" },
49
+ ],
50
+ },
51
+ {
52
+ title: "case 2 (remove skip from operations)",
53
+ startIndex: { index: 3, skip: 1 },
54
+ operationsA: buildOperations([
55
+ {
56
+ index: 2,
57
+ skip: 0,
58
+ type: "OP_A_2",
59
+ timestamp: "2021-01-01T00:00:00.000Z",
60
+ },
61
+ {
62
+ index: 3,
63
+ skip: 0,
64
+ type: "OP_A_3",
65
+ timestamp: "2021-01-03T00:00:00.000Z",
66
+ },
67
+ {
68
+ index: 4,
69
+ skip: 0,
70
+ type: "OP_A_4",
71
+ timestamp: "2021-01-04T00:00:00.000Z",
72
+ },
73
+ ]),
74
+ operationsB: buildOperations([
75
+ {
76
+ index: 3,
77
+ skip: 0,
78
+ type: "OP_B_3",
79
+ timestamp: "2021-01-02T00:00:00.000Z",
80
+ },
81
+ {
82
+ index: 5,
83
+ skip: 1,
84
+ type: "OP_B_5",
85
+ timestamp: "2021-01-05T00:00:00.000Z",
86
+ },
87
+ ]),
88
+ expected: [
89
+ { index: 3, skip: 1, type: "OP_A_2" },
90
+ { index: 4, skip: 0, type: "OP_B_3" },
91
+ { index: 5, skip: 0, type: "OP_A_3" },
92
+ { index: 6, skip: 0, type: "OP_A_4" },
93
+ { index: 7, skip: 0, type: "OP_B_5" },
94
+ ],
95
+ },
96
+ {
97
+ title: "case 3 (should consider index when sorting operations)",
98
+ startIndex: { index: 3, skip: 1 },
99
+ operationsA: buildOperations([
100
+ {
101
+ index: 2,
102
+ skip: 0,
103
+ type: "OP_A_2",
104
+ timestamp: "2021-01-01T00:00:00.000Z",
105
+ },
106
+ {
107
+ index: 3,
108
+ skip: 0,
109
+ type: "OP_A_3",
110
+ timestamp: "2021-01-03T00:00:00.000Z",
111
+ },
112
+ {
113
+ index: 4,
114
+ skip: 0,
115
+ type: "OP_A_4",
116
+ timestamp: "2021-01-05T00:00:00.000Z",
117
+ },
118
+ ]),
119
+ operationsB: buildOperations([
120
+ {
121
+ index: 3,
122
+ skip: 0,
123
+ type: "OP_B_3",
124
+ timestamp: "2021-01-02T00:00:00.000Z",
125
+ },
126
+ {
127
+ index: 5,
128
+ skip: 1,
129
+ type: "OP_B_5",
130
+ timestamp: "2021-01-04T00:00:00.000Z",
131
+ },
132
+ ]),
133
+ expected: [
134
+ { index: 3, skip: 1, type: "OP_A_2" },
135
+ { index: 4, skip: 0, type: "OP_B_3" },
136
+ { index: 5, skip: 0, type: "OP_A_3" },
137
+ { index: 6, skip: 0, type: "OP_A_4" },
138
+ { index: 7, skip: 0, type: "OP_B_5" },
139
+ ],
140
+ },
141
+ {
142
+ title: "case 4 (should consider index when sorting operations)",
143
+ startIndex: { index: 3, skip: 1 },
144
+ operationsA: buildOperations([
145
+ {
146
+ index: 2,
147
+ skip: 0,
148
+ type: "OP_A_2",
149
+ timestamp: "2021-01-01T00:00:00.000Z",
150
+ },
151
+ {
152
+ index: 3,
153
+ skip: 0,
154
+ type: "OP_A_3",
155
+ timestamp: "2021-01-02T00:00:00.000Z",
156
+ },
157
+ {
158
+ index: 4,
159
+ skip: 0,
160
+ type: "OP_A_4",
161
+ timestamp: "2021-01-03T00:00:00.000Z",
162
+ },
163
+ ]),
164
+ operationsB: buildOperations([
165
+ {
166
+ index: 2,
167
+ skip: 0,
168
+ type: "OP_B_2",
169
+ timestamp: "2021-01-04T00:00:00.000Z",
170
+ },
171
+ {
172
+ index: 3,
173
+ skip: 0,
174
+ type: "OP_B_3",
175
+ timestamp: "2021-01-05T00:00:00.000Z",
176
+ },
177
+ {
178
+ index: 4,
179
+ skip: 0,
180
+ type: "OP_B_4",
181
+ timestamp: "2021-01-06T00:00:00.000Z",
182
+ },
183
+ ]),
184
+ expected: [
185
+ { index: 3, skip: 1, type: "OP_A_2" },
186
+ { index: 4, skip: 0, type: "OP_B_2" },
187
+ { index: 5, skip: 0, type: "OP_A_3" },
188
+ { index: 6, skip: 0, type: "OP_B_3" },
189
+ { index: 7, skip: 0, type: "OP_A_4" },
190
+ { index: 8, skip: 0, type: "OP_B_4" },
191
+ ],
192
+ },
193
+ ];
194
+ it.each(scenarios)("should reshuffle the operations: $title", (testInput) => {
195
+ const result = reshuffleByTimestampAndIndex(testInput.startIndex, testInput.operationsA, testInput.operationsB);
196
+ expect(result.length).toBe(testInput.expected.length);
197
+ expect(result).toMatchObject(testInput.expected);
198
+ });
199
+ });
200
+ //# sourceMappingURL=reshuffleByTimestampAndIndex.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reshuffleByTimestampAndIndex.test.js","sourceRoot":"","sources":["../../../test/document-helpers/reshuffleByTimestampAndIndex.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=sortOperations.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sortOperations.test.d.ts","sourceRoot":"","sources":["../../../test/document-helpers/sortOperations.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,101 @@
1
+ import { sortOperations } from "document-model";
2
+ import { describe, expect, it } from "vitest";
3
+ import { buildOperations } from "./utils.js";
4
+ describe("sortOperations", () => {
5
+ const scenarios = [
6
+ {
7
+ // 0:0 1:0 2:0 => 0:0 1:0 2:0
8
+ title: "case 1",
9
+ operations: [
10
+ { index: 0, skip: 0 },
11
+ { index: 1, skip: 0 },
12
+ { index: 2, skip: 0 },
13
+ ],
14
+ expected: [
15
+ { index: 0, skip: 0 },
16
+ { index: 1, skip: 0 },
17
+ { index: 2, skip: 0 },
18
+ ],
19
+ },
20
+ {
21
+ // 0:0 1:0 2:0 3:0 4:2 4:1 4:0 => 0:0 1:0 2:0 3:0 4:0 4:1 4:2
22
+ title: "case 2 (with skip value)",
23
+ operations: [
24
+ { index: 0, skip: 0 },
25
+ { index: 1, skip: 0 },
26
+ { index: 2, skip: 0 },
27
+ { index: 3, skip: 0 },
28
+ { index: 4, skip: 2 },
29
+ { index: 4, skip: 1 },
30
+ { index: 4, skip: 0 },
31
+ ],
32
+ expected: [
33
+ { index: 0, skip: 0 },
34
+ { index: 1, skip: 0 },
35
+ { index: 2, skip: 0 },
36
+ { index: 3, skip: 0 },
37
+ { index: 4, skip: 0 },
38
+ { index: 4, skip: 1 },
39
+ { index: 4, skip: 2 },
40
+ ],
41
+ },
42
+ {
43
+ // 1:1 5:0 4:0 3:0 => 1:1 3:0 4:0 5:0
44
+ title: "case 3 (with skip value)",
45
+ operations: [
46
+ { index: 1, skip: 1 },
47
+ { index: 5, skip: 0 },
48
+ { index: 4, skip: 0 },
49
+ { index: 3, skip: 0 },
50
+ ],
51
+ expected: [
52
+ { index: 1, skip: 1 },
53
+ { index: 3, skip: 0 },
54
+ { index: 4, skip: 0 },
55
+ { index: 5, skip: 0 },
56
+ ],
57
+ },
58
+ {
59
+ // 6:0 7:2 1:1 4:1 2:0 3:0 7:0 4:0 7:1 4:2 5:0 => 1:1 2:0 3:0 4:0 4:1 4:2 5:0 6:0 7:0 7:1 7:2
60
+ title: "case 4 (with skip value)",
61
+ operations: [
62
+ { index: 6, skip: 0 },
63
+ { index: 7, skip: 2 },
64
+ { index: 1, skip: 1 },
65
+ { index: 4, skip: 1 },
66
+ { index: 2, skip: 0 },
67
+ { index: 3, skip: 0 },
68
+ { index: 7, skip: 0 },
69
+ { index: 4, skip: 0 },
70
+ { index: 7, skip: 1 },
71
+ { index: 4, skip: 2 },
72
+ { index: 5, skip: 0 },
73
+ ],
74
+ expected: [
75
+ { index: 1, skip: 1 },
76
+ { index: 2, skip: 0 },
77
+ { index: 3, skip: 0 },
78
+ { index: 4, skip: 0 },
79
+ { index: 4, skip: 1 },
80
+ { index: 4, skip: 2 },
81
+ { index: 5, skip: 0 },
82
+ { index: 6, skip: 0 },
83
+ { index: 7, skip: 0 },
84
+ { index: 7, skip: 1 },
85
+ { index: 7, skip: 2 },
86
+ ],
87
+ },
88
+ {
89
+ // [] => []
90
+ title: "case 5 (empty)",
91
+ operations: [],
92
+ expected: [],
93
+ },
94
+ ];
95
+ it.each(scenarios)("should sort operations: $title", (testInput) => {
96
+ const operations = buildOperations(testInput.operations);
97
+ const result = sortOperations(operations);
98
+ expect(result).toMatchObject(testInput.expected);
99
+ });
100
+ });
101
+ //# sourceMappingURL=sortOperations.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sortOperations.test.js","sourceRoot":"","sources":["../../../test/document-helpers/sortOperations.test.ts"],"names":[],"mappings":"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"}