@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.
- package/{.eslintrc.js → .eslintrc.cjs} +4 -1
- package/{.mocharc.js → .mocharc.cjs} +1 -1
- package/CHANGELOG.md +8 -0
- package/README.md +2 -2
- package/{api-extractor-esm.json → api-extractor-cjs.json} +5 -1
- package/api-extractor.json +1 -1
- package/api-report/sequence.api.md +15 -27
- package/dist/defaultMap.d.ts +10 -16
- package/dist/defaultMap.d.ts.map +1 -1
- package/dist/defaultMap.js +73 -70
- package/dist/defaultMap.js.map +1 -1
- package/dist/defaultMapInterfaces.d.ts +1 -8
- package/dist/defaultMapInterfaces.d.ts.map +1 -1
- package/dist/defaultMapInterfaces.js.map +1 -1
- package/dist/index.d.ts +11 -11
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +42 -42
- package/dist/index.js.map +1 -1
- package/dist/intervalCollection.d.ts +21 -15
- package/dist/intervalCollection.d.ts.map +1 -1
- package/dist/intervalCollection.js +59 -110
- package/dist/intervalCollection.js.map +1 -1
- package/dist/intervalIndex/endpointInRangeIndex.d.ts +3 -3
- package/dist/intervalIndex/endpointInRangeIndex.d.ts.map +1 -1
- package/dist/intervalIndex/endpointInRangeIndex.js +8 -8
- package/dist/intervalIndex/endpointInRangeIndex.js.map +1 -1
- package/dist/intervalIndex/endpointIndex.d.ts +3 -3
- package/dist/intervalIndex/endpointIndex.d.ts.map +1 -1
- package/dist/intervalIndex/endpointIndex.js +4 -4
- package/dist/intervalIndex/endpointIndex.js.map +1 -1
- package/dist/intervalIndex/idIntervalIndex.d.ts +2 -2
- package/dist/intervalIndex/idIntervalIndex.d.ts.map +1 -1
- package/dist/intervalIndex/idIntervalIndex.js +2 -2
- package/dist/intervalIndex/idIntervalIndex.js.map +1 -1
- package/dist/intervalIndex/index.d.ts +8 -8
- package/dist/intervalIndex/index.d.ts.map +1 -1
- package/dist/intervalIndex/index.js +16 -16
- package/dist/intervalIndex/index.js.map +1 -1
- package/dist/intervalIndex/intervalIndex.d.ts +1 -1
- package/dist/intervalIndex/intervalIndex.d.ts.map +1 -1
- package/dist/intervalIndex/intervalIndex.js.map +1 -1
- package/dist/intervalIndex/overlappingIntervalsIndex.d.ts +7 -10
- package/dist/intervalIndex/overlappingIntervalsIndex.d.ts.map +1 -1
- package/dist/intervalIndex/overlappingIntervalsIndex.js +12 -13
- package/dist/intervalIndex/overlappingIntervalsIndex.js.map +1 -1
- package/dist/intervalIndex/overlappingSequenceIntervalsIndex.d.ts +2 -2
- package/dist/intervalIndex/overlappingSequenceIntervalsIndex.d.ts.map +1 -1
- package/dist/intervalIndex/overlappingSequenceIntervalsIndex.js +7 -7
- package/dist/intervalIndex/overlappingSequenceIntervalsIndex.js.map +1 -1
- package/dist/intervalIndex/sequenceIntervalIndexes.d.ts +2 -2
- package/dist/intervalIndex/sequenceIntervalIndexes.d.ts.map +1 -1
- package/dist/intervalIndex/sequenceIntervalIndexes.js.map +1 -1
- package/dist/intervalIndex/startpointInRangeIndex.d.ts +3 -3
- package/dist/intervalIndex/startpointInRangeIndex.d.ts.map +1 -1
- package/dist/intervalIndex/startpointInRangeIndex.js +8 -8
- package/dist/intervalIndex/startpointInRangeIndex.js.map +1 -1
- package/dist/intervalTree.d.ts +1 -1
- package/dist/intervalTree.d.ts.map +1 -1
- package/dist/intervalTree.js.map +1 -1
- package/dist/intervals/index.d.ts +3 -3
- package/dist/intervals/index.d.ts.map +1 -1
- package/dist/intervals/index.js +16 -16
- package/dist/intervals/index.js.map +1 -1
- package/dist/intervals/interval.d.ts +2 -2
- package/dist/intervals/interval.d.ts.map +1 -1
- package/dist/intervals/interval.js +2 -2
- package/dist/intervals/interval.js.map +1 -1
- package/dist/intervals/intervalUtils.d.ts +3 -3
- package/dist/intervals/intervalUtils.d.ts.map +1 -1
- package/dist/intervals/intervalUtils.js +1 -1
- package/dist/intervals/intervalUtils.js.map +1 -1
- package/dist/intervals/sequenceInterval.d.ts +2 -2
- package/dist/intervals/sequenceInterval.d.ts.map +1 -1
- package/dist/intervals/sequenceInterval.js +22 -23
- package/dist/intervals/sequenceInterval.js.map +1 -1
- package/dist/localValues.d.ts +2 -2
- package/dist/localValues.d.ts.map +1 -1
- package/dist/localValues.js.map +1 -1
- package/dist/package.json +3 -0
- package/dist/packageVersion.d.ts +1 -1
- package/dist/packageVersion.js +1 -1
- package/dist/packageVersion.js.map +1 -1
- package/dist/revertibles.d.ts +12 -12
- package/dist/revertibles.d.ts.map +1 -1
- package/dist/revertibles.js +26 -26
- package/dist/revertibles.js.map +1 -1
- package/dist/sequence-alpha.d.ts +172 -13
- package/dist/sequence-beta.d.ts +2 -0
- package/dist/sequence-public.d.ts +2 -0
- package/dist/sequence-untrimmed.d.ts +73 -14
- package/dist/sequence.d.ts +48 -5
- package/dist/sequence.d.ts.map +1 -1
- package/dist/sequence.js +103 -29
- package/dist/sequence.js.map +1 -1
- package/dist/sequenceFactory.d.ts +4 -1
- package/dist/sequenceFactory.d.ts.map +1 -1
- package/dist/sequenceFactory.js +8 -5
- package/dist/sequenceFactory.js.map +1 -1
- package/dist/sharedIntervalCollection.d.ts +2 -2
- package/dist/sharedIntervalCollection.d.ts.map +1 -1
- package/dist/sharedIntervalCollection.js +5 -5
- package/dist/sharedIntervalCollection.js.map +1 -1
- package/dist/sharedSequence.d.ts +1 -1
- package/dist/sharedSequence.d.ts.map +1 -1
- package/dist/sharedSequence.js +2 -2
- package/dist/sharedSequence.js.map +1 -1
- package/dist/sharedString.d.ts +2 -2
- package/dist/sharedString.d.ts.map +1 -1
- package/dist/sharedString.js +6 -6
- package/dist/sharedString.js.map +1 -1
- package/dist/tsdoc-metadata.json +1 -1
- package/lib/{defaultMap.d.mts → defaultMap.d.ts} +11 -17
- package/lib/defaultMap.d.ts.map +1 -0
- package/lib/{defaultMap.mjs → defaultMap.js} +72 -69
- package/lib/defaultMap.js.map +1 -0
- package/lib/{defaultMapInterfaces.d.mts → defaultMapInterfaces.d.ts} +2 -9
- package/lib/defaultMapInterfaces.d.ts.map +1 -0
- package/lib/{defaultMapInterfaces.mjs → defaultMapInterfaces.js} +1 -1
- package/lib/defaultMapInterfaces.js.map +1 -0
- package/lib/{index.d.mts → index.d.ts} +24 -12
- package/lib/index.d.ts.map +1 -0
- package/lib/{index.mjs → index.js} +11 -11
- package/lib/index.js.map +1 -0
- package/lib/{intervalCollection.d.mts → intervalCollection.d.ts} +22 -16
- package/lib/intervalCollection.d.ts.map +1 -0
- package/lib/{intervalCollection.mjs → intervalCollection.js} +23 -74
- package/lib/intervalCollection.js.map +1 -0
- package/lib/intervalIndex/{endpointInRangeIndex.d.mts → endpointInRangeIndex.d.ts} +4 -4
- package/lib/intervalIndex/endpointInRangeIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{endpointInRangeIndex.mjs → endpointInRangeIndex.js} +3 -3
- package/lib/intervalIndex/endpointInRangeIndex.js.map +1 -0
- package/lib/intervalIndex/{endpointIndex.d.mts → endpointIndex.d.ts} +4 -4
- package/lib/intervalIndex/endpointIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{endpointIndex.mjs → endpointIndex.js} +2 -2
- package/lib/intervalIndex/endpointIndex.js.map +1 -0
- package/lib/intervalIndex/{idIntervalIndex.d.mts → idIntervalIndex.d.ts} +3 -3
- package/lib/intervalIndex/idIntervalIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{idIntervalIndex.mjs → idIntervalIndex.js} +2 -2
- package/lib/intervalIndex/idIntervalIndex.js.map +1 -0
- package/lib/intervalIndex/{index.d.mts → index.d.ts} +9 -9
- package/lib/intervalIndex/index.d.ts.map +1 -0
- package/lib/intervalIndex/{index.mjs → index.js} +7 -7
- package/lib/intervalIndex/index.js.map +1 -0
- package/lib/intervalIndex/{intervalIndex.d.mts → intervalIndex.d.ts} +2 -2
- package/lib/intervalIndex/intervalIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{intervalIndex.mjs → intervalIndex.js} +1 -1
- package/lib/intervalIndex/intervalIndex.js.map +1 -0
- package/lib/intervalIndex/{intervalIndexUtils.d.mts → intervalIndexUtils.d.ts} +1 -1
- package/lib/intervalIndex/intervalIndexUtils.d.ts.map +1 -0
- package/lib/intervalIndex/{intervalIndexUtils.mjs → intervalIndexUtils.js} +1 -1
- package/lib/intervalIndex/intervalIndexUtils.js.map +1 -0
- package/lib/intervalIndex/{overlappingIntervalsIndex.d.mts → overlappingIntervalsIndex.d.ts} +8 -11
- package/lib/intervalIndex/overlappingIntervalsIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{overlappingIntervalsIndex.mjs → overlappingIntervalsIndex.js} +8 -9
- package/lib/intervalIndex/overlappingIntervalsIndex.js.map +1 -0
- package/lib/intervalIndex/{overlappingSequenceIntervalsIndex.d.mts → overlappingSequenceIntervalsIndex.d.ts} +3 -3
- package/lib/intervalIndex/overlappingSequenceIntervalsIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{overlappingSequenceIntervalsIndex.mjs → overlappingSequenceIntervalsIndex.js} +3 -3
- package/lib/intervalIndex/overlappingSequenceIntervalsIndex.js.map +1 -0
- package/lib/intervalIndex/{sequenceIntervalIndexes.d.mts → sequenceIntervalIndexes.d.ts} +3 -3
- package/lib/intervalIndex/sequenceIntervalIndexes.d.ts.map +1 -0
- package/lib/intervalIndex/{sequenceIntervalIndexes.mjs → sequenceIntervalIndexes.js} +1 -1
- package/lib/intervalIndex/sequenceIntervalIndexes.js.map +1 -0
- package/lib/intervalIndex/{startpointInRangeIndex.d.mts → startpointInRangeIndex.d.ts} +4 -4
- package/lib/intervalIndex/startpointInRangeIndex.d.ts.map +1 -0
- package/lib/intervalIndex/{startpointInRangeIndex.mjs → startpointInRangeIndex.js} +3 -3
- package/lib/intervalIndex/startpointInRangeIndex.js.map +1 -0
- package/lib/{intervalTree.d.mts → intervalTree.d.ts} +2 -2
- package/lib/intervalTree.d.ts.map +1 -0
- package/lib/{intervalTree.mjs → intervalTree.js} +1 -1
- package/lib/intervalTree.js.map +1 -0
- package/lib/intervals/{index.d.mts → index.d.ts} +4 -4
- package/lib/intervals/index.d.ts.map +1 -0
- package/lib/intervals/{index.mjs → index.js} +4 -4
- package/lib/intervals/index.js.map +1 -0
- package/lib/intervals/{interval.d.mts → interval.d.ts} +3 -3
- package/lib/intervals/{interval.d.mts.map → interval.d.ts.map} +1 -1
- package/lib/intervals/{interval.mjs → interval.js} +2 -2
- package/lib/intervals/interval.js.map +1 -0
- package/lib/intervals/{intervalUtils.d.mts → intervalUtils.d.ts} +4 -4
- package/lib/intervals/intervalUtils.d.ts.map +1 -0
- package/lib/intervals/{intervalUtils.mjs → intervalUtils.js} +3 -2
- package/lib/intervals/intervalUtils.js.map +1 -0
- package/lib/intervals/{sequenceInterval.d.mts → sequenceInterval.d.ts} +3 -3
- package/lib/intervals/sequenceInterval.d.ts.map +1 -0
- package/lib/intervals/{sequenceInterval.mjs → sequenceInterval.js} +5 -4
- package/lib/intervals/{sequenceInterval.mjs.map → sequenceInterval.js.map} +1 -1
- package/lib/{localValues.d.mts → localValues.d.ts} +3 -3
- package/lib/{localValues.d.mts.map → localValues.d.ts.map} +1 -1
- package/lib/{localValues.mjs → localValues.js} +1 -1
- package/lib/localValues.js.map +1 -0
- package/lib/{packageVersion.d.mts → packageVersion.d.ts} +2 -2
- package/lib/packageVersion.d.ts.map +1 -0
- package/lib/{packageVersion.mjs → packageVersion.js} +2 -2
- package/lib/packageVersion.js.map +1 -0
- package/lib/{revertibles.d.mts → revertibles.d.ts} +13 -13
- package/lib/revertibles.d.ts.map +1 -0
- package/lib/{revertibles.mjs → revertibles.js} +11 -10
- package/lib/revertibles.js.map +1 -0
- package/lib/{sequence-alpha.d.mts → sequence-alpha.d.ts} +185 -13
- package/lib/{sequence-public.d.mts → sequence-beta.d.ts} +15 -0
- package/lib/{sequence-beta.d.mts → sequence-public.d.ts} +15 -0
- package/lib/{sequence-untrimmed.d.mts → sequence-untrimmed.d.ts} +86 -14
- package/lib/{sequence.d.mts → sequence.d.ts} +49 -6
- package/lib/sequence.d.ts.map +1 -0
- package/lib/{sequence.mjs → sequence.js} +100 -29
- package/lib/sequence.js.map +1 -0
- package/lib/{sequenceDeltaEvent.d.mts → sequenceDeltaEvent.d.ts} +1 -1
- package/lib/sequenceDeltaEvent.d.ts.map +1 -0
- package/lib/{sequenceDeltaEvent.mjs → sequenceDeltaEvent.js} +1 -1
- package/lib/sequenceDeltaEvent.js.map +1 -0
- package/lib/{sequenceFactory.d.mts → sequenceFactory.d.ts} +5 -2
- package/lib/sequenceFactory.d.ts.map +1 -0
- package/lib/{sequenceFactory.mjs → sequenceFactory.js} +6 -3
- package/lib/sequenceFactory.js.map +1 -0
- package/lib/{sharedIntervalCollection.d.mts → sharedIntervalCollection.d.ts} +3 -3
- package/lib/sharedIntervalCollection.d.ts.map +1 -0
- package/lib/{sharedIntervalCollection.mjs → sharedIntervalCollection.js} +4 -4
- package/lib/sharedIntervalCollection.js.map +1 -0
- package/lib/{sharedSequence.d.mts → sharedSequence.d.ts} +2 -2
- package/lib/sharedSequence.d.ts.map +1 -0
- package/lib/{sharedSequence.mjs → sharedSequence.js} +2 -2
- package/lib/sharedSequence.js.map +1 -0
- package/lib/{sharedString.d.mts → sharedString.d.ts} +3 -3
- package/lib/sharedString.d.ts.map +1 -0
- package/lib/{sharedString.mjs → sharedString.js} +3 -3
- package/lib/sharedString.js.map +1 -0
- package/lib/test/collections.intervalTree.js +73 -0
- package/lib/test/collections.intervalTree.js.map +1 -0
- package/lib/test/createSnapshotFiles.js +15 -0
- package/lib/test/createSnapshotFiles.js.map +1 -0
- package/lib/test/dirname.cjs +16 -0
- package/lib/test/dirname.cjs.map +1 -0
- package/lib/test/endpointInRangeIndex.spec.js +182 -0
- package/lib/test/endpointInRangeIndex.spec.js.map +1 -0
- package/lib/test/fuzz/fuzzUtils.js +250 -0
- package/lib/test/fuzz/fuzzUtils.js.map +1 -0
- package/lib/test/fuzz/intervalCollection.fuzz.spec.js +200 -0
- package/lib/test/fuzz/intervalCollection.fuzz.spec.js.map +1 -0
- package/lib/test/fuzz/intervalRevertibles.fuzz.spec.js +129 -0
- package/lib/test/fuzz/intervalRevertibles.fuzz.spec.js.map +1 -0
- package/lib/test/fuzz/sharedString.fuzz.spec.js +91 -0
- package/lib/test/fuzz/sharedString.fuzz.spec.js.map +1 -0
- package/lib/test/generateSharedStrings.js +138 -0
- package/lib/test/generateSharedStrings.js.map +1 -0
- package/lib/test/intervalCollection.detached.spec.js +126 -0
- package/lib/test/intervalCollection.detached.spec.js.map +1 -0
- package/lib/test/intervalCollection.events.spec.js +491 -0
- package/lib/test/intervalCollection.events.spec.js.map +1 -0
- package/lib/test/intervalCollection.perf.spec.js +88 -0
- package/lib/test/intervalCollection.perf.spec.js.map +1 -0
- package/lib/test/intervalCollection.snapshot.spec.js +171 -0
- package/lib/test/intervalCollection.snapshot.spec.js.map +1 -0
- package/lib/test/intervalCollection.spec.js +1660 -0
- package/lib/test/intervalCollection.spec.js.map +1 -0
- package/lib/test/intervalIndexTestUtils.js +49 -0
- package/lib/test/intervalIndexTestUtils.js.map +1 -0
- package/lib/test/intervalRebasing.spec.js +589 -0
- package/lib/test/intervalRebasing.spec.js.map +1 -0
- package/lib/test/intervalStashedOps.spec.js +142 -0
- package/lib/test/intervalStashedOps.spec.js.map +1 -0
- package/lib/test/intervalTestUtils.js +81 -0
- package/lib/test/intervalTestUtils.js.map +1 -0
- package/lib/test/marshalling.spec.js +55 -0
- package/lib/test/marshalling.spec.js.map +1 -0
- package/lib/test/memory/sharedSequence.spec.js +82 -0
- package/lib/test/memory/sharedSequence.spec.js.map +1 -0
- package/lib/test/memory/sharedString.spec.js +134 -0
- package/lib/test/memory/sharedString.spec.js.map +1 -0
- package/lib/test/overlappingSequenceIntervalsIndex.spec.js +348 -0
- package/lib/test/overlappingSequenceIntervalsIndex.spec.js.map +1 -0
- package/lib/test/partialLoad.spec.js +211 -0
- package/lib/test/partialLoad.spec.js.map +1 -0
- package/lib/test/rebasing.spec.js +81 -0
- package/lib/test/rebasing.spec.js.map +1 -0
- package/lib/test/reentrancy.spec.js +174 -0
- package/lib/test/reentrancy.spec.js.map +1 -0
- package/lib/test/revertibles.spec.js +971 -0
- package/lib/test/revertibles.spec.js.map +1 -0
- package/lib/test/sequenceDeltaEvent.spec.js +2144 -0
- package/lib/test/sequenceDeltaEvent.spec.js.map +1 -0
- package/lib/test/sharedIntervalCollection.spec.js +159 -0
- package/lib/test/sharedIntervalCollection.spec.js.map +1 -0
- package/lib/test/sharedString.spec.js +532 -0
- package/lib/test/sharedString.spec.js.map +1 -0
- package/lib/test/snapshotEmptyProps.spec.js +45 -0
- package/lib/test/snapshotEmptyProps.spec.js.map +1 -0
- package/lib/test/snapshotVersion.spec.js +149 -0
- package/lib/test/snapshotVersion.spec.js.map +1 -0
- package/lib/test/startpointInRangeIndex.spec.js +182 -0
- package/lib/test/startpointInRangeIndex.spec.js.map +1 -0
- package/lib/test/subSequence.spec.js +92 -0
- package/lib/test/subSequence.spec.js.map +1 -0
- package/lib/test/types/validateSequencePrevious.generated.js +162 -0
- package/lib/test/types/validateSequencePrevious.generated.js.map +1 -0
- package/lib/test/v1IntervalCollectionHelpers.js +93 -0
- package/lib/test/v1IntervalCollectionHelpers.js.map +1 -0
- package/package.json +66 -60
- package/src/defaultMap.ts +97 -123
- package/src/defaultMapInterfaces.ts +1 -9
- package/src/index.ts +15 -11
- package/src/intervalCollection.ts +57 -84
- package/src/intervalIndex/endpointInRangeIndex.ts +4 -4
- package/src/intervalIndex/endpointIndex.ts +3 -3
- package/src/intervalIndex/idIntervalIndex.ts +3 -4
- package/src/intervalIndex/index.ts +8 -8
- package/src/intervalIndex/intervalIndex.ts +1 -1
- package/src/intervalIndex/overlappingIntervalsIndex.ts +10 -11
- package/src/intervalIndex/overlappingSequenceIntervalsIndex.ts +4 -4
- package/src/intervalIndex/sequenceIntervalIndexes.ts +2 -2
- package/src/intervalIndex/startpointInRangeIndex.ts +4 -4
- package/src/intervalTree.ts +1 -1
- package/src/intervals/index.ts +3 -3
- package/src/intervals/interval.ts +2 -4
- package/src/intervals/intervalUtils.ts +3 -3
- package/src/intervals/sequenceInterval.ts +3 -4
- package/src/localValues.ts +2 -2
- package/src/packageVersion.ts +1 -1
- package/src/revertibles.ts +13 -13
- package/src/sequence.ts +126 -44
- package/src/sequenceFactory.ts +5 -2
- package/src/sharedIntervalCollection.ts +5 -5
- package/src/sharedSequence.ts +1 -1
- package/src/sharedString.ts +2 -2
- package/tsconfig.cjs.json +7 -0
- package/tsconfig.json +2 -5
- package/lib/defaultMap.d.mts.map +0 -1
- package/lib/defaultMap.mjs.map +0 -1
- package/lib/defaultMapInterfaces.d.mts.map +0 -1
- package/lib/defaultMapInterfaces.mjs.map +0 -1
- package/lib/index.d.mts.map +0 -1
- package/lib/index.mjs.map +0 -1
- package/lib/intervalCollection.d.mts.map +0 -1
- package/lib/intervalCollection.mjs.map +0 -1
- package/lib/intervalIndex/endpointInRangeIndex.d.mts.map +0 -1
- package/lib/intervalIndex/endpointInRangeIndex.mjs.map +0 -1
- package/lib/intervalIndex/endpointIndex.d.mts.map +0 -1
- package/lib/intervalIndex/endpointIndex.mjs.map +0 -1
- package/lib/intervalIndex/idIntervalIndex.d.mts.map +0 -1
- package/lib/intervalIndex/idIntervalIndex.mjs.map +0 -1
- package/lib/intervalIndex/index.d.mts.map +0 -1
- package/lib/intervalIndex/index.mjs.map +0 -1
- package/lib/intervalIndex/intervalIndex.d.mts.map +0 -1
- package/lib/intervalIndex/intervalIndex.mjs.map +0 -1
- package/lib/intervalIndex/intervalIndexUtils.d.mts.map +0 -1
- package/lib/intervalIndex/intervalIndexUtils.mjs.map +0 -1
- package/lib/intervalIndex/overlappingIntervalsIndex.d.mts.map +0 -1
- package/lib/intervalIndex/overlappingIntervalsIndex.mjs.map +0 -1
- package/lib/intervalIndex/overlappingSequenceIntervalsIndex.d.mts.map +0 -1
- package/lib/intervalIndex/overlappingSequenceIntervalsIndex.mjs.map +0 -1
- package/lib/intervalIndex/sequenceIntervalIndexes.d.mts.map +0 -1
- package/lib/intervalIndex/sequenceIntervalIndexes.mjs.map +0 -1
- package/lib/intervalIndex/startpointInRangeIndex.d.mts.map +0 -1
- package/lib/intervalIndex/startpointInRangeIndex.mjs.map +0 -1
- package/lib/intervalTree.d.mts.map +0 -1
- package/lib/intervalTree.mjs.map +0 -1
- package/lib/intervals/index.d.mts.map +0 -1
- package/lib/intervals/index.mjs.map +0 -1
- package/lib/intervals/interval.mjs.map +0 -1
- package/lib/intervals/intervalUtils.d.mts.map +0 -1
- package/lib/intervals/intervalUtils.mjs.map +0 -1
- package/lib/intervals/sequenceInterval.d.mts.map +0 -1
- package/lib/localValues.mjs.map +0 -1
- package/lib/packageVersion.d.mts.map +0 -1
- package/lib/packageVersion.mjs.map +0 -1
- package/lib/revertibles.d.mts.map +0 -1
- package/lib/revertibles.mjs.map +0 -1
- package/lib/sequence.d.mts.map +0 -1
- package/lib/sequence.mjs.map +0 -1
- package/lib/sequenceDeltaEvent.d.mts.map +0 -1
- package/lib/sequenceDeltaEvent.mjs.map +0 -1
- package/lib/sequenceFactory.d.mts.map +0 -1
- package/lib/sequenceFactory.mjs.map +0 -1
- package/lib/sharedIntervalCollection.d.mts.map +0 -1
- package/lib/sharedIntervalCollection.mjs.map +0 -1
- package/lib/sharedSequence.d.mts.map +0 -1
- package/lib/sharedSequence.mjs.map +0 -1
- package/lib/sharedString.d.mts.map +0 -1
- 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":"AAAA;;;GAGG;AACH,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAEN,2BAA2B,EAC3B,0CAA0C,EAE1C,yBAAyB,EACzB,WAAW,GACX,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EACN,wBAAwB,EACxB,+BAA+B,GAC/B,MAAM,gCAAgC,CAAC;AAExC,OAAO,EAAY,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAClE,OAAO,EAA8B,yBAAyB,EAAE,MAAM,2BAA2B,CAAC;AAElG,MAAM,eAAe,GAAG,CACvB,kBAAiD,EACjD,QAAmD,EACnD,yBAAgE,EAC/D,EAAE;IACH,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC9C,IAAI,yBAAyB,EAAE;QAC9B,MAAM,WAAW,GAAG,yBAAyB,CAAC,wBAAwB,CACrE,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,iBAAiB,CACxB,CAAC;QACF,MAAM,CAAC,SAAS,CAAC,MAAM,EAAE,WAAW,EAAE,+CAA+C,CAAC,CAAC;KACvF;IACD,MAAM,CAAC,WAAW,CACjB,MAAM,CAAC,MAAM,EACb,QAAQ,CAAC,MAAM,EACf,4CAA4C,CAC5C,CAAC;IAEF,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE;QACzC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACjB,OAAO,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,CAAC,GAAG,EAAE,CAAC;IACrD,CAAC,CAAC,CAAC;IACH,MAAM,CAAC,SAAS,CAAC,SAAS,EAAE,QAAQ,EAAE,+BAA+B,CAAC,CAAC;AACxE,CAAC,CAAC;AAgBF,SAAS,iCAAiC,CACzC,EAAU,EACV,cAAwF;IAExF,MAAM,gBAAgB,GAAG,IAAI,yBAAyB,EAAE,CAAC;IACzD,MAAM,SAAS,GAAG,IAAI,wBAAwB,CAC7C,EAAE,EACF,gBAAgB,EAChB,+BAA+B,CAAC,UAAU,CAC1C,CAAC;IACF,MAAM,gBAAgB,GAAG,cAAc,CAAC,sBAAsB,CAAC,gBAAgB,CAAC,CAAC;IACjF,MAAM,QAAQ,GAAG;QAChB,eAAe,EAAE,gBAAgB,CAAC,qBAAqB,EAAE;QACzD,aAAa,EAAE,IAAI,WAAW,CAAC,SAAS,CAAC;KACzC,CAAC;IACF,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC5B,SAAS,CAAC,eAAe,EAAE,CAAC;IAC5B,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC;AACxC,CAAC;AAED,QAAQ,CAAC,0BAA0B,EAAE,GAAG,EAAE;IACzC,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;QACrC,IAAI,cAA2C,CAAC;QAChD,IAAI,UAAoC,CAAC;QACzC,IAAI,UAAoC,CAAC;QACzC,IAAI,WAA0C,CAAC;QAC/C,IAAI,WAA0C,CAAC;QAC/C,IAAI,0BAAgE,CAAC;QACrE,IAAI,0BAAgE,CAAC;QAErE,UAAU,CAAC,GAAG,EAAE;YACf,cAAc,GAAG,IAAI,2BAA2B,EAAE,CAAC;YACnD,UAAU,GAAG,iCAAiC,CAC7C,cAAc,EACd,cAAc,CACd,CAAC,SAAS,CAAC;YACZ,UAAU,GAAG,iCAAiC,CAC7C,cAAc,EACd,cAAc,CACd,CAAC,SAAS,CAAC;YACZ,WAAW,GAAG,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;YACvD,WAAW,GAAG,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;YACvD,0BAA0B,GAAG,IAAI,yBAAyB,CACzD,SAA8B,EAC9B,eAAe,CACf,CAAC;YACF,0BAA0B,GAAG,IAAI,yBAAyB,CACzD,SAA8B,EAC9B,eAAe,CACf,CAAC;YACF,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;YACpD,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACd,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;YACpD,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;YAClD,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACvC,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACxC,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;YAClF,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;YAEnF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACnF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAEnF,cAAc,CAAC,kBAAkB,EAAE,CAAC;YACpC,MAAM,QAAQ,GAAG;gBAChB,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;gBACrB,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;aACtB,CAAC;YACF,eAAe,CAAC,WAAW,EAAE,QAAQ,EAAE,0BAA0B,CAAC,CAAC;YACnE,eAAe,CAAC,WAAW,EAAE,QAAQ,EAAE,0BAA0B,CAAC,CAAC;YAEnE,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAClF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACnF,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACpF,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sCAAsC,EAAE,GAAG,EAAE;YAC/C,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACxD,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACxC,cAAc,CAAC,kBAAkB,EAAE,CAAC;YAEpC,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;YACnF,WAAW,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC;YACnC,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;YACnF,eAAe,CACd,WAAW,EACX;gBACC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;gBACrB,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;aACtB,EACD,0BAA0B,CAC1B,CAAC;YAEF,cAAc,CAAC,kBAAkB,EAAE,CAAC;YACpC,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;YACnF,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;QACpF,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,sBAAsB,EAAE,GAAG,EAAE;YAC/B,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACxD,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACxC,cAAc,CAAC,kBAAkB,EAAE,CAAC;YAEpC,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,EAAE,IAAI,MAAM,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAAC;YACnF,WAAW,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YAC/C,eAAe,CACd,WAAW,EACX;gBACC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;gBACtB,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;aACtB,EACD,0BAA0B,CAC1B,CAAC;YACF,eAAe,CACd,WAAW,EACX;gBACC,EAAE,KAAK,EAAE,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;gBACrB,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;aACtB,EACD,0BAA0B,CAC1B,CAAC;YAEF,cAAc,CAAC,kBAAkB,EAAE,CAAC;YACpC,eAAe,CACd,WAAW,EACX;gBACC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;gBACtB,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;aACtB,EACD,0BAA0B,CAC1B,CAAC;YACF,eAAe,CACd,WAAW,EACX;gBACC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;gBACtB,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;aACtB,EACD,0BAA0B,CAC1B,CAAC;QACH,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;QAC7B,IAAI,cAA0D,CAAC;QAC/D,IAAI,UAAoC,CAAC;QACzC,IAAI,UAAoC,CAAC;QACzC,IAAI,QAA6C,CAAC;QAClD,IAAI,WAA0C,CAAC;QAC/C,IAAI,WAA0C,CAAC;QAC/C,IAAI,0BAAgE,CAAC;QACrE,IAAI,0BAAgE,CAAC;QAErE,UAAU,CAAC,GAAG,EAAE;YACf,cAAc,GAAG,IAAI,0CAA0C,EAAE,CAAC;YAClE,MAAM,OAAO,GAAG,iCAAiC,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC;YAClF,QAAQ,GAAG,OAAO,CAAC,gBAAgB,CAAC;YACpC,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC;YAC/B,UAAU,GAAG,iCAAiC,CAC7C,cAAc,EACd,cAAc,CACd,CAAC,SAAS,CAAC;YACZ,WAAW,GAAG,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;YACvD,WAAW,GAAG,UAAU,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;YAEvD,0BAA0B,GAAG,IAAI,yBAAyB,CACzD,SAA8B,EAC9B,eAAe,CACf,CAAC;YACF,0BAA0B,GAAG,IAAI,yBAAyB,CACzD,SAA8B,EAC9B,eAAe,CACf,CAAC;YACF,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;YACpD,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,SAAS,CAAC,GAAG,EAAE;YACd,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;YACpD,WAAW,CAAC,WAAW,CAAC,0BAA0B,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,oBAAoB,EAAE,GAAG,EAAE;YAC7B,QAAQ,CAAC,SAAS,GAAG,KAAK,CAAC;YAC3B,WAAW,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,CAAC;YACxC,cAAc,CAAC,kBAAkB,EAAE,CAAC;YAEpC,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;YACnF,eAAe,CAAC,WAAW,EAAE,EAAE,EAAE,0BAA0B,CAAC,CAAC;YAE7D,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC;YAC1B,cAAc,CAAC,kBAAkB,EAAE,CAAC;YAEpC,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;YACnF,eAAe,CAAC,WAAW,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,EAAE,0BAA0B,CAAC,CAAC;QACpF,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC","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"]}
|