@fluidframework/sequence 2.0.0-rc.1.0.3 → 2.0.0-rc.2.0.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 (379) hide show
  1. package/{.eslintrc.js → .eslintrc.cjs} +4 -1
  2. package/{.mocharc.js → .mocharc.cjs} +1 -1
  3. package/CHANGELOG.md +8 -0
  4. package/README.md +2 -2
  5. package/{api-extractor-esm.json → api-extractor-cjs.json} +5 -1
  6. package/api-extractor.json +1 -1
  7. package/api-report/sequence.api.md +15 -27
  8. package/dist/defaultMap.d.ts +10 -16
  9. package/dist/defaultMap.d.ts.map +1 -1
  10. package/dist/defaultMap.js +73 -70
  11. package/dist/defaultMap.js.map +1 -1
  12. package/dist/defaultMapInterfaces.d.ts +1 -8
  13. package/dist/defaultMapInterfaces.d.ts.map +1 -1
  14. package/dist/defaultMapInterfaces.js.map +1 -1
  15. package/dist/index.d.ts +11 -11
  16. package/dist/index.d.ts.map +1 -1
  17. package/dist/index.js +42 -42
  18. package/dist/index.js.map +1 -1
  19. package/dist/intervalCollection.d.ts +21 -15
  20. package/dist/intervalCollection.d.ts.map +1 -1
  21. package/dist/intervalCollection.js +59 -110
  22. package/dist/intervalCollection.js.map +1 -1
  23. package/dist/intervalIndex/endpointInRangeIndex.d.ts +3 -3
  24. package/dist/intervalIndex/endpointInRangeIndex.d.ts.map +1 -1
  25. package/dist/intervalIndex/endpointInRangeIndex.js +8 -8
  26. package/dist/intervalIndex/endpointInRangeIndex.js.map +1 -1
  27. package/dist/intervalIndex/endpointIndex.d.ts +3 -3
  28. package/dist/intervalIndex/endpointIndex.d.ts.map +1 -1
  29. package/dist/intervalIndex/endpointIndex.js +4 -4
  30. package/dist/intervalIndex/endpointIndex.js.map +1 -1
  31. package/dist/intervalIndex/idIntervalIndex.d.ts +2 -2
  32. package/dist/intervalIndex/idIntervalIndex.d.ts.map +1 -1
  33. package/dist/intervalIndex/idIntervalIndex.js +2 -2
  34. package/dist/intervalIndex/idIntervalIndex.js.map +1 -1
  35. package/dist/intervalIndex/index.d.ts +8 -8
  36. package/dist/intervalIndex/index.d.ts.map +1 -1
  37. package/dist/intervalIndex/index.js +16 -16
  38. package/dist/intervalIndex/index.js.map +1 -1
  39. package/dist/intervalIndex/intervalIndex.d.ts +1 -1
  40. package/dist/intervalIndex/intervalIndex.d.ts.map +1 -1
  41. package/dist/intervalIndex/intervalIndex.js.map +1 -1
  42. package/dist/intervalIndex/overlappingIntervalsIndex.d.ts +7 -10
  43. package/dist/intervalIndex/overlappingIntervalsIndex.d.ts.map +1 -1
  44. package/dist/intervalIndex/overlappingIntervalsIndex.js +12 -13
  45. package/dist/intervalIndex/overlappingIntervalsIndex.js.map +1 -1
  46. package/dist/intervalIndex/overlappingSequenceIntervalsIndex.d.ts +2 -2
  47. package/dist/intervalIndex/overlappingSequenceIntervalsIndex.d.ts.map +1 -1
  48. package/dist/intervalIndex/overlappingSequenceIntervalsIndex.js +7 -7
  49. package/dist/intervalIndex/overlappingSequenceIntervalsIndex.js.map +1 -1
  50. package/dist/intervalIndex/sequenceIntervalIndexes.d.ts +2 -2
  51. package/dist/intervalIndex/sequenceIntervalIndexes.d.ts.map +1 -1
  52. package/dist/intervalIndex/sequenceIntervalIndexes.js.map +1 -1
  53. package/dist/intervalIndex/startpointInRangeIndex.d.ts +3 -3
  54. package/dist/intervalIndex/startpointInRangeIndex.d.ts.map +1 -1
  55. package/dist/intervalIndex/startpointInRangeIndex.js +8 -8
  56. package/dist/intervalIndex/startpointInRangeIndex.js.map +1 -1
  57. package/dist/intervalTree.d.ts +1 -1
  58. package/dist/intervalTree.d.ts.map +1 -1
  59. package/dist/intervalTree.js.map +1 -1
  60. package/dist/intervals/index.d.ts +3 -3
  61. package/dist/intervals/index.d.ts.map +1 -1
  62. package/dist/intervals/index.js +16 -16
  63. package/dist/intervals/index.js.map +1 -1
  64. package/dist/intervals/interval.d.ts +2 -2
  65. package/dist/intervals/interval.d.ts.map +1 -1
  66. package/dist/intervals/interval.js +2 -2
  67. package/dist/intervals/interval.js.map +1 -1
  68. package/dist/intervals/intervalUtils.d.ts +3 -3
  69. package/dist/intervals/intervalUtils.d.ts.map +1 -1
  70. package/dist/intervals/intervalUtils.js +1 -1
  71. package/dist/intervals/intervalUtils.js.map +1 -1
  72. package/dist/intervals/sequenceInterval.d.ts +2 -2
  73. package/dist/intervals/sequenceInterval.d.ts.map +1 -1
  74. package/dist/intervals/sequenceInterval.js +22 -23
  75. package/dist/intervals/sequenceInterval.js.map +1 -1
  76. package/dist/localValues.d.ts +2 -2
  77. package/dist/localValues.d.ts.map +1 -1
  78. package/dist/localValues.js.map +1 -1
  79. package/dist/package.json +3 -0
  80. package/dist/packageVersion.d.ts +1 -1
  81. package/dist/packageVersion.js +1 -1
  82. package/dist/packageVersion.js.map +1 -1
  83. package/dist/revertibles.d.ts +12 -12
  84. package/dist/revertibles.d.ts.map +1 -1
  85. package/dist/revertibles.js +26 -26
  86. package/dist/revertibles.js.map +1 -1
  87. package/dist/sequence-alpha.d.ts +172 -13
  88. package/dist/sequence-beta.d.ts +2 -0
  89. package/dist/sequence-public.d.ts +2 -0
  90. package/dist/sequence-untrimmed.d.ts +73 -14
  91. package/dist/sequence.d.ts +48 -5
  92. package/dist/sequence.d.ts.map +1 -1
  93. package/dist/sequence.js +103 -29
  94. package/dist/sequence.js.map +1 -1
  95. package/dist/sequenceFactory.d.ts +4 -1
  96. package/dist/sequenceFactory.d.ts.map +1 -1
  97. package/dist/sequenceFactory.js +8 -5
  98. package/dist/sequenceFactory.js.map +1 -1
  99. package/dist/sharedIntervalCollection.d.ts +2 -2
  100. package/dist/sharedIntervalCollection.d.ts.map +1 -1
  101. package/dist/sharedIntervalCollection.js +5 -5
  102. package/dist/sharedIntervalCollection.js.map +1 -1
  103. package/dist/sharedSequence.d.ts +1 -1
  104. package/dist/sharedSequence.d.ts.map +1 -1
  105. package/dist/sharedSequence.js +2 -2
  106. package/dist/sharedSequence.js.map +1 -1
  107. package/dist/sharedString.d.ts +2 -2
  108. package/dist/sharedString.d.ts.map +1 -1
  109. package/dist/sharedString.js +6 -6
  110. package/dist/sharedString.js.map +1 -1
  111. package/dist/tsdoc-metadata.json +1 -1
  112. package/lib/{defaultMap.d.mts → defaultMap.d.ts} +11 -17
  113. package/lib/defaultMap.d.ts.map +1 -0
  114. package/lib/{defaultMap.mjs → defaultMap.js} +72 -69
  115. package/lib/defaultMap.js.map +1 -0
  116. package/lib/{defaultMapInterfaces.d.mts → defaultMapInterfaces.d.ts} +2 -9
  117. package/lib/defaultMapInterfaces.d.ts.map +1 -0
  118. package/lib/{defaultMapInterfaces.mjs → defaultMapInterfaces.js} +1 -1
  119. package/lib/defaultMapInterfaces.js.map +1 -0
  120. package/lib/{index.d.mts → index.d.ts} +24 -12
  121. package/lib/index.d.ts.map +1 -0
  122. package/lib/{index.mjs → index.js} +11 -11
  123. package/lib/index.js.map +1 -0
  124. package/lib/{intervalCollection.d.mts → intervalCollection.d.ts} +22 -16
  125. package/lib/intervalCollection.d.ts.map +1 -0
  126. package/lib/{intervalCollection.mjs → intervalCollection.js} +23 -74
  127. package/lib/intervalCollection.js.map +1 -0
  128. package/lib/intervalIndex/{endpointInRangeIndex.d.mts → endpointInRangeIndex.d.ts} +4 -4
  129. package/lib/intervalIndex/endpointInRangeIndex.d.ts.map +1 -0
  130. package/lib/intervalIndex/{endpointInRangeIndex.mjs → endpointInRangeIndex.js} +3 -3
  131. package/lib/intervalIndex/endpointInRangeIndex.js.map +1 -0
  132. package/lib/intervalIndex/{endpointIndex.d.mts → endpointIndex.d.ts} +4 -4
  133. package/lib/intervalIndex/endpointIndex.d.ts.map +1 -0
  134. package/lib/intervalIndex/{endpointIndex.mjs → endpointIndex.js} +2 -2
  135. package/lib/intervalIndex/endpointIndex.js.map +1 -0
  136. package/lib/intervalIndex/{idIntervalIndex.d.mts → idIntervalIndex.d.ts} +3 -3
  137. package/lib/intervalIndex/idIntervalIndex.d.ts.map +1 -0
  138. package/lib/intervalIndex/{idIntervalIndex.mjs → idIntervalIndex.js} +2 -2
  139. package/lib/intervalIndex/idIntervalIndex.js.map +1 -0
  140. package/lib/intervalIndex/{index.d.mts → index.d.ts} +9 -9
  141. package/lib/intervalIndex/index.d.ts.map +1 -0
  142. package/lib/intervalIndex/{index.mjs → index.js} +7 -7
  143. package/lib/intervalIndex/index.js.map +1 -0
  144. package/lib/intervalIndex/{intervalIndex.d.mts → intervalIndex.d.ts} +2 -2
  145. package/lib/intervalIndex/intervalIndex.d.ts.map +1 -0
  146. package/lib/intervalIndex/{intervalIndex.mjs → intervalIndex.js} +1 -1
  147. package/lib/intervalIndex/intervalIndex.js.map +1 -0
  148. package/lib/intervalIndex/{intervalIndexUtils.d.mts → intervalIndexUtils.d.ts} +1 -1
  149. package/lib/intervalIndex/intervalIndexUtils.d.ts.map +1 -0
  150. package/lib/intervalIndex/{intervalIndexUtils.mjs → intervalIndexUtils.js} +1 -1
  151. package/lib/intervalIndex/intervalIndexUtils.js.map +1 -0
  152. package/lib/intervalIndex/{overlappingIntervalsIndex.d.mts → overlappingIntervalsIndex.d.ts} +8 -11
  153. package/lib/intervalIndex/overlappingIntervalsIndex.d.ts.map +1 -0
  154. package/lib/intervalIndex/{overlappingIntervalsIndex.mjs → overlappingIntervalsIndex.js} +8 -9
  155. package/lib/intervalIndex/overlappingIntervalsIndex.js.map +1 -0
  156. package/lib/intervalIndex/{overlappingSequenceIntervalsIndex.d.mts → overlappingSequenceIntervalsIndex.d.ts} +3 -3
  157. package/lib/intervalIndex/overlappingSequenceIntervalsIndex.d.ts.map +1 -0
  158. package/lib/intervalIndex/{overlappingSequenceIntervalsIndex.mjs → overlappingSequenceIntervalsIndex.js} +3 -3
  159. package/lib/intervalIndex/overlappingSequenceIntervalsIndex.js.map +1 -0
  160. package/lib/intervalIndex/{sequenceIntervalIndexes.d.mts → sequenceIntervalIndexes.d.ts} +3 -3
  161. package/lib/intervalIndex/sequenceIntervalIndexes.d.ts.map +1 -0
  162. package/lib/intervalIndex/{sequenceIntervalIndexes.mjs → sequenceIntervalIndexes.js} +1 -1
  163. package/lib/intervalIndex/sequenceIntervalIndexes.js.map +1 -0
  164. package/lib/intervalIndex/{startpointInRangeIndex.d.mts → startpointInRangeIndex.d.ts} +4 -4
  165. package/lib/intervalIndex/startpointInRangeIndex.d.ts.map +1 -0
  166. package/lib/intervalIndex/{startpointInRangeIndex.mjs → startpointInRangeIndex.js} +3 -3
  167. package/lib/intervalIndex/startpointInRangeIndex.js.map +1 -0
  168. package/lib/{intervalTree.d.mts → intervalTree.d.ts} +2 -2
  169. package/lib/intervalTree.d.ts.map +1 -0
  170. package/lib/{intervalTree.mjs → intervalTree.js} +1 -1
  171. package/lib/intervalTree.js.map +1 -0
  172. package/lib/intervals/{index.d.mts → index.d.ts} +4 -4
  173. package/lib/intervals/index.d.ts.map +1 -0
  174. package/lib/intervals/{index.mjs → index.js} +4 -4
  175. package/lib/intervals/index.js.map +1 -0
  176. package/lib/intervals/{interval.d.mts → interval.d.ts} +3 -3
  177. package/lib/intervals/{interval.d.mts.map → interval.d.ts.map} +1 -1
  178. package/lib/intervals/{interval.mjs → interval.js} +2 -2
  179. package/lib/intervals/interval.js.map +1 -0
  180. package/lib/intervals/{intervalUtils.d.mts → intervalUtils.d.ts} +4 -4
  181. package/lib/intervals/intervalUtils.d.ts.map +1 -0
  182. package/lib/intervals/{intervalUtils.mjs → intervalUtils.js} +3 -2
  183. package/lib/intervals/intervalUtils.js.map +1 -0
  184. package/lib/intervals/{sequenceInterval.d.mts → sequenceInterval.d.ts} +3 -3
  185. package/lib/intervals/sequenceInterval.d.ts.map +1 -0
  186. package/lib/intervals/{sequenceInterval.mjs → sequenceInterval.js} +5 -4
  187. package/lib/intervals/{sequenceInterval.mjs.map → sequenceInterval.js.map} +1 -1
  188. package/lib/{localValues.d.mts → localValues.d.ts} +3 -3
  189. package/lib/{localValues.d.mts.map → localValues.d.ts.map} +1 -1
  190. package/lib/{localValues.mjs → localValues.js} +1 -1
  191. package/lib/localValues.js.map +1 -0
  192. package/lib/{packageVersion.d.mts → packageVersion.d.ts} +2 -2
  193. package/lib/packageVersion.d.ts.map +1 -0
  194. package/lib/{packageVersion.mjs → packageVersion.js} +2 -2
  195. package/lib/packageVersion.js.map +1 -0
  196. package/lib/{revertibles.d.mts → revertibles.d.ts} +13 -13
  197. package/lib/revertibles.d.ts.map +1 -0
  198. package/lib/{revertibles.mjs → revertibles.js} +11 -10
  199. package/lib/revertibles.js.map +1 -0
  200. package/lib/{sequence-alpha.d.mts → sequence-alpha.d.ts} +185 -13
  201. package/lib/{sequence-public.d.mts → sequence-beta.d.ts} +15 -0
  202. package/lib/{sequence-beta.d.mts → sequence-public.d.ts} +15 -0
  203. package/lib/{sequence-untrimmed.d.mts → sequence-untrimmed.d.ts} +86 -14
  204. package/lib/{sequence.d.mts → sequence.d.ts} +49 -6
  205. package/lib/sequence.d.ts.map +1 -0
  206. package/lib/{sequence.mjs → sequence.js} +100 -29
  207. package/lib/sequence.js.map +1 -0
  208. package/lib/{sequenceDeltaEvent.d.mts → sequenceDeltaEvent.d.ts} +1 -1
  209. package/lib/sequenceDeltaEvent.d.ts.map +1 -0
  210. package/lib/{sequenceDeltaEvent.mjs → sequenceDeltaEvent.js} +1 -1
  211. package/lib/sequenceDeltaEvent.js.map +1 -0
  212. package/lib/{sequenceFactory.d.mts → sequenceFactory.d.ts} +5 -2
  213. package/lib/sequenceFactory.d.ts.map +1 -0
  214. package/lib/{sequenceFactory.mjs → sequenceFactory.js} +6 -3
  215. package/lib/sequenceFactory.js.map +1 -0
  216. package/lib/{sharedIntervalCollection.d.mts → sharedIntervalCollection.d.ts} +3 -3
  217. package/lib/sharedIntervalCollection.d.ts.map +1 -0
  218. package/lib/{sharedIntervalCollection.mjs → sharedIntervalCollection.js} +4 -4
  219. package/lib/sharedIntervalCollection.js.map +1 -0
  220. package/lib/{sharedSequence.d.mts → sharedSequence.d.ts} +2 -2
  221. package/lib/sharedSequence.d.ts.map +1 -0
  222. package/lib/{sharedSequence.mjs → sharedSequence.js} +2 -2
  223. package/lib/sharedSequence.js.map +1 -0
  224. package/lib/{sharedString.d.mts → sharedString.d.ts} +3 -3
  225. package/lib/sharedString.d.ts.map +1 -0
  226. package/lib/{sharedString.mjs → sharedString.js} +3 -3
  227. package/lib/sharedString.js.map +1 -0
  228. package/lib/test/collections.intervalTree.js +73 -0
  229. package/lib/test/collections.intervalTree.js.map +1 -0
  230. package/lib/test/createSnapshotFiles.js +15 -0
  231. package/lib/test/createSnapshotFiles.js.map +1 -0
  232. package/lib/test/dirname.cjs +16 -0
  233. package/lib/test/dirname.cjs.map +1 -0
  234. package/lib/test/endpointInRangeIndex.spec.js +182 -0
  235. package/lib/test/endpointInRangeIndex.spec.js.map +1 -0
  236. package/lib/test/fuzz/fuzzUtils.js +250 -0
  237. package/lib/test/fuzz/fuzzUtils.js.map +1 -0
  238. package/lib/test/fuzz/intervalCollection.fuzz.spec.js +200 -0
  239. package/lib/test/fuzz/intervalCollection.fuzz.spec.js.map +1 -0
  240. package/lib/test/fuzz/intervalRevertibles.fuzz.spec.js +129 -0
  241. package/lib/test/fuzz/intervalRevertibles.fuzz.spec.js.map +1 -0
  242. package/lib/test/fuzz/sharedString.fuzz.spec.js +91 -0
  243. package/lib/test/fuzz/sharedString.fuzz.spec.js.map +1 -0
  244. package/lib/test/generateSharedStrings.js +138 -0
  245. package/lib/test/generateSharedStrings.js.map +1 -0
  246. package/lib/test/intervalCollection.detached.spec.js +126 -0
  247. package/lib/test/intervalCollection.detached.spec.js.map +1 -0
  248. package/lib/test/intervalCollection.events.spec.js +491 -0
  249. package/lib/test/intervalCollection.events.spec.js.map +1 -0
  250. package/lib/test/intervalCollection.perf.spec.js +88 -0
  251. package/lib/test/intervalCollection.perf.spec.js.map +1 -0
  252. package/lib/test/intervalCollection.snapshot.spec.js +171 -0
  253. package/lib/test/intervalCollection.snapshot.spec.js.map +1 -0
  254. package/lib/test/intervalCollection.spec.js +1660 -0
  255. package/lib/test/intervalCollection.spec.js.map +1 -0
  256. package/lib/test/intervalIndexTestUtils.js +49 -0
  257. package/lib/test/intervalIndexTestUtils.js.map +1 -0
  258. package/lib/test/intervalRebasing.spec.js +589 -0
  259. package/lib/test/intervalRebasing.spec.js.map +1 -0
  260. package/lib/test/intervalStashedOps.spec.js +142 -0
  261. package/lib/test/intervalStashedOps.spec.js.map +1 -0
  262. package/lib/test/intervalTestUtils.js +81 -0
  263. package/lib/test/intervalTestUtils.js.map +1 -0
  264. package/lib/test/marshalling.spec.js +55 -0
  265. package/lib/test/marshalling.spec.js.map +1 -0
  266. package/lib/test/memory/sharedSequence.spec.js +82 -0
  267. package/lib/test/memory/sharedSequence.spec.js.map +1 -0
  268. package/lib/test/memory/sharedString.spec.js +134 -0
  269. package/lib/test/memory/sharedString.spec.js.map +1 -0
  270. package/lib/test/overlappingSequenceIntervalsIndex.spec.js +348 -0
  271. package/lib/test/overlappingSequenceIntervalsIndex.spec.js.map +1 -0
  272. package/lib/test/partialLoad.spec.js +211 -0
  273. package/lib/test/partialLoad.spec.js.map +1 -0
  274. package/lib/test/rebasing.spec.js +81 -0
  275. package/lib/test/rebasing.spec.js.map +1 -0
  276. package/lib/test/reentrancy.spec.js +174 -0
  277. package/lib/test/reentrancy.spec.js.map +1 -0
  278. package/lib/test/revertibles.spec.js +971 -0
  279. package/lib/test/revertibles.spec.js.map +1 -0
  280. package/lib/test/sequenceDeltaEvent.spec.js +2144 -0
  281. package/lib/test/sequenceDeltaEvent.spec.js.map +1 -0
  282. package/lib/test/sharedIntervalCollection.spec.js +159 -0
  283. package/lib/test/sharedIntervalCollection.spec.js.map +1 -0
  284. package/lib/test/sharedString.spec.js +532 -0
  285. package/lib/test/sharedString.spec.js.map +1 -0
  286. package/lib/test/snapshotEmptyProps.spec.js +45 -0
  287. package/lib/test/snapshotEmptyProps.spec.js.map +1 -0
  288. package/lib/test/snapshotVersion.spec.js +149 -0
  289. package/lib/test/snapshotVersion.spec.js.map +1 -0
  290. package/lib/test/startpointInRangeIndex.spec.js +182 -0
  291. package/lib/test/startpointInRangeIndex.spec.js.map +1 -0
  292. package/lib/test/subSequence.spec.js +92 -0
  293. package/lib/test/subSequence.spec.js.map +1 -0
  294. package/lib/test/types/validateSequencePrevious.generated.js +162 -0
  295. package/lib/test/types/validateSequencePrevious.generated.js.map +1 -0
  296. package/lib/test/v1IntervalCollectionHelpers.js +93 -0
  297. package/lib/test/v1IntervalCollectionHelpers.js.map +1 -0
  298. package/package.json +66 -60
  299. package/src/defaultMap.ts +97 -123
  300. package/src/defaultMapInterfaces.ts +1 -9
  301. package/src/index.ts +15 -11
  302. package/src/intervalCollection.ts +57 -84
  303. package/src/intervalIndex/endpointInRangeIndex.ts +4 -4
  304. package/src/intervalIndex/endpointIndex.ts +3 -3
  305. package/src/intervalIndex/idIntervalIndex.ts +3 -4
  306. package/src/intervalIndex/index.ts +8 -8
  307. package/src/intervalIndex/intervalIndex.ts +1 -1
  308. package/src/intervalIndex/overlappingIntervalsIndex.ts +10 -11
  309. package/src/intervalIndex/overlappingSequenceIntervalsIndex.ts +4 -4
  310. package/src/intervalIndex/sequenceIntervalIndexes.ts +2 -2
  311. package/src/intervalIndex/startpointInRangeIndex.ts +4 -4
  312. package/src/intervalTree.ts +1 -1
  313. package/src/intervals/index.ts +3 -3
  314. package/src/intervals/interval.ts +2 -4
  315. package/src/intervals/intervalUtils.ts +3 -3
  316. package/src/intervals/sequenceInterval.ts +3 -4
  317. package/src/localValues.ts +2 -2
  318. package/src/packageVersion.ts +1 -1
  319. package/src/revertibles.ts +13 -13
  320. package/src/sequence.ts +126 -44
  321. package/src/sequenceFactory.ts +5 -2
  322. package/src/sharedIntervalCollection.ts +5 -5
  323. package/src/sharedSequence.ts +1 -1
  324. package/src/sharedString.ts +2 -2
  325. package/tsconfig.cjs.json +7 -0
  326. package/tsconfig.json +2 -5
  327. package/lib/defaultMap.d.mts.map +0 -1
  328. package/lib/defaultMap.mjs.map +0 -1
  329. package/lib/defaultMapInterfaces.d.mts.map +0 -1
  330. package/lib/defaultMapInterfaces.mjs.map +0 -1
  331. package/lib/index.d.mts.map +0 -1
  332. package/lib/index.mjs.map +0 -1
  333. package/lib/intervalCollection.d.mts.map +0 -1
  334. package/lib/intervalCollection.mjs.map +0 -1
  335. package/lib/intervalIndex/endpointInRangeIndex.d.mts.map +0 -1
  336. package/lib/intervalIndex/endpointInRangeIndex.mjs.map +0 -1
  337. package/lib/intervalIndex/endpointIndex.d.mts.map +0 -1
  338. package/lib/intervalIndex/endpointIndex.mjs.map +0 -1
  339. package/lib/intervalIndex/idIntervalIndex.d.mts.map +0 -1
  340. package/lib/intervalIndex/idIntervalIndex.mjs.map +0 -1
  341. package/lib/intervalIndex/index.d.mts.map +0 -1
  342. package/lib/intervalIndex/index.mjs.map +0 -1
  343. package/lib/intervalIndex/intervalIndex.d.mts.map +0 -1
  344. package/lib/intervalIndex/intervalIndex.mjs.map +0 -1
  345. package/lib/intervalIndex/intervalIndexUtils.d.mts.map +0 -1
  346. package/lib/intervalIndex/intervalIndexUtils.mjs.map +0 -1
  347. package/lib/intervalIndex/overlappingIntervalsIndex.d.mts.map +0 -1
  348. package/lib/intervalIndex/overlappingIntervalsIndex.mjs.map +0 -1
  349. package/lib/intervalIndex/overlappingSequenceIntervalsIndex.d.mts.map +0 -1
  350. package/lib/intervalIndex/overlappingSequenceIntervalsIndex.mjs.map +0 -1
  351. package/lib/intervalIndex/sequenceIntervalIndexes.d.mts.map +0 -1
  352. package/lib/intervalIndex/sequenceIntervalIndexes.mjs.map +0 -1
  353. package/lib/intervalIndex/startpointInRangeIndex.d.mts.map +0 -1
  354. package/lib/intervalIndex/startpointInRangeIndex.mjs.map +0 -1
  355. package/lib/intervalTree.d.mts.map +0 -1
  356. package/lib/intervalTree.mjs.map +0 -1
  357. package/lib/intervals/index.d.mts.map +0 -1
  358. package/lib/intervals/index.mjs.map +0 -1
  359. package/lib/intervals/interval.mjs.map +0 -1
  360. package/lib/intervals/intervalUtils.d.mts.map +0 -1
  361. package/lib/intervals/intervalUtils.mjs.map +0 -1
  362. package/lib/intervals/sequenceInterval.d.mts.map +0 -1
  363. package/lib/localValues.mjs.map +0 -1
  364. package/lib/packageVersion.d.mts.map +0 -1
  365. package/lib/packageVersion.mjs.map +0 -1
  366. package/lib/revertibles.d.mts.map +0 -1
  367. package/lib/revertibles.mjs.map +0 -1
  368. package/lib/sequence.d.mts.map +0 -1
  369. package/lib/sequence.mjs.map +0 -1
  370. package/lib/sequenceDeltaEvent.d.mts.map +0 -1
  371. package/lib/sequenceDeltaEvent.mjs.map +0 -1
  372. package/lib/sequenceFactory.d.mts.map +0 -1
  373. package/lib/sequenceFactory.mjs.map +0 -1
  374. package/lib/sharedIntervalCollection.d.mts.map +0 -1
  375. package/lib/sharedIntervalCollection.mjs.map +0 -1
  376. package/lib/sharedSequence.d.mts.map +0 -1
  377. package/lib/sharedSequence.mjs.map +0 -1
  378. package/lib/sharedString.d.mts.map +0 -1
  379. package/lib/sharedString.mjs.map +0 -1
@@ -0,0 +1,159 @@
1
+ /*!
2
+ * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
+ * Licensed under the MIT License.
4
+ */
5
+ import { strict as assert } from "assert";
6
+ import { MockContainerRuntimeFactory, MockContainerRuntimeFactoryForReconnection, MockFluidDataStoreRuntime, MockStorage, } from "@fluidframework/test-runtime-utils";
7
+ import { SharedIntervalCollection, SharedIntervalCollectionFactory, } from "../sharedIntervalCollection.js";
8
+ import { intervalHelpers } from "../intervals/index.js";
9
+ import { OverlappingIntervalsIndex } from "../intervalIndex/index.js";
10
+ const assertIntervals = (intervalCollection, expected, overlappingIntervalsIndex) => {
11
+ const actual = Array.from(intervalCollection);
12
+ if (overlappingIntervalsIndex) {
13
+ const overlapping = overlappingIntervalsIndex.findOverlappingIntervals(Number.NEGATIVE_INFINITY, Number.POSITIVE_INFINITY);
14
+ assert.deepEqual(actual, overlapping, "Interval search returned inconsistent results");
15
+ }
16
+ assert.strictEqual(actual.length, expected.length, `the number of intervals must be consistent`);
17
+ const actualPos = actual.map((interval) => {
18
+ assert(interval);
19
+ return { start: interval.start, end: interval.end };
20
+ });
21
+ assert.deepEqual(actualPos, expected, "intervals are not as expected");
22
+ };
23
+ function createConnectedIntervalCollection(id, runtimeFactory) {
24
+ const dataStoreRuntime = new MockFluidDataStoreRuntime();
25
+ const intervals = new SharedIntervalCollection(id, dataStoreRuntime, SharedIntervalCollectionFactory.Attributes);
26
+ const containerRuntime = runtimeFactory.createContainerRuntime(dataStoreRuntime);
27
+ const services = {
28
+ deltaConnection: dataStoreRuntime.createDeltaConnection(),
29
+ objectStorage: new MockStorage(undefined),
30
+ };
31
+ intervals.connect(services);
32
+ intervals.initializeLocal();
33
+ return { intervals, containerRuntime };
34
+ }
35
+ describe("SharedIntervalCollection", () => {
36
+ describe("In a connected state", () => {
37
+ let runtimeFactory;
38
+ let intervals1;
39
+ let intervals2;
40
+ let collection1;
41
+ let collection2;
42
+ let overlappingIntervalsIndex1;
43
+ let overlappingIntervalsIndex2;
44
+ beforeEach(() => {
45
+ runtimeFactory = new MockContainerRuntimeFactory();
46
+ intervals1 = createConnectedIntervalCollection("collection 1", runtimeFactory).intervals;
47
+ intervals2 = createConnectedIntervalCollection("collection 2", runtimeFactory).intervals;
48
+ collection1 = intervals1.getIntervalCollection("test");
49
+ collection2 = intervals2.getIntervalCollection("test");
50
+ overlappingIntervalsIndex1 = new OverlappingIntervalsIndex(undefined, intervalHelpers);
51
+ overlappingIntervalsIndex2 = new OverlappingIntervalsIndex(undefined, intervalHelpers);
52
+ collection1.attachIndex(overlappingIntervalsIndex1);
53
+ collection2.attachIndex(overlappingIntervalsIndex2);
54
+ });
55
+ afterEach(() => {
56
+ collection1.detachIndex(overlappingIntervalsIndex1);
57
+ collection2.detachIndex(overlappingIntervalsIndex2);
58
+ });
59
+ it("Can add intervals from multiple clients", () => {
60
+ collection1.add({ start: 0, end: 20 });
61
+ collection2.add({ start: 10, end: 30 });
62
+ assertIntervals(collection1, [{ start: 0, end: 20 }], overlappingIntervalsIndex1);
63
+ assertIntervals(collection2, [{ start: 10, end: 30 }], overlappingIntervalsIndex2);
64
+ assert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 3).length, 1);
65
+ assert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 3).length, 0);
66
+ assert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 19).length, 1);
67
+ assert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 19).length, 1);
68
+ runtimeFactory.processAllMessages();
69
+ const expected = [
70
+ { start: 0, end: 20 },
71
+ { start: 10, end: 30 },
72
+ ];
73
+ assertIntervals(collection1, expected, overlappingIntervalsIndex1);
74
+ assertIntervals(collection2, expected, overlappingIntervalsIndex2);
75
+ assert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 3).length, 1);
76
+ assert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 3).length, 1);
77
+ assert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 19).length, 2);
78
+ assert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 19).length, 2);
79
+ });
80
+ it("Can remove intervals that were added", () => {
81
+ const interval = collection1.add({ start: 0, end: 20 });
82
+ collection2.add({ start: 10, end: 30 });
83
+ runtimeFactory.processAllMessages();
84
+ const id = interval.getIntervalId() ?? assert.fail("expected interval to have id");
85
+ collection1.removeIntervalById(id);
86
+ assertIntervals(collection1, [{ start: 10, end: 30 }], overlappingIntervalsIndex1);
87
+ assertIntervals(collection2, [
88
+ { start: 0, end: 20 },
89
+ { start: 10, end: 30 },
90
+ ], overlappingIntervalsIndex2);
91
+ runtimeFactory.processAllMessages();
92
+ assertIntervals(collection1, [{ start: 10, end: 30 }], overlappingIntervalsIndex1);
93
+ assertIntervals(collection2, [{ start: 10, end: 30 }], overlappingIntervalsIndex2);
94
+ });
95
+ it("Can change intervals", () => {
96
+ const interval = collection1.add({ start: 0, end: 20 });
97
+ collection2.add({ start: 10, end: 30 });
98
+ runtimeFactory.processAllMessages();
99
+ const id = interval.getIntervalId() ?? assert.fail("expected interval to have id");
100
+ collection1.change(id, { start: 10, end: 20 });
101
+ assertIntervals(collection1, [
102
+ { start: 10, end: 20 },
103
+ { start: 10, end: 30 },
104
+ ], overlappingIntervalsIndex1);
105
+ assertIntervals(collection2, [
106
+ { start: 0, end: 20 },
107
+ { start: 10, end: 30 },
108
+ ], overlappingIntervalsIndex2);
109
+ runtimeFactory.processAllMessages();
110
+ assertIntervals(collection1, [
111
+ { start: 10, end: 20 },
112
+ { start: 10, end: 30 },
113
+ ], overlappingIntervalsIndex1);
114
+ assertIntervals(collection2, [
115
+ { start: 10, end: 20 },
116
+ { start: 10, end: 30 },
117
+ ], overlappingIntervalsIndex2);
118
+ });
119
+ });
120
+ describe("on reconnect", () => {
121
+ let runtimeFactory;
122
+ let intervals1;
123
+ let intervals2;
124
+ let runtime1;
125
+ let collection1;
126
+ let collection2;
127
+ let overlappingIntervalsIndex1;
128
+ let overlappingIntervalsIndex2;
129
+ beforeEach(() => {
130
+ runtimeFactory = new MockContainerRuntimeFactoryForReconnection();
131
+ const client1 = createConnectedIntervalCollection("collection 1", runtimeFactory);
132
+ runtime1 = client1.containerRuntime;
133
+ intervals1 = client1.intervals;
134
+ intervals2 = createConnectedIntervalCollection("collection 2", runtimeFactory).intervals;
135
+ collection1 = intervals1.getIntervalCollection("test");
136
+ collection2 = intervals2.getIntervalCollection("test");
137
+ overlappingIntervalsIndex1 = new OverlappingIntervalsIndex(undefined, intervalHelpers);
138
+ overlappingIntervalsIndex2 = new OverlappingIntervalsIndex(undefined, intervalHelpers);
139
+ collection1.attachIndex(overlappingIntervalsIndex1);
140
+ collection2.attachIndex(overlappingIntervalsIndex2);
141
+ });
142
+ afterEach(() => {
143
+ collection1.detachIndex(overlappingIntervalsIndex1);
144
+ collection2.detachIndex(overlappingIntervalsIndex2);
145
+ });
146
+ it("can rebase add ops", () => {
147
+ runtime1.connected = false;
148
+ collection1.add({ start: 15, end: 17 });
149
+ runtimeFactory.processAllMessages();
150
+ assertIntervals(collection1, [{ start: 15, end: 17 }], overlappingIntervalsIndex1);
151
+ assertIntervals(collection2, [], overlappingIntervalsIndex2);
152
+ runtime1.connected = true;
153
+ runtimeFactory.processAllMessages();
154
+ assertIntervals(collection1, [{ start: 15, end: 17 }], overlappingIntervalsIndex1);
155
+ assertIntervals(collection2, [{ start: 15, end: 17 }], overlappingIntervalsIndex2);
156
+ });
157
+ });
158
+ });
159
+ //# sourceMappingURL=sharedIntervalCollection.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sharedIntervalCollection.spec.js","sourceRoot":"","sources":["../../src/test/sharedIntervalCollection.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\nimport { strict as assert } from \"assert\";\nimport {\n\tMockContainerRuntime,\n\tMockContainerRuntimeFactory,\n\tMockContainerRuntimeFactoryForReconnection,\n\tMockContainerRuntimeForReconnection,\n\tMockFluidDataStoreRuntime,\n\tMockStorage,\n} from \"@fluidframework/test-runtime-utils\";\nimport { Client } from \"@fluidframework/merge-tree\";\nimport {\n\tSharedIntervalCollection,\n\tSharedIntervalCollectionFactory,\n} from \"../sharedIntervalCollection.js\";\nimport { IIntervalCollection } from \"../intervalCollection.js\";\nimport { Interval, intervalHelpers } from \"../intervals/index.js\";\nimport { IOverlappingIntervalsIndex, OverlappingIntervalsIndex } from \"../intervalIndex/index.js\";\n\nconst assertIntervals = (\n\tintervalCollection: IIntervalCollection<Interval>,\n\texpected: readonly { start: number; end: number }[],\n\toverlappingIntervalsIndex?: IOverlappingIntervalsIndex<Interval>,\n) => {\n\tconst actual = Array.from(intervalCollection);\n\tif (overlappingIntervalsIndex) {\n\t\tconst overlapping = overlappingIntervalsIndex.findOverlappingIntervals(\n\t\t\tNumber.NEGATIVE_INFINITY,\n\t\t\tNumber.POSITIVE_INFINITY,\n\t\t);\n\t\tassert.deepEqual(actual, overlapping, \"Interval search returned inconsistent results\");\n\t}\n\tassert.strictEqual(\n\t\tactual.length,\n\t\texpected.length,\n\t\t`the number of intervals must be consistent`,\n\t);\n\n\tconst actualPos = actual.map((interval) => {\n\t\tassert(interval);\n\t\treturn { start: interval.start, end: interval.end };\n\t});\n\tassert.deepEqual(actualPos, expected, \"intervals are not as expected\");\n};\n\nfunction createConnectedIntervalCollection(\n\tid: string,\n\truntimeFactory: MockContainerRuntimeFactoryForReconnection,\n): {\n\tintervals: SharedIntervalCollection;\n\tcontainerRuntime: MockContainerRuntimeForReconnection;\n};\nfunction createConnectedIntervalCollection(\n\tid: string,\n\truntimeFactory: MockContainerRuntimeFactory,\n): {\n\tintervals: SharedIntervalCollection;\n\tcontainerRuntime: MockContainerRuntime;\n};\nfunction createConnectedIntervalCollection(\n\tid: string,\n\truntimeFactory: MockContainerRuntimeFactory | MockContainerRuntimeFactoryForReconnection,\n) {\n\tconst dataStoreRuntime = new MockFluidDataStoreRuntime();\n\tconst intervals = new SharedIntervalCollection(\n\t\tid,\n\t\tdataStoreRuntime,\n\t\tSharedIntervalCollectionFactory.Attributes,\n\t);\n\tconst containerRuntime = runtimeFactory.createContainerRuntime(dataStoreRuntime);\n\tconst services = {\n\t\tdeltaConnection: dataStoreRuntime.createDeltaConnection(),\n\t\tobjectStorage: new MockStorage(undefined),\n\t};\n\tintervals.connect(services);\n\tintervals.initializeLocal();\n\treturn { intervals, containerRuntime };\n}\n\ndescribe(\"SharedIntervalCollection\", () => {\n\tdescribe(\"In a connected state\", () => {\n\t\tlet runtimeFactory: MockContainerRuntimeFactory;\n\t\tlet intervals1: SharedIntervalCollection;\n\t\tlet intervals2: SharedIntervalCollection;\n\t\tlet collection1: IIntervalCollection<Interval>;\n\t\tlet collection2: IIntervalCollection<Interval>;\n\t\tlet overlappingIntervalsIndex1: IOverlappingIntervalsIndex<Interval>;\n\t\tlet overlappingIntervalsIndex2: IOverlappingIntervalsIndex<Interval>;\n\n\t\tbeforeEach(() => {\n\t\t\truntimeFactory = new MockContainerRuntimeFactory();\n\t\t\tintervals1 = createConnectedIntervalCollection(\n\t\t\t\t\"collection 1\",\n\t\t\t\truntimeFactory,\n\t\t\t).intervals;\n\t\t\tintervals2 = createConnectedIntervalCollection(\n\t\t\t\t\"collection 2\",\n\t\t\t\truntimeFactory,\n\t\t\t).intervals;\n\t\t\tcollection1 = intervals1.getIntervalCollection(\"test\");\n\t\t\tcollection2 = intervals2.getIntervalCollection(\"test\");\n\t\t\toverlappingIntervalsIndex1 = new OverlappingIntervalsIndex(\n\t\t\t\tundefined as unknown as Client,\n\t\t\t\tintervalHelpers,\n\t\t\t);\n\t\t\toverlappingIntervalsIndex2 = new OverlappingIntervalsIndex(\n\t\t\t\tundefined as unknown as Client,\n\t\t\t\tintervalHelpers,\n\t\t\t);\n\t\t\tcollection1.attachIndex(overlappingIntervalsIndex1);\n\t\t\tcollection2.attachIndex(overlappingIntervalsIndex2);\n\t\t});\n\n\t\tafterEach(() => {\n\t\t\tcollection1.detachIndex(overlappingIntervalsIndex1);\n\t\t\tcollection2.detachIndex(overlappingIntervalsIndex2);\n\t\t});\n\n\t\tit(\"Can add intervals from multiple clients\", () => {\n\t\t\tcollection1.add({ start: 0, end: 20 });\n\t\t\tcollection2.add({ start: 10, end: 30 });\n\t\t\tassertIntervals(collection1, [{ start: 0, end: 20 }], overlappingIntervalsIndex1);\n\t\t\tassertIntervals(collection2, [{ start: 10, end: 30 }], overlappingIntervalsIndex2);\n\n\t\t\tassert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 3).length, 1);\n\t\t\tassert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 3).length, 0);\n\t\t\tassert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 19).length, 1);\n\t\t\tassert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 19).length, 1);\n\n\t\t\truntimeFactory.processAllMessages();\n\t\t\tconst expected = [\n\t\t\t\t{ start: 0, end: 20 },\n\t\t\t\t{ start: 10, end: 30 },\n\t\t\t];\n\t\t\tassertIntervals(collection1, expected, overlappingIntervalsIndex1);\n\t\t\tassertIntervals(collection2, expected, overlappingIntervalsIndex2);\n\n\t\t\tassert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 3).length, 1);\n\t\t\tassert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 3).length, 1);\n\t\t\tassert.equal(overlappingIntervalsIndex1.findOverlappingIntervals(1, 19).length, 2);\n\t\t\tassert.equal(overlappingIntervalsIndex2.findOverlappingIntervals(1, 19).length, 2);\n\t\t});\n\n\t\tit(\"Can remove intervals that were added\", () => {\n\t\t\tconst interval = collection1.add({ start: 0, end: 20 });\n\t\t\tcollection2.add({ start: 10, end: 30 });\n\t\t\truntimeFactory.processAllMessages();\n\n\t\t\tconst id = interval.getIntervalId() ?? assert.fail(\"expected interval to have id\");\n\t\t\tcollection1.removeIntervalById(id);\n\t\t\tassertIntervals(collection1, [{ start: 10, end: 30 }], overlappingIntervalsIndex1);\n\t\t\tassertIntervals(\n\t\t\t\tcollection2,\n\t\t\t\t[\n\t\t\t\t\t{ start: 0, end: 20 },\n\t\t\t\t\t{ start: 10, end: 30 },\n\t\t\t\t],\n\t\t\t\toverlappingIntervalsIndex2,\n\t\t\t);\n\n\t\t\truntimeFactory.processAllMessages();\n\t\t\tassertIntervals(collection1, [{ start: 10, end: 30 }], overlappingIntervalsIndex1);\n\t\t\tassertIntervals(collection2, [{ start: 10, end: 30 }], overlappingIntervalsIndex2);\n\t\t});\n\n\t\tit(\"Can change intervals\", () => {\n\t\t\tconst interval = collection1.add({ start: 0, end: 20 });\n\t\t\tcollection2.add({ start: 10, end: 30 });\n\t\t\truntimeFactory.processAllMessages();\n\n\t\t\tconst id = interval.getIntervalId() ?? assert.fail(\"expected interval to have id\");\n\t\t\tcollection1.change(id, { start: 10, end: 20 });\n\t\t\tassertIntervals(\n\t\t\t\tcollection1,\n\t\t\t\t[\n\t\t\t\t\t{ start: 10, end: 20 },\n\t\t\t\t\t{ start: 10, end: 30 },\n\t\t\t\t],\n\t\t\t\toverlappingIntervalsIndex1,\n\t\t\t);\n\t\t\tassertIntervals(\n\t\t\t\tcollection2,\n\t\t\t\t[\n\t\t\t\t\t{ start: 0, end: 20 },\n\t\t\t\t\t{ start: 10, end: 30 },\n\t\t\t\t],\n\t\t\t\toverlappingIntervalsIndex2,\n\t\t\t);\n\n\t\t\truntimeFactory.processAllMessages();\n\t\t\tassertIntervals(\n\t\t\t\tcollection1,\n\t\t\t\t[\n\t\t\t\t\t{ start: 10, end: 20 },\n\t\t\t\t\t{ start: 10, end: 30 },\n\t\t\t\t],\n\t\t\t\toverlappingIntervalsIndex1,\n\t\t\t);\n\t\t\tassertIntervals(\n\t\t\t\tcollection2,\n\t\t\t\t[\n\t\t\t\t\t{ start: 10, end: 20 },\n\t\t\t\t\t{ start: 10, end: 30 },\n\t\t\t\t],\n\t\t\t\toverlappingIntervalsIndex2,\n\t\t\t);\n\t\t});\n\t});\n\n\tdescribe(\"on reconnect\", () => {\n\t\tlet runtimeFactory: MockContainerRuntimeFactoryForReconnection;\n\t\tlet intervals1: SharedIntervalCollection;\n\t\tlet intervals2: SharedIntervalCollection;\n\t\tlet runtime1: MockContainerRuntimeForReconnection;\n\t\tlet collection1: IIntervalCollection<Interval>;\n\t\tlet collection2: IIntervalCollection<Interval>;\n\t\tlet overlappingIntervalsIndex1: IOverlappingIntervalsIndex<Interval>;\n\t\tlet overlappingIntervalsIndex2: IOverlappingIntervalsIndex<Interval>;\n\n\t\tbeforeEach(() => {\n\t\t\truntimeFactory = new MockContainerRuntimeFactoryForReconnection();\n\t\t\tconst client1 = createConnectedIntervalCollection(\"collection 1\", runtimeFactory);\n\t\t\truntime1 = client1.containerRuntime;\n\t\t\tintervals1 = client1.intervals;\n\t\t\tintervals2 = createConnectedIntervalCollection(\n\t\t\t\t\"collection 2\",\n\t\t\t\truntimeFactory,\n\t\t\t).intervals;\n\t\t\tcollection1 = intervals1.getIntervalCollection(\"test\");\n\t\t\tcollection2 = intervals2.getIntervalCollection(\"test\");\n\n\t\t\toverlappingIntervalsIndex1 = new OverlappingIntervalsIndex(\n\t\t\t\tundefined as unknown as Client,\n\t\t\t\tintervalHelpers,\n\t\t\t);\n\t\t\toverlappingIntervalsIndex2 = new OverlappingIntervalsIndex(\n\t\t\t\tundefined as unknown as Client,\n\t\t\t\tintervalHelpers,\n\t\t\t);\n\t\t\tcollection1.attachIndex(overlappingIntervalsIndex1);\n\t\t\tcollection2.attachIndex(overlappingIntervalsIndex2);\n\t\t});\n\n\t\tafterEach(() => {\n\t\t\tcollection1.detachIndex(overlappingIntervalsIndex1);\n\t\t\tcollection2.detachIndex(overlappingIntervalsIndex2);\n\t\t});\n\n\t\tit(\"can rebase add ops\", () => {\n\t\t\truntime1.connected = false;\n\t\t\tcollection1.add({ start: 15, end: 17 });\n\t\t\truntimeFactory.processAllMessages();\n\n\t\t\tassertIntervals(collection1, [{ start: 15, end: 17 }], overlappingIntervalsIndex1);\n\t\t\tassertIntervals(collection2, [], overlappingIntervalsIndex2);\n\n\t\t\truntime1.connected = true;\n\t\t\truntimeFactory.processAllMessages();\n\n\t\t\tassertIntervals(collection1, [{ start: 15, end: 17 }], overlappingIntervalsIndex1);\n\t\t\tassertIntervals(collection2, [{ start: 15, end: 17 }], overlappingIntervalsIndex2);\n\t\t});\n\t});\n});\n"]}