@fluidframework/container-runtime 2.0.0-dev-rc.2.0.0.246488 → 2.0.0-dev-rc.3.0.0.250606

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 (456) hide show
  1. package/api-report/container-runtime.api.md +78 -25
  2. package/dist/batchTracker.d.ts +1 -1
  3. package/dist/batchTracker.d.ts.map +1 -1
  4. package/dist/batchTracker.js +2 -2
  5. package/dist/batchTracker.js.map +1 -1
  6. package/dist/blobManager.d.ts +3 -3
  7. package/dist/blobManager.d.ts.map +1 -1
  8. package/dist/blobManager.js +3 -3
  9. package/dist/blobManager.js.map +1 -1
  10. package/dist/channelCollection.d.ts +5 -5
  11. package/dist/channelCollection.d.ts.map +1 -1
  12. package/dist/channelCollection.js +44 -11
  13. package/dist/channelCollection.js.map +1 -1
  14. package/dist/connectionTelemetry.d.ts +2 -2
  15. package/dist/connectionTelemetry.d.ts.map +1 -1
  16. package/dist/connectionTelemetry.js +3 -3
  17. package/dist/connectionTelemetry.js.map +1 -1
  18. package/dist/container-runtime-alpha.d.ts +205 -11
  19. package/dist/container-runtime-beta.d.ts +16 -2
  20. package/dist/container-runtime-public.d.ts +16 -2
  21. package/dist/container-runtime-untrimmed.d.ts +205 -24
  22. package/dist/containerHandleContext.d.ts.map +1 -1
  23. package/dist/containerHandleContext.js.map +1 -1
  24. package/dist/containerRuntime.d.ts +32 -26
  25. package/dist/containerRuntime.d.ts.map +1 -1
  26. package/dist/containerRuntime.js +213 -119
  27. package/dist/containerRuntime.js.map +1 -1
  28. package/dist/dataStore.d.ts +1 -1
  29. package/dist/dataStore.d.ts.map +1 -1
  30. package/dist/dataStore.js +2 -2
  31. package/dist/dataStore.js.map +1 -1
  32. package/dist/dataStoreContext.d.ts +4 -4
  33. package/dist/dataStoreContext.d.ts.map +1 -1
  34. package/dist/dataStoreContext.js +18 -18
  35. package/dist/dataStoreContext.js.map +1 -1
  36. package/dist/dataStoreContexts.d.ts.map +1 -1
  37. package/dist/dataStoreContexts.js.map +1 -1
  38. package/dist/dataStoreRegistry.d.ts.map +1 -1
  39. package/dist/dataStoreRegistry.js.map +1 -1
  40. package/dist/deltaScheduler.d.ts +1 -1
  41. package/dist/deltaScheduler.d.ts.map +1 -1
  42. package/dist/deltaScheduler.js +1 -1
  43. package/dist/deltaScheduler.js.map +1 -1
  44. package/dist/gc/garbageCollection.d.ts +1 -1
  45. package/dist/gc/garbageCollection.d.ts.map +1 -1
  46. package/dist/gc/garbageCollection.js +1 -1
  47. package/dist/gc/garbageCollection.js.map +1 -1
  48. package/dist/gc/gcConfigs.d.ts +1 -1
  49. package/dist/gc/gcConfigs.d.ts.map +1 -1
  50. package/dist/gc/gcConfigs.js.map +1 -1
  51. package/dist/gc/gcDefinitions.d.ts +1 -1
  52. package/dist/gc/gcDefinitions.d.ts.map +1 -1
  53. package/dist/gc/gcDefinitions.js.map +1 -1
  54. package/dist/gc/gcHelpers.d.ts.map +1 -1
  55. package/dist/gc/gcHelpers.js.map +1 -1
  56. package/dist/gc/gcSummaryStateTracker.d.ts +1 -1
  57. package/dist/gc/gcSummaryStateTracker.d.ts.map +1 -1
  58. package/dist/gc/gcSummaryStateTracker.js.map +1 -1
  59. package/dist/gc/gcTelemetry.d.ts +1 -1
  60. package/dist/gc/gcTelemetry.d.ts.map +1 -1
  61. package/dist/gc/gcTelemetry.js.map +1 -1
  62. package/dist/index.d.ts +2 -2
  63. package/dist/index.d.ts.map +1 -1
  64. package/dist/index.js +4 -2
  65. package/dist/index.js.map +1 -1
  66. package/dist/messageTypes.d.ts +11 -5
  67. package/dist/messageTypes.d.ts.map +1 -1
  68. package/dist/messageTypes.js +4 -0
  69. package/dist/messageTypes.js.map +1 -1
  70. package/dist/opLifecycle/definitions.d.ts +1 -19
  71. package/dist/opLifecycle/definitions.d.ts.map +1 -1
  72. package/dist/opLifecycle/definitions.js.map +1 -1
  73. package/dist/opLifecycle/index.d.ts +3 -3
  74. package/dist/opLifecycle/index.d.ts.map +1 -1
  75. package/dist/opLifecycle/index.js +3 -1
  76. package/dist/opLifecycle/index.js.map +1 -1
  77. package/dist/opLifecycle/opCompressor.d.ts.map +1 -1
  78. package/dist/opLifecycle/opCompressor.js +2 -3
  79. package/dist/opLifecycle/opCompressor.js.map +1 -1
  80. package/dist/opLifecycle/opDecompressor.d.ts +15 -4
  81. package/dist/opLifecycle/opDecompressor.d.ts.map +1 -1
  82. package/dist/opLifecycle/opDecompressor.js +60 -61
  83. package/dist/opLifecycle/opDecompressor.js.map +1 -1
  84. package/dist/opLifecycle/opGroupingManager.d.ts +2 -1
  85. package/dist/opLifecycle/opGroupingManager.d.ts.map +1 -1
  86. package/dist/opLifecycle/opGroupingManager.js +9 -11
  87. package/dist/opLifecycle/opGroupingManager.js.map +1 -1
  88. package/dist/opLifecycle/opSplitter.d.ts +11 -3
  89. package/dist/opLifecycle/opSplitter.d.ts.map +1 -1
  90. package/dist/opLifecycle/opSplitter.js +48 -38
  91. package/dist/opLifecycle/opSplitter.js.map +1 -1
  92. package/dist/opLifecycle/outbox.d.ts.map +1 -1
  93. package/dist/opLifecycle/outbox.js +7 -12
  94. package/dist/opLifecycle/outbox.js.map +1 -1
  95. package/dist/opLifecycle/remoteMessageProcessor.d.ts +8 -0
  96. package/dist/opLifecycle/remoteMessageProcessor.d.ts.map +1 -1
  97. package/dist/opLifecycle/remoteMessageProcessor.js +36 -35
  98. package/dist/opLifecycle/remoteMessageProcessor.js.map +1 -1
  99. package/dist/packageVersion.d.ts +1 -1
  100. package/dist/packageVersion.js +1 -1
  101. package/dist/packageVersion.js.map +1 -1
  102. package/dist/pendingStateManager.d.ts +1 -1
  103. package/dist/pendingStateManager.d.ts.map +1 -1
  104. package/dist/pendingStateManager.js.map +1 -1
  105. package/dist/scheduleManager.d.ts +1 -1
  106. package/dist/scheduleManager.d.ts.map +1 -1
  107. package/dist/scheduleManager.js +2 -2
  108. package/dist/scheduleManager.js.map +1 -1
  109. package/dist/summary/documentSchema.d.ts +178 -0
  110. package/dist/summary/documentSchema.d.ts.map +1 -0
  111. package/dist/summary/documentSchema.js +345 -0
  112. package/dist/summary/documentSchema.js.map +1 -0
  113. package/dist/summary/index.d.ts +2 -1
  114. package/dist/summary/index.d.ts.map +1 -1
  115. package/dist/summary/index.js +4 -1
  116. package/dist/summary/index.js.map +1 -1
  117. package/dist/summary/orderedClientElection.d.ts +2 -2
  118. package/dist/summary/orderedClientElection.d.ts.map +1 -1
  119. package/dist/summary/orderedClientElection.js +3 -2
  120. package/dist/summary/orderedClientElection.js.map +1 -1
  121. package/dist/summary/runWhileConnectedCoordinator.d.ts +1 -1
  122. package/dist/summary/runWhileConnectedCoordinator.d.ts.map +1 -1
  123. package/dist/summary/runWhileConnectedCoordinator.js.map +1 -1
  124. package/dist/summary/runningSummarizer.d.ts +2 -2
  125. package/dist/summary/runningSummarizer.d.ts.map +1 -1
  126. package/dist/summary/runningSummarizer.js +2 -2
  127. package/dist/summary/runningSummarizer.js.map +1 -1
  128. package/dist/summary/summarizer.d.ts +2 -2
  129. package/dist/summary/summarizer.d.ts.map +1 -1
  130. package/dist/summary/summarizer.js +2 -2
  131. package/dist/summary/summarizer.js.map +1 -1
  132. package/dist/summary/summarizerClientElection.d.ts +2 -2
  133. package/dist/summary/summarizerClientElection.d.ts.map +1 -1
  134. package/dist/summary/summarizerClientElection.js.map +1 -1
  135. package/dist/summary/summarizerHeuristics.d.ts +1 -1
  136. package/dist/summary/summarizerHeuristics.d.ts.map +1 -1
  137. package/dist/summary/summarizerHeuristics.js.map +1 -1
  138. package/dist/summary/summarizerNode/summarizerNode.d.ts +2 -2
  139. package/dist/summary/summarizerNode/summarizerNode.d.ts.map +1 -1
  140. package/dist/summary/summarizerNode/summarizerNode.js +3 -3
  141. package/dist/summary/summarizerNode/summarizerNode.js.map +1 -1
  142. package/dist/summary/summarizerNode/summarizerNodeUtils.d.ts +1 -1
  143. package/dist/summary/summarizerNode/summarizerNodeUtils.d.ts.map +1 -1
  144. package/dist/summary/summarizerNode/summarizerNodeUtils.js.map +1 -1
  145. package/dist/summary/summarizerNode/summarizerNodeWithGc.d.ts +1 -1
  146. package/dist/summary/summarizerNode/summarizerNodeWithGc.d.ts.map +1 -1
  147. package/dist/summary/summarizerNode/summarizerNodeWithGc.js +1 -1
  148. package/dist/summary/summarizerNode/summarizerNodeWithGc.js.map +1 -1
  149. package/dist/summary/summarizerTypes.d.ts +3 -3
  150. package/dist/summary/summarizerTypes.d.ts.map +1 -1
  151. package/dist/summary/summarizerTypes.js.map +1 -1
  152. package/dist/summary/summaryCollection.d.ts +2 -2
  153. package/dist/summary/summaryCollection.d.ts.map +1 -1
  154. package/dist/summary/summaryCollection.js +1 -1
  155. package/dist/summary/summaryCollection.js.map +1 -1
  156. package/dist/summary/summaryFormat.d.ts +5 -16
  157. package/dist/summary/summaryFormat.d.ts.map +1 -1
  158. package/dist/summary/summaryFormat.js.map +1 -1
  159. package/dist/summary/summaryGenerator.d.ts +2 -2
  160. package/dist/summary/summaryGenerator.d.ts.map +1 -1
  161. package/dist/summary/summaryGenerator.js +2 -2
  162. package/dist/summary/summaryGenerator.js.map +1 -1
  163. package/dist/summary/summaryManager.d.ts +1 -1
  164. package/dist/summary/summaryManager.d.ts.map +1 -1
  165. package/dist/summary/summaryManager.js +2 -2
  166. package/dist/summary/summaryManager.js.map +1 -1
  167. package/lib/batchTracker.d.ts +1 -1
  168. package/lib/batchTracker.d.ts.map +1 -1
  169. package/lib/batchTracker.js +2 -2
  170. package/lib/batchTracker.js.map +1 -1
  171. package/lib/blobManager.d.ts +3 -3
  172. package/lib/blobManager.d.ts.map +1 -1
  173. package/lib/blobManager.js +5 -5
  174. package/lib/blobManager.js.map +1 -1
  175. package/lib/channelCollection.d.ts +5 -5
  176. package/lib/channelCollection.d.ts.map +1 -1
  177. package/lib/channelCollection.js +46 -13
  178. package/lib/channelCollection.js.map +1 -1
  179. package/lib/connectionTelemetry.d.ts +2 -2
  180. package/lib/connectionTelemetry.d.ts.map +1 -1
  181. package/lib/connectionTelemetry.js +3 -3
  182. package/lib/connectionTelemetry.js.map +1 -1
  183. package/lib/container-runtime-alpha.d.ts +205 -11
  184. package/lib/container-runtime-beta.d.ts +16 -2
  185. package/lib/container-runtime-public.d.ts +16 -2
  186. package/lib/container-runtime-untrimmed.d.ts +205 -24
  187. package/lib/containerHandleContext.d.ts.map +1 -1
  188. package/lib/containerHandleContext.js.map +1 -1
  189. package/lib/containerRuntime.d.ts +32 -26
  190. package/lib/containerRuntime.d.ts.map +1 -1
  191. package/lib/containerRuntime.js +175 -81
  192. package/lib/containerRuntime.js.map +1 -1
  193. package/lib/dataStore.d.ts +1 -1
  194. package/lib/dataStore.d.ts.map +1 -1
  195. package/lib/dataStore.js +2 -2
  196. package/lib/dataStore.js.map +1 -1
  197. package/lib/dataStoreContext.d.ts +4 -4
  198. package/lib/dataStoreContext.d.ts.map +1 -1
  199. package/lib/dataStoreContext.js +3 -3
  200. package/lib/dataStoreContext.js.map +1 -1
  201. package/lib/dataStoreContexts.d.ts.map +1 -1
  202. package/lib/dataStoreContexts.js.map +1 -1
  203. package/lib/dataStoreRegistry.d.ts.map +1 -1
  204. package/lib/dataStoreRegistry.js.map +1 -1
  205. package/lib/deltaScheduler.d.ts +1 -1
  206. package/lib/deltaScheduler.d.ts.map +1 -1
  207. package/lib/deltaScheduler.js +1 -1
  208. package/lib/deltaScheduler.js.map +1 -1
  209. package/lib/gc/garbageCollection.d.ts +1 -1
  210. package/lib/gc/garbageCollection.d.ts.map +1 -1
  211. package/lib/gc/garbageCollection.js +3 -3
  212. package/lib/gc/garbageCollection.js.map +1 -1
  213. package/lib/gc/gcConfigs.d.ts +1 -1
  214. package/lib/gc/gcConfigs.d.ts.map +1 -1
  215. package/lib/gc/gcConfigs.js +1 -1
  216. package/lib/gc/gcConfigs.js.map +1 -1
  217. package/lib/gc/gcDefinitions.d.ts +1 -1
  218. package/lib/gc/gcDefinitions.d.ts.map +1 -1
  219. package/lib/gc/gcDefinitions.js.map +1 -1
  220. package/lib/gc/gcHelpers.d.ts.map +1 -1
  221. package/lib/gc/gcHelpers.js.map +1 -1
  222. package/lib/gc/gcSummaryStateTracker.d.ts +1 -1
  223. package/lib/gc/gcSummaryStateTracker.d.ts.map +1 -1
  224. package/lib/gc/gcSummaryStateTracker.js +1 -1
  225. package/lib/gc/gcSummaryStateTracker.js.map +1 -1
  226. package/lib/gc/gcTelemetry.d.ts +1 -1
  227. package/lib/gc/gcTelemetry.d.ts.map +1 -1
  228. package/lib/gc/gcTelemetry.js +1 -1
  229. package/lib/gc/gcTelemetry.js.map +1 -1
  230. package/lib/index.d.ts +2 -2
  231. package/lib/index.d.ts.map +1 -1
  232. package/lib/index.js +2 -2
  233. package/lib/index.js.map +1 -1
  234. package/lib/messageTypes.d.ts +11 -5
  235. package/lib/messageTypes.d.ts.map +1 -1
  236. package/lib/messageTypes.js +4 -0
  237. package/lib/messageTypes.js.map +1 -1
  238. package/lib/opLifecycle/definitions.d.ts +1 -19
  239. package/lib/opLifecycle/definitions.d.ts.map +1 -1
  240. package/lib/opLifecycle/definitions.js.map +1 -1
  241. package/lib/opLifecycle/index.d.ts +3 -3
  242. package/lib/opLifecycle/index.d.ts.map +1 -1
  243. package/lib/opLifecycle/index.js +2 -2
  244. package/lib/opLifecycle/index.js.map +1 -1
  245. package/lib/opLifecycle/opCompressor.d.ts.map +1 -1
  246. package/lib/opLifecycle/opCompressor.js +2 -3
  247. package/lib/opLifecycle/opCompressor.js.map +1 -1
  248. package/lib/opLifecycle/opDecompressor.d.ts +15 -4
  249. package/lib/opLifecycle/opDecompressor.d.ts.map +1 -1
  250. package/lib/opLifecycle/opDecompressor.js +60 -61
  251. package/lib/opLifecycle/opDecompressor.js.map +1 -1
  252. package/lib/opLifecycle/opGroupingManager.d.ts +2 -1
  253. package/lib/opLifecycle/opGroupingManager.d.ts.map +1 -1
  254. package/lib/opLifecycle/opGroupingManager.js +7 -10
  255. package/lib/opLifecycle/opGroupingManager.js.map +1 -1
  256. package/lib/opLifecycle/opSplitter.d.ts +11 -3
  257. package/lib/opLifecycle/opSplitter.d.ts.map +1 -1
  258. package/lib/opLifecycle/opSplitter.js +46 -37
  259. package/lib/opLifecycle/opSplitter.js.map +1 -1
  260. package/lib/opLifecycle/outbox.d.ts.map +1 -1
  261. package/lib/opLifecycle/outbox.js +7 -12
  262. package/lib/opLifecycle/outbox.js.map +1 -1
  263. package/lib/opLifecycle/remoteMessageProcessor.d.ts +8 -0
  264. package/lib/opLifecycle/remoteMessageProcessor.d.ts.map +1 -1
  265. package/lib/opLifecycle/remoteMessageProcessor.js +36 -35
  266. package/lib/opLifecycle/remoteMessageProcessor.js.map +1 -1
  267. package/lib/packageVersion.d.ts +1 -1
  268. package/lib/packageVersion.js +1 -1
  269. package/lib/packageVersion.js.map +1 -1
  270. package/lib/pendingStateManager.d.ts +1 -1
  271. package/lib/pendingStateManager.d.ts.map +1 -1
  272. package/lib/pendingStateManager.js.map +1 -1
  273. package/lib/scheduleManager.d.ts +1 -1
  274. package/lib/scheduleManager.d.ts.map +1 -1
  275. package/lib/scheduleManager.js +2 -2
  276. package/lib/scheduleManager.js.map +1 -1
  277. package/lib/summary/documentSchema.d.ts +178 -0
  278. package/lib/summary/documentSchema.d.ts.map +1 -0
  279. package/lib/summary/documentSchema.js +341 -0
  280. package/lib/summary/documentSchema.js.map +1 -0
  281. package/lib/summary/index.d.ts +2 -1
  282. package/lib/summary/index.d.ts.map +1 -1
  283. package/lib/summary/index.js +1 -0
  284. package/lib/summary/index.js.map +1 -1
  285. package/lib/summary/orderedClientElection.d.ts +2 -2
  286. package/lib/summary/orderedClientElection.d.ts.map +1 -1
  287. package/lib/summary/orderedClientElection.js +3 -2
  288. package/lib/summary/orderedClientElection.js.map +1 -1
  289. package/lib/summary/runWhileConnectedCoordinator.d.ts +1 -1
  290. package/lib/summary/runWhileConnectedCoordinator.d.ts.map +1 -1
  291. package/lib/summary/runWhileConnectedCoordinator.js.map +1 -1
  292. package/lib/summary/runningSummarizer.d.ts +2 -2
  293. package/lib/summary/runningSummarizer.d.ts.map +1 -1
  294. package/lib/summary/runningSummarizer.js +3 -3
  295. package/lib/summary/runningSummarizer.js.map +1 -1
  296. package/lib/summary/summarizer.d.ts +2 -2
  297. package/lib/summary/summarizer.d.ts.map +1 -1
  298. package/lib/summary/summarizer.js +3 -3
  299. package/lib/summary/summarizer.js.map +1 -1
  300. package/lib/summary/summarizerClientElection.d.ts +2 -2
  301. package/lib/summary/summarizerClientElection.d.ts.map +1 -1
  302. package/lib/summary/summarizerClientElection.js.map +1 -1
  303. package/lib/summary/summarizerHeuristics.d.ts +1 -1
  304. package/lib/summary/summarizerHeuristics.d.ts.map +1 -1
  305. package/lib/summary/summarizerHeuristics.js.map +1 -1
  306. package/lib/summary/summarizerNode/summarizerNode.d.ts +2 -2
  307. package/lib/summary/summarizerNode/summarizerNode.d.ts.map +1 -1
  308. package/lib/summary/summarizerNode/summarizerNode.js +4 -4
  309. package/lib/summary/summarizerNode/summarizerNode.js.map +1 -1
  310. package/lib/summary/summarizerNode/summarizerNodeUtils.d.ts +1 -1
  311. package/lib/summary/summarizerNode/summarizerNodeUtils.d.ts.map +1 -1
  312. package/lib/summary/summarizerNode/summarizerNodeUtils.js.map +1 -1
  313. package/lib/summary/summarizerNode/summarizerNodeWithGc.d.ts +1 -1
  314. package/lib/summary/summarizerNode/summarizerNodeWithGc.d.ts.map +1 -1
  315. package/lib/summary/summarizerNode/summarizerNodeWithGc.js +1 -1
  316. package/lib/summary/summarizerNode/summarizerNodeWithGc.js.map +1 -1
  317. package/lib/summary/summarizerTypes.d.ts +3 -3
  318. package/lib/summary/summarizerTypes.d.ts.map +1 -1
  319. package/lib/summary/summarizerTypes.js.map +1 -1
  320. package/lib/summary/summaryCollection.d.ts +2 -2
  321. package/lib/summary/summaryCollection.d.ts.map +1 -1
  322. package/lib/summary/summaryCollection.js +1 -1
  323. package/lib/summary/summaryCollection.js.map +1 -1
  324. package/lib/summary/summaryFormat.d.ts +5 -16
  325. package/lib/summary/summaryFormat.d.ts.map +1 -1
  326. package/lib/summary/summaryFormat.js +1 -1
  327. package/lib/summary/summaryFormat.js.map +1 -1
  328. package/lib/summary/summaryGenerator.d.ts +2 -2
  329. package/lib/summary/summaryGenerator.d.ts.map +1 -1
  330. package/lib/summary/summaryGenerator.js +3 -3
  331. package/lib/summary/summaryGenerator.js.map +1 -1
  332. package/lib/summary/summaryManager.d.ts +1 -1
  333. package/lib/summary/summaryManager.d.ts.map +1 -1
  334. package/lib/summary/summaryManager.js +2 -2
  335. package/lib/summary/summaryManager.js.map +1 -1
  336. package/lib/test/blobManager.spec.js +3 -3
  337. package/lib/test/blobManager.spec.js.map +1 -1
  338. package/lib/test/containerRuntime.spec.js +6 -4
  339. package/lib/test/containerRuntime.spec.js.map +1 -1
  340. package/lib/test/dataStoreContext.spec.js +4 -4
  341. package/lib/test/dataStoreContext.spec.js.map +1 -1
  342. package/lib/test/dataStoreCreation.spec.js +1 -1
  343. package/lib/test/dataStoreCreation.spec.js.map +1 -1
  344. package/lib/test/dataStoreRegistry.spec.js.map +1 -1
  345. package/lib/test/documentSchema.spec.js +282 -0
  346. package/lib/test/documentSchema.spec.js.map +1 -0
  347. package/lib/test/fuzz/fuzzUtils.js +11 -7
  348. package/lib/test/fuzz/fuzzUtils.js.map +1 -1
  349. package/lib/test/fuzz/summarizer.fuzz.spec.js +9 -7
  350. package/lib/test/fuzz/summarizer.fuzz.spec.js.map +1 -1
  351. package/lib/test/fuzz/summarizerFuzzMocks.js +43 -25
  352. package/lib/test/fuzz/summarizerFuzzMocks.js.map +1 -1
  353. package/lib/test/fuzz/summarizerFuzzSuite.js +7 -4
  354. package/lib/test/fuzz/summarizerFuzzSuite.js.map +1 -1
  355. package/lib/test/gc/garbageCollection.spec.js +5 -5
  356. package/lib/test/gc/garbageCollection.spec.js.map +1 -1
  357. package/lib/test/gc/gcConfigs.spec.js +2 -2
  358. package/lib/test/gc/gcConfigs.spec.js.map +1 -1
  359. package/lib/test/gc/gcHelpers.spec.js.map +1 -1
  360. package/lib/test/gc/gcStats.spec.js +2 -2
  361. package/lib/test/gc/gcStats.spec.js.map +1 -1
  362. package/lib/test/gc/gcSummaryStateTracker.spec.js +1 -1
  363. package/lib/test/gc/gcSummaryStateTracker.spec.js.map +1 -1
  364. package/lib/test/gc/gcTelemetry.spec.js +3 -3
  365. package/lib/test/gc/gcTelemetry.spec.js.map +1 -1
  366. package/lib/test/gc/gcUnreferencedStateTracker.spec.js +1 -1
  367. package/lib/test/gc/gcUnreferencedStateTracker.spec.js.map +1 -1
  368. package/lib/test/getPendingBlobs.spec.js +1 -1
  369. package/lib/test/getPendingBlobs.spec.js.map +1 -1
  370. package/lib/test/hardwareStats.spec.js +1 -1
  371. package/lib/test/hardwareStats.spec.js.map +1 -1
  372. package/lib/test/opLifecycle/OpGroupingManager.spec.js +95 -118
  373. package/lib/test/opLifecycle/OpGroupingManager.spec.js.map +1 -1
  374. package/lib/test/opLifecycle/batchManager.spec.js +1 -1
  375. package/lib/test/opLifecycle/batchManager.spec.js.map +1 -1
  376. package/lib/test/opLifecycle/opCompressor.spec.js +0 -1
  377. package/lib/test/opLifecycle/opCompressor.spec.js.map +1 -1
  378. package/lib/test/opLifecycle/opDecompressor.spec.js +60 -55
  379. package/lib/test/opLifecycle/opDecompressor.spec.js.map +1 -1
  380. package/lib/test/opLifecycle/opSplitter.spec.js +56 -41
  381. package/lib/test/opLifecycle/opSplitter.spec.js.map +1 -1
  382. package/lib/test/opLifecycle/outbox.spec.js +118 -10
  383. package/lib/test/opLifecycle/outbox.spec.js.map +1 -1
  384. package/lib/test/opLifecycle/remoteMessageProcessor.spec.js +115 -91
  385. package/lib/test/opLifecycle/remoteMessageProcessor.spec.js.map +1 -1
  386. package/lib/test/pendingStateManager.spec.js +1 -1
  387. package/lib/test/pendingStateManager.spec.js.map +1 -1
  388. package/lib/test/scheduleManager.spec.js +1 -1
  389. package/lib/test/scheduleManager.spec.js.map +1 -1
  390. package/lib/test/summarizerNode.spec.js +1 -1
  391. package/lib/test/summarizerNode.spec.js.map +1 -1
  392. package/lib/test/summarizerNodeWithGc.spec.js +1 -1
  393. package/lib/test/summarizerNodeWithGc.spec.js.map +1 -1
  394. package/lib/test/summary/runningSummarizer.spec.js +4 -4
  395. package/lib/test/summary/runningSummarizer.spec.js.map +1 -1
  396. package/lib/test/summary/summarizer.spec.js.map +1 -1
  397. package/lib/test/summary/summarizerClientElection.spec.js +2 -2
  398. package/lib/test/summary/summarizerClientElection.spec.js.map +1 -1
  399. package/lib/test/summary/summarizerHeuristics.spec.js +1 -1
  400. package/lib/test/summary/summarizerHeuristics.spec.js.map +1 -1
  401. package/lib/test/summary/summaryCollection.spec.js +1 -1
  402. package/lib/test/summary/summaryCollection.spec.js.map +1 -1
  403. package/lib/test/summary/summaryManager.spec.js +3 -3
  404. package/lib/test/summary/summaryManager.spec.js.map +1 -1
  405. package/lib/test/throttler.spec.js +1 -1
  406. package/lib/test/throttler.spec.js.map +1 -1
  407. package/lib/test/types/validateContainerRuntimePrevious.generated.js +6 -4
  408. package/lib/test/types/validateContainerRuntimePrevious.generated.js.map +1 -1
  409. package/package.json +35 -21
  410. package/src/batchTracker.ts +3 -3
  411. package/src/blobManager.ts +15 -15
  412. package/src/channelCollection.ts +75 -35
  413. package/src/connectionTelemetry.ts +10 -10
  414. package/src/containerHandleContext.ts +1 -1
  415. package/src/containerRuntime.ts +352 -197
  416. package/src/dataStore.ts +2 -2
  417. package/src/dataStoreContext.ts +19 -19
  418. package/src/dataStoreContexts.ts +2 -2
  419. package/src/dataStoreRegistry.ts +1 -1
  420. package/src/deltaScheduler.ts +1 -1
  421. package/src/gc/garbageCollection.ts +12 -12
  422. package/src/gc/gcConfigs.ts +11 -11
  423. package/src/gc/gcDefinitions.ts +2 -2
  424. package/src/gc/gcHelpers.ts +2 -2
  425. package/src/gc/gcSummaryStateTracker.ts +4 -4
  426. package/src/gc/gcTelemetry.ts +6 -6
  427. package/src/index.ts +8 -1
  428. package/src/messageTypes.ts +18 -5
  429. package/src/opLifecycle/README.md +89 -0
  430. package/src/opLifecycle/definitions.ts +1 -20
  431. package/src/opLifecycle/index.ts +3 -9
  432. package/src/opLifecycle/opCompressor.ts +4 -5
  433. package/src/opLifecycle/opDecompressor.ts +83 -100
  434. package/src/opLifecycle/opGroupingManager.ts +9 -12
  435. package/src/opLifecycle/opSplitter.ts +73 -47
  436. package/src/opLifecycle/outbox.ts +13 -31
  437. package/src/opLifecycle/remoteMessageProcessor.ts +41 -59
  438. package/src/packageVersion.ts +1 -1
  439. package/src/pendingStateManager.ts +2 -2
  440. package/src/scheduleManager.ts +7 -7
  441. package/src/summary/documentSchema.ts +553 -0
  442. package/src/summary/index.ts +10 -1
  443. package/src/summary/orderedClientElection.ts +6 -5
  444. package/src/summary/runWhileConnectedCoordinator.ts +1 -1
  445. package/src/summary/runningSummarizer.ts +19 -19
  446. package/src/summary/summarizer.ts +14 -14
  447. package/src/summary/summarizerClientElection.ts +2 -2
  448. package/src/summary/summarizerHeuristics.ts +2 -2
  449. package/src/summary/summarizerNode/summarizerNode.ts +15 -15
  450. package/src/summary/summarizerNode/summarizerNodeUtils.ts +1 -1
  451. package/src/summary/summarizerNode/summarizerNodeWithGc.ts +4 -4
  452. package/src/summary/summarizerTypes.ts +3 -3
  453. package/src/summary/summaryCollection.ts +3 -3
  454. package/src/summary/summaryFormat.ts +8 -19
  455. package/src/summary/summaryGenerator.ts +10 -10
  456. package/src/summary/summaryManager.ts +4 -4
@@ -1 +1 @@
1
- {"version":3,"file":"hardwareStats.spec.js","sourceRoot":"","sources":["../../src/test/hardwareStats.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 */\n\nimport assert from \"assert\";\nimport { ITelemetryBaseEvent } from \"@fluidframework/core-interfaces\";\nimport { IContainerContext } from \"@fluidframework/container-definitions\";\nimport { MockDeltaManager, MockQuorumClients } from \"@fluidframework/test-runtime-utils\";\nimport { MockLogger } from \"@fluidframework/telemetry-utils\";\nimport { ContainerRuntime, getDeviceSpec } from \"../containerRuntime.js\";\n\nfunction setNavigator(\n\tnavigator: Partial<Navigator & { deviceMemory?: number }> | undefined | null,\n) {\n\tglobal.navigator = navigator as Navigator;\n}\n\ndescribe(\"Hardware Stats\", () => {\n\tlet mockLogger = new MockLogger();\n\tlet mockContext: Partial<IContainerContext> = {\n\t\tdeltaManager: new MockDeltaManager(),\n\t\tquorum: new MockQuorumClients(),\n\t\ttaggedLogger: mockLogger,\n\t\tclientDetails: { capabilities: { interactive: true } },\n\t\tupdateDirtyContainerState: (dirty: boolean) => {},\n\t\tgetLoadedFromVersion: () => undefined,\n\t};\n\n\tconst getDeviceSpecEvents = (): ITelemetryBaseEvent[] =>\n\t\tmockLogger.events.filter((event) => event.eventName === \"DeviceSpec\");\n\n\tconst loadContainer = async () =>\n\t\tContainerRuntime.loadRuntime({\n\t\t\tcontext: mockContext as IContainerContext,\n\t\t\tregistryEntries: [],\n\t\t\truntimeOptions: {\n\t\t\t\tsummaryOptions: {\n\t\t\t\t\tsummaryConfigOverrides: { state: \"disabled\" },\n\t\t\t\t},\n\t\t\t},\n\t\t\tprovideEntryPoint: async () => ({\n\t\t\t\tmyProp: \"myValue\",\n\t\t\t}),\n\t\t\texisting: false,\n\t\t});\n\n\tbeforeEach(async () => {\n\t\tmockLogger = new MockLogger();\n\t\tmockContext = {\n\t\t\tdeltaManager: new MockDeltaManager(),\n\t\t\tquorum: new MockQuorumClients(),\n\t\t\ttaggedLogger: mockLogger,\n\t\t\tclientDetails: { capabilities: { interactive: true } },\n\t\t\tupdateDirtyContainerState: (dirty: boolean) => {},\n\t\t\tgetLoadedFromVersion: () => undefined,\n\t\t};\n\t});\n\n\tit(\"should generate correct hardware stats with regular navigator\", async () => {\n\t\tconst navigator = {\n\t\t\tdeviceMemory: 10,\n\t\t\thardwareConcurrency: 8,\n\t\t};\n\t\tsetNavigator(navigator);\n\t\t// testing function\n\t\tconst { deviceMemory, hardwareConcurrency } = getDeviceSpec();\n\t\tassert.strictEqual(deviceMemory, 10, \"incorrect deviceMemory value\");\n\t\tassert.strictEqual(hardwareConcurrency, 8, \"incorrect hardwareConcurrency value\");\n\n\t\tawait loadContainer();\n\n\t\t// checking telemetry\n\t\tconst events = getDeviceSpecEvents();\n\t\tassert(events !== undefined, \"No deviceSpec event found\");\n\t\tassert.strictEqual(events[0].deviceMemory, 10, \"incorrect deviceMemory logged\");\n\t\tassert.strictEqual(\n\t\t\tevents[0].hardwareConcurrency,\n\t\t\t8,\n\t\t\t\"incorrect hardwareConcurrency logged\",\n\t\t);\n\t});\n\n\tit(\"should generate correct hardware stats with null navigator\", async () => {\n\t\tconst navigator = null;\n\t\tsetNavigator(navigator);\n\t\t// testing function\n\t\tconst { deviceMemory, hardwareConcurrency } = getDeviceSpec();\n\t\tassert.strictEqual(deviceMemory, undefined, \"incorrect deviceMemory value\");\n\t\tassert.strictEqual(hardwareConcurrency, undefined, \"incorrect hardwareConcurrency value\");\n\n\t\tawait loadContainer();\n\n\t\t// checking telemetry\n\t\tconst events = getDeviceSpecEvents();\n\t\tassert(events !== undefined, \"No deviceSpec event found\");\n\t\tassert.strictEqual(events[0].deviceMemory, undefined, \"incorrect deviceMemory logged\");\n\t\tassert.strictEqual(\n\t\t\tevents[0].hardwareConcurrency,\n\t\t\tundefined,\n\t\t\t\"incorrect hardwareConcurrency logged\",\n\t\t);\n\t});\n\n\tit(\"should generate correct hardware stats with undefined navigator\", async () => {\n\t\tconst navigator = undefined;\n\t\tsetNavigator(navigator);\n\t\t// testing function\n\t\tconst { deviceMemory, hardwareConcurrency } = getDeviceSpec();\n\t\tassert.strictEqual(deviceMemory, undefined, \"incorrect deviceMemory value\");\n\t\tassert.strictEqual(hardwareConcurrency, undefined, \"incorrect hardwareConcurrency value\");\n\n\t\tawait loadContainer();\n\n\t\t// checking telemetry\n\t\tconst events = getDeviceSpecEvents();\n\t\tassert(events !== undefined, \"No deviceSpec event found\");\n\t\tassert.strictEqual(events[0].deviceMemory, undefined, \"incorrect deviceMemory logged\");\n\t\tassert.strictEqual(\n\t\t\tevents[0].hardwareConcurrency,\n\t\t\tundefined,\n\t\t\t\"incorrect hardwareConcurrency logged\",\n\t\t);\n\t});\n});\n"]}
1
+ {"version":3,"file":"hardwareStats.spec.js","sourceRoot":"","sources":["../../src/test/hardwareStats.spec.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,MAAM,MAAM,QAAQ,CAAC;AAG5B,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAEzE,SAAS,YAAY,CACpB,SAA4E;IAE5E,MAAM,CAAC,SAAS,GAAG,SAAsB,CAAC;AAC3C,CAAC;AAED,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC/B,IAAI,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;IAClC,IAAI,WAAW,GAA+B;QAC7C,YAAY,EAAE,IAAI,gBAAgB,EAAE;QACpC,MAAM,EAAE,IAAI,iBAAiB,EAAE;QAC/B,YAAY,EAAE,UAAU;QACxB,aAAa,EAAE,EAAE,YAAY,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,EAAE;QACtD,yBAAyB,EAAE,CAAC,KAAc,EAAE,EAAE,GAAE,CAAC;QACjD,oBAAoB,EAAE,GAAG,EAAE,CAAC,SAAS;KACrC,CAAC;IAEF,MAAM,mBAAmB,GAAG,GAA0B,EAAE,CACvD,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC;IAEvE,MAAM,aAAa,GAAG,KAAK,IAAI,EAAE,CAChC,gBAAgB,CAAC,WAAW,CAAC;QAC5B,OAAO,EAAE,WAAgC;QACzC,eAAe,EAAE,EAAE;QACnB,cAAc,EAAE;YACf,cAAc,EAAE;gBACf,sBAAsB,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE;aAC7C;SACD;QACD,iBAAiB,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;YAC/B,MAAM,EAAE,SAAS;SACjB,CAAC;QACF,QAAQ,EAAE,KAAK;KACf,CAAC,CAAC;IAEJ,UAAU,CAAC,KAAK,IAAI,EAAE;QACrB,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;QAC9B,WAAW,GAAG;YACb,YAAY,EAAE,IAAI,gBAAgB,EAAE;YACpC,MAAM,EAAE,IAAI,iBAAiB,EAAE;YAC/B,YAAY,EAAE,UAAU;YACxB,aAAa,EAAE,EAAE,YAAY,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,EAAE;YACtD,yBAAyB,EAAE,CAAC,KAAc,EAAE,EAAE,GAAE,CAAC;YACjD,oBAAoB,EAAE,GAAG,EAAE,CAAC,SAAS;SACrC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+DAA+D,EAAE,KAAK,IAAI,EAAE;QAC9E,MAAM,SAAS,GAAG;YACjB,YAAY,EAAE,EAAE;YAChB,mBAAmB,EAAE,CAAC;SACtB,CAAC;QACF,YAAY,CAAC,SAAS,CAAC,CAAC;QACxB,mBAAmB;QACnB,MAAM,EAAE,YAAY,EAAE,mBAAmB,EAAE,GAAG,aAAa,EAAE,CAAC;QAC9D,MAAM,CAAC,WAAW,CAAC,YAAY,EAAE,EAAE,EAAE,8BAA8B,CAAC,CAAC;QACrE,MAAM,CAAC,WAAW,CAAC,mBAAmB,EAAE,CAAC,EAAE,qCAAqC,CAAC,CAAC;QAElF,MAAM,aAAa,EAAE,CAAC;QAEtB,qBAAqB;QACrB,MAAM,MAAM,GAAG,mBAAmB,EAAE,CAAC;QACrC,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,2BAA2B,CAAC,CAAC;QAC1D,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,EAAE,EAAE,+BAA+B,CAAC,CAAC;QAChF,MAAM,CAAC,WAAW,CACjB,MAAM,CAAC,CAAC,CAAC,CAAC,mBAAmB,EAC7B,CAAC,EACD,sCAAsC,CACtC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4DAA4D,EAAE,KAAK,IAAI,EAAE;QAC3E,MAAM,SAAS,GAAG,IAAI,CAAC;QACvB,YAAY,CAAC,SAAS,CAAC,CAAC;QACxB,mBAAmB;QACnB,MAAM,EAAE,YAAY,EAAE,mBAAmB,EAAE,GAAG,aAAa,EAAE,CAAC;QAC9D,MAAM,CAAC,WAAW,CAAC,YAAY,EAAE,SAAS,EAAE,8BAA8B,CAAC,CAAC;QAC5E,MAAM,CAAC,WAAW,CAAC,mBAAmB,EAAE,SAAS,EAAE,qCAAqC,CAAC,CAAC;QAE1F,MAAM,aAAa,EAAE,CAAC;QAEtB,qBAAqB;QACrB,MAAM,MAAM,GAAG,mBAAmB,EAAE,CAAC;QACrC,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,2BAA2B,CAAC,CAAC;QAC1D,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,SAAS,EAAE,+BAA+B,CAAC,CAAC;QACvF,MAAM,CAAC,WAAW,CACjB,MAAM,CAAC,CAAC,CAAC,CAAC,mBAAmB,EAC7B,SAAS,EACT,sCAAsC,CACtC,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE,KAAK,IAAI,EAAE;QAChF,MAAM,SAAS,GAAG,SAAS,CAAC;QAC5B,YAAY,CAAC,SAAS,CAAC,CAAC;QACxB,mBAAmB;QACnB,MAAM,EAAE,YAAY,EAAE,mBAAmB,EAAE,GAAG,aAAa,EAAE,CAAC;QAC9D,MAAM,CAAC,WAAW,CAAC,YAAY,EAAE,SAAS,EAAE,8BAA8B,CAAC,CAAC;QAC5E,MAAM,CAAC,WAAW,CAAC,mBAAmB,EAAE,SAAS,EAAE,qCAAqC,CAAC,CAAC;QAE1F,MAAM,aAAa,EAAE,CAAC;QAEtB,qBAAqB;QACrB,MAAM,MAAM,GAAG,mBAAmB,EAAE,CAAC;QACrC,MAAM,CAAC,MAAM,KAAK,SAAS,EAAE,2BAA2B,CAAC,CAAC;QAC1D,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,YAAY,EAAE,SAAS,EAAE,+BAA+B,CAAC,CAAC;QACvF,MAAM,CAAC,WAAW,CACjB,MAAM,CAAC,CAAC,CAAC,CAAC,mBAAmB,EAC7B,SAAS,EACT,sCAAsC,CACtC,CAAC;IACH,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 */\n\nimport assert from \"assert\";\nimport { IContainerContext } from \"@fluidframework/container-definitions\";\nimport { ITelemetryBaseEvent } from \"@fluidframework/core-interfaces\";\nimport { MockLogger } from \"@fluidframework/telemetry-utils\";\nimport { MockDeltaManager, MockQuorumClients } from \"@fluidframework/test-runtime-utils\";\nimport { ContainerRuntime, getDeviceSpec } from \"../containerRuntime.js\";\n\nfunction setNavigator(\n\tnavigator: Partial<Navigator & { deviceMemory?: number }> | undefined | null,\n) {\n\tglobal.navigator = navigator as Navigator;\n}\n\ndescribe(\"Hardware Stats\", () => {\n\tlet mockLogger = new MockLogger();\n\tlet mockContext: Partial<IContainerContext> = {\n\t\tdeltaManager: new MockDeltaManager(),\n\t\tquorum: new MockQuorumClients(),\n\t\ttaggedLogger: mockLogger,\n\t\tclientDetails: { capabilities: { interactive: true } },\n\t\tupdateDirtyContainerState: (dirty: boolean) => {},\n\t\tgetLoadedFromVersion: () => undefined,\n\t};\n\n\tconst getDeviceSpecEvents = (): ITelemetryBaseEvent[] =>\n\t\tmockLogger.events.filter((event) => event.eventName === \"DeviceSpec\");\n\n\tconst loadContainer = async () =>\n\t\tContainerRuntime.loadRuntime({\n\t\t\tcontext: mockContext as IContainerContext,\n\t\t\tregistryEntries: [],\n\t\t\truntimeOptions: {\n\t\t\t\tsummaryOptions: {\n\t\t\t\t\tsummaryConfigOverrides: { state: \"disabled\" },\n\t\t\t\t},\n\t\t\t},\n\t\t\tprovideEntryPoint: async () => ({\n\t\t\t\tmyProp: \"myValue\",\n\t\t\t}),\n\t\t\texisting: false,\n\t\t});\n\n\tbeforeEach(async () => {\n\t\tmockLogger = new MockLogger();\n\t\tmockContext = {\n\t\t\tdeltaManager: new MockDeltaManager(),\n\t\t\tquorum: new MockQuorumClients(),\n\t\t\ttaggedLogger: mockLogger,\n\t\t\tclientDetails: { capabilities: { interactive: true } },\n\t\t\tupdateDirtyContainerState: (dirty: boolean) => {},\n\t\t\tgetLoadedFromVersion: () => undefined,\n\t\t};\n\t});\n\n\tit(\"should generate correct hardware stats with regular navigator\", async () => {\n\t\tconst navigator = {\n\t\t\tdeviceMemory: 10,\n\t\t\thardwareConcurrency: 8,\n\t\t};\n\t\tsetNavigator(navigator);\n\t\t// testing function\n\t\tconst { deviceMemory, hardwareConcurrency } = getDeviceSpec();\n\t\tassert.strictEqual(deviceMemory, 10, \"incorrect deviceMemory value\");\n\t\tassert.strictEqual(hardwareConcurrency, 8, \"incorrect hardwareConcurrency value\");\n\n\t\tawait loadContainer();\n\n\t\t// checking telemetry\n\t\tconst events = getDeviceSpecEvents();\n\t\tassert(events !== undefined, \"No deviceSpec event found\");\n\t\tassert.strictEqual(events[0].deviceMemory, 10, \"incorrect deviceMemory logged\");\n\t\tassert.strictEqual(\n\t\t\tevents[0].hardwareConcurrency,\n\t\t\t8,\n\t\t\t\"incorrect hardwareConcurrency logged\",\n\t\t);\n\t});\n\n\tit(\"should generate correct hardware stats with null navigator\", async () => {\n\t\tconst navigator = null;\n\t\tsetNavigator(navigator);\n\t\t// testing function\n\t\tconst { deviceMemory, hardwareConcurrency } = getDeviceSpec();\n\t\tassert.strictEqual(deviceMemory, undefined, \"incorrect deviceMemory value\");\n\t\tassert.strictEqual(hardwareConcurrency, undefined, \"incorrect hardwareConcurrency value\");\n\n\t\tawait loadContainer();\n\n\t\t// checking telemetry\n\t\tconst events = getDeviceSpecEvents();\n\t\tassert(events !== undefined, \"No deviceSpec event found\");\n\t\tassert.strictEqual(events[0].deviceMemory, undefined, \"incorrect deviceMemory logged\");\n\t\tassert.strictEqual(\n\t\t\tevents[0].hardwareConcurrency,\n\t\t\tundefined,\n\t\t\t\"incorrect hardwareConcurrency logged\",\n\t\t);\n\t});\n\n\tit(\"should generate correct hardware stats with undefined navigator\", async () => {\n\t\tconst navigator = undefined;\n\t\tsetNavigator(navigator);\n\t\t// testing function\n\t\tconst { deviceMemory, hardwareConcurrency } = getDeviceSpec();\n\t\tassert.strictEqual(deviceMemory, undefined, \"incorrect deviceMemory value\");\n\t\tassert.strictEqual(hardwareConcurrency, undefined, \"incorrect hardwareConcurrency value\");\n\n\t\tawait loadContainer();\n\n\t\t// checking telemetry\n\t\tconst events = getDeviceSpecEvents();\n\t\tassert(events !== undefined, \"No deviceSpec event found\");\n\t\tassert.strictEqual(events[0].deviceMemory, undefined, \"incorrect deviceMemory logged\");\n\t\tassert.strictEqual(\n\t\t\tevents[0].hardwareConcurrency,\n\t\t\tundefined,\n\t\t\t\"incorrect hardwareConcurrency logged\",\n\t\t);\n\t});\n});\n"]}
@@ -5,11 +5,11 @@
5
5
  import { strict as assert } from "assert";
6
6
  import { MockLogger } from "@fluidframework/telemetry-utils";
7
7
  import { ContainerMessageType } from "../../index.js";
8
- import { OpGroupingManager } from "../../opLifecycle/index.js";
8
+ import { OpGroupingManager, isGroupedBatch, } from "../../opLifecycle/index.js";
9
9
  describe("OpGroupingManager", () => {
10
10
  const mockLogger = new MockLogger();
11
- const createBatch = (length, hasReentrantOps) => ({
12
- ...messagesToBatch(new Array(length).fill(createMessage(generateStringOfSize(1)))),
11
+ const createBatch = (length, hasReentrantOps, opHasMetadata = false) => ({
12
+ ...messagesToBatch(new Array(length).fill(createMessage(opHasMetadata))),
13
13
  hasReentrantOps,
14
14
  });
15
15
  const messagesToBatch = (messages) => ({
@@ -19,53 +19,76 @@ describe("OpGroupingManager", () => {
19
19
  .reduce((a, b) => a + b),
20
20
  referenceSequenceNumber: messages[0].referenceSequenceNumber,
21
21
  });
22
- const createMessage = (contents) => ({
23
- metadata: { flag: true },
24
- localOpMetadata: undefined,
22
+ const createMessage = (opHasMetadata) => ({
23
+ metadata: opHasMetadata ? { flag: true } : undefined,
25
24
  type: ContainerMessageType.FluidDataStoreOp,
26
- contents,
25
+ contents: "0",
27
26
  referenceSequenceNumber: 0,
28
27
  });
29
- const generateStringOfSize = (sizeInBytes) => new Array(sizeInBytes + 1).join("0");
30
28
  describe("Configs", () => {
31
- it("Grouped batching is disabled", () => {
32
- assert.strictEqual(new OpGroupingManager({
33
- groupedBatchingEnabled: false,
34
- opCountThreshold: 0,
35
- reentrantBatchGroupingEnabled: true,
36
- }, mockLogger).shouldGroup(createBatch(100)), false);
29
+ const options = [
30
+ { enabled: false, expectedResult: false },
31
+ { enabled: true, tooSmall: true, expectedResult: false },
32
+ { enabled: true, reentrant: true, expectedResult: false },
33
+ { enabled: true, reentrant: true, reentryEnabled: true, expectedResult: true },
34
+ { enabled: true, expectedResult: true },
35
+ ];
36
+ options.forEach((option) => {
37
+ it(`shouldGroup: groupedBatchingEnabled [${option.enabled}] tooSmall [${option.tooSmall === true}] reentrant [${option.reentrant === true}] reentryEnabled [${option.reentryEnabled === true}]`, () => {
38
+ assert.strictEqual(new OpGroupingManager({
39
+ groupedBatchingEnabled: option.enabled,
40
+ opCountThreshold: option.tooSmall === true ? 10 : 2,
41
+ reentrantBatchGroupingEnabled: option.reentryEnabled ?? false,
42
+ }, mockLogger).shouldGroup(createBatch(5, option.reentrant)), option.expectedResult);
43
+ });
37
44
  });
38
- it("Grouped batching is enabled but the batch is too small", () => {
39
- assert.strictEqual(new OpGroupingManager({
40
- groupedBatchingEnabled: true,
41
- opCountThreshold: 10,
42
- reentrantBatchGroupingEnabled: true,
43
- }, mockLogger).shouldGroup(createBatch(5)), false);
45
+ });
46
+ describe("groupBatch", () => {
47
+ it("grouped batching disabled", () => {
48
+ assert.throws(() => {
49
+ new OpGroupingManager({
50
+ groupedBatchingEnabled: false,
51
+ opCountThreshold: 2,
52
+ reentrantBatchGroupingEnabled: false,
53
+ }, mockLogger).groupBatch(createBatch(5));
54
+ });
44
55
  });
45
- it("Grouped batching is enabled, the batch is large enough, but it is reentrant", () => {
46
- assert.strictEqual(new OpGroupingManager({
56
+ it("grouped batching enabled", () => {
57
+ const result = new OpGroupingManager({
47
58
  groupedBatchingEnabled: true,
48
59
  opCountThreshold: 2,
49
60
  reentrantBatchGroupingEnabled: false,
50
- }, mockLogger).shouldGroup(createBatch(5, true)), false);
61
+ }, mockLogger).groupBatch(createBatch(5));
62
+ assert.strictEqual(result.content.length, 1);
63
+ assert.deepStrictEqual(result.content, [
64
+ {
65
+ contents: '{"type":"groupedBatch","contents":[{"contents":0},{"contents":0},{"contents":0},{"contents":0},{"contents":0}]}',
66
+ metadata: undefined,
67
+ referenceSequenceNumber: 0,
68
+ },
69
+ ]);
51
70
  });
52
- it("Grouped batching is enabled, the batch is large enough, and it is reentrant", () => {
53
- assert.strictEqual(new OpGroupingManager({
54
- groupedBatchingEnabled: true,
55
- opCountThreshold: 2,
56
- reentrantBatchGroupingEnabled: true,
57
- }, mockLogger).shouldGroup(createBatch(5, true)), true);
71
+ it("grouped batching enabled, not large enough", () => {
72
+ assert.throws(() => {
73
+ new OpGroupingManager({
74
+ groupedBatchingEnabled: true,
75
+ opCountThreshold: 10,
76
+ reentrantBatchGroupingEnabled: false,
77
+ }, mockLogger).groupBatch(createBatch(5));
78
+ });
58
79
  });
59
- it("Grouped batching is enabled and the batch is large enough", () => {
60
- assert.strictEqual(new OpGroupingManager({
61
- groupedBatchingEnabled: true,
62
- opCountThreshold: 2,
63
- reentrantBatchGroupingEnabled: false,
64
- }, mockLogger).shouldGroup(createBatch(5)), true);
80
+ it("grouped batching enabled, op metadata not allowed", () => {
81
+ assert.throws(() => {
82
+ new OpGroupingManager({
83
+ groupedBatchingEnabled: true,
84
+ opCountThreshold: 2,
85
+ reentrantBatchGroupingEnabled: false,
86
+ }, mockLogger).groupBatch(createBatch(5, false, true));
87
+ });
65
88
  });
66
89
  });
67
- describe("Fakes clientSequenceNumber when ungrouping", () => {
68
- it("grouped op", () => {
90
+ describe("ungroupOp", () => {
91
+ it("packed grouped op", () => {
69
92
  const opGroupingManager = new OpGroupingManager({
70
93
  groupedBatchingEnabled: true,
71
94
  opCountThreshold: 2,
@@ -88,6 +111,7 @@ describe("OpGroupingManager", () => {
88
111
  ],
89
112
  },
90
113
  };
114
+ assert.strictEqual(isGroupedBatch(op), true);
91
115
  const result = opGroupingManager.ungroupOp(op);
92
116
  assert.deepStrictEqual(result, [
93
117
  {
@@ -120,13 +144,8 @@ describe("OpGroupingManager", () => {
120
144
  clientSequenceNumber: 10,
121
145
  contents: "1",
122
146
  };
123
- const result = opGroupingManager.ungroupOp(op);
124
- assert.deepStrictEqual(result, [
125
- {
126
- clientSequenceNumber: 10,
127
- contents: "1",
128
- },
129
- ]);
147
+ assert.strictEqual(isGroupedBatch(op), false);
148
+ assert.throws(() => opGroupingManager.ungroupOp(op));
130
149
  });
131
150
  it("non-grouped op with grouped batching disabled", () => {
132
151
  const opGroupingManager = new OpGroupingManager({
@@ -138,88 +157,46 @@ describe("OpGroupingManager", () => {
138
157
  clientSequenceNumber: 10,
139
158
  contents: "1",
140
159
  };
141
- const result = opGroupingManager.ungroupOp(op);
142
- assert.deepStrictEqual(result, [
143
- {
144
- clientSequenceNumber: 10,
145
- contents: "1",
146
- },
147
- ]);
160
+ assert.strictEqual(isGroupedBatch(op), false);
161
+ assert.throws(() => opGroupingManager.ungroupOp(op));
148
162
  });
149
- });
150
- it("Ungrouping multiple times does not mess up groupedBatch messages", () => {
151
- const groupedBatch = {
152
- type: "op",
153
- sequenceNumber: 10,
154
- clientSequenceNumber: 12,
155
- contents: {
156
- type: OpGroupingManager.groupedBatchOp,
157
- contents: [
158
- {
159
- contents: {
160
- type: ContainerMessageType.FluidDataStoreOp,
163
+ it("Ungrouping multiple times is not allowed", () => {
164
+ const groupedBatch = {
165
+ type: "op",
166
+ sequenceNumber: 10,
167
+ clientSequenceNumber: 12,
168
+ contents: {
169
+ type: OpGroupingManager.groupedBatchOp,
170
+ contents: [
171
+ {
161
172
  contents: {
162
- contents: "a",
173
+ type: ContainerMessageType.FluidDataStoreOp,
174
+ contents: {
175
+ contents: "a",
176
+ },
163
177
  },
164
178
  },
165
- },
166
- {
167
- contents: {
168
- type: ContainerMessageType.FluidDataStoreOp,
179
+ {
169
180
  contents: {
170
- contents: "b",
181
+ type: ContainerMessageType.FluidDataStoreOp,
182
+ contents: {
183
+ contents: "b",
184
+ },
171
185
  },
172
186
  },
173
- },
174
- ],
175
- },
176
- };
177
- const opGroupingManager = new OpGroupingManager({
178
- groupedBatchingEnabled: false,
179
- opCountThreshold: 2,
180
- reentrantBatchGroupingEnabled: true,
181
- }, mockLogger);
182
- // Run the groupedBatch through a couple times to ensure it cannot get messed up
183
- let messagesToUngroup = [groupedBatch];
184
- let result = [];
185
- for (let i = 0; i < 4; i++) {
186
- result = [];
187
- for (const message of messagesToUngroup) {
188
- for (const ungroupedOp of opGroupingManager.ungroupOp(message)) {
189
- result.push(ungroupedOp);
190
- }
191
- }
192
- messagesToUngroup = [...result];
193
- }
194
- const expected = [
195
- {
196
- type: "op",
197
- sequenceNumber: 10,
198
- clientSequenceNumber: 1,
199
- metadata: undefined,
200
- compression: undefined,
201
- contents: {
202
- type: ContainerMessageType.FluidDataStoreOp,
203
- contents: {
204
- contents: "a",
205
- },
206
- },
207
- },
208
- {
209
- type: "op",
210
- sequenceNumber: 10,
211
- clientSequenceNumber: 2,
212
- metadata: undefined,
213
- compression: undefined,
214
- contents: {
215
- type: ContainerMessageType.FluidDataStoreOp,
216
- contents: {
217
- contents: "b",
218
- },
187
+ ],
219
188
  },
220
- },
221
- ];
222
- assert.deepStrictEqual(result, expected, "ungrouping should work as expected");
189
+ };
190
+ const opGroupingManager = new OpGroupingManager({
191
+ groupedBatchingEnabled: false,
192
+ opCountThreshold: 2,
193
+ reentrantBatchGroupingEnabled: true,
194
+ }, mockLogger);
195
+ for (const ungroupedOp of opGroupingManager.ungroupOp(groupedBatch)) {
196
+ assert.strictEqual(isGroupedBatch(ungroupedOp), false);
197
+ assert.throws(() => opGroupingManager.ungroupOp(ungroupedOp));
198
+ }
199
+ });
223
200
  });
224
201
  });
225
202
  //# sourceMappingURL=OpGroupingManager.spec.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"OpGroupingManager.spec.js","sourceRoot":"","sources":["../../../src/test/opLifecycle/OpGroupingManager.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 */\n\nimport { strict as assert } from \"assert\";\nimport { MockLogger } from \"@fluidframework/telemetry-utils\";\nimport { ISequencedDocumentMessage } from \"@fluidframework/protocol-definitions\";\nimport { ContainerMessageType } from \"../../index.js\";\nimport { BatchMessage, IBatch, OpGroupingManager } from \"../../opLifecycle/index.js\";\n\ndescribe(\"OpGroupingManager\", () => {\n\tconst mockLogger = new MockLogger();\n\tconst createBatch = (length: number, hasReentrantOps?: boolean): IBatch => ({\n\t\t...messagesToBatch(new Array(length).fill(createMessage(generateStringOfSize(1)))),\n\t\thasReentrantOps,\n\t});\n\tconst messagesToBatch = (messages: BatchMessage[]): IBatch => ({\n\t\tcontent: messages,\n\t\tcontentSizeInBytes: messages\n\t\t\t.map((message) => JSON.stringify(message).length)\n\t\t\t.reduce((a, b) => a + b),\n\t\treferenceSequenceNumber: messages[0].referenceSequenceNumber,\n\t});\n\tconst createMessage = (contents: string) => ({\n\t\tmetadata: { flag: true },\n\t\tlocalOpMetadata: undefined,\n\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\tcontents,\n\t\treferenceSequenceNumber: 0,\n\t});\n\tconst generateStringOfSize = (sizeInBytes: number): string =>\n\t\tnew Array(sizeInBytes + 1).join(\"0\");\n\n\tdescribe(\"Configs\", () => {\n\t\tit(\"Grouped batching is disabled\", () => {\n\t\t\tassert.strictEqual(\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: false,\n\t\t\t\t\t\topCountThreshold: 0,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).shouldGroup(createBatch(100)),\n\t\t\t\tfalse,\n\t\t\t);\n\t\t});\n\n\t\tit(\"Grouped batching is enabled but the batch is too small\", () => {\n\t\t\tassert.strictEqual(\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\t\topCountThreshold: 10,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).shouldGroup(createBatch(5)),\n\t\t\t\tfalse,\n\t\t\t);\n\t\t});\n\n\t\tit(\"Grouped batching is enabled, the batch is large enough, but it is reentrant\", () => {\n\t\t\tassert.strictEqual(\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: false,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).shouldGroup(createBatch(5, true)),\n\t\t\t\tfalse,\n\t\t\t);\n\t\t});\n\n\t\tit(\"Grouped batching is enabled, the batch is large enough, and it is reentrant\", () => {\n\t\t\tassert.strictEqual(\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).shouldGroup(createBatch(5, true)),\n\t\t\t\ttrue,\n\t\t\t);\n\t\t});\n\n\t\tit(\"Grouped batching is enabled and the batch is large enough\", () => {\n\t\t\tassert.strictEqual(\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: false,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).shouldGroup(createBatch(5)),\n\t\t\t\ttrue,\n\t\t\t);\n\t\t});\n\t});\n\n\tdescribe(\"Fakes clientSequenceNumber when ungrouping\", () => {\n\t\tit(\"grouped op\", () => {\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tconst op = {\n\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\tcontents: {\n\t\t\t\t\ttype: OpGroupingManager.groupedBatchOp,\n\t\t\t\t\tcontents: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: \"1\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: \"2\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: \"3\",\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t} as any;\n\n\t\t\tconst result = opGroupingManager.ungroupOp(op);\n\n\t\t\tassert.deepStrictEqual(result, [\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 1,\n\t\t\t\t\tcontents: \"1\",\n\t\t\t\t\tcompression: undefined,\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 2,\n\t\t\t\t\tcontents: \"2\",\n\t\t\t\t\tcompression: undefined,\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 3,\n\t\t\t\t\tcontents: \"3\",\n\t\t\t\t\tcompression: undefined,\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t},\n\t\t\t]);\n\t\t});\n\n\t\tit(\"non-grouped op with grouped batching enabled\", () => {\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tconst op = {\n\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\tcontents: \"1\",\n\t\t\t} as any;\n\n\t\t\tconst result = opGroupingManager.ungroupOp(op);\n\n\t\t\tassert.deepStrictEqual(result, [\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\t\tcontents: \"1\",\n\t\t\t\t},\n\t\t\t]);\n\t\t});\n\n\t\tit(\"non-grouped op with grouped batching disabled\", () => {\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: false,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tconst op = {\n\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\tcontents: \"1\",\n\t\t\t} as any;\n\n\t\t\tconst result = opGroupingManager.ungroupOp(op);\n\n\t\t\tassert.deepStrictEqual(result, [\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\t\tcontents: \"1\",\n\t\t\t\t},\n\t\t\t]);\n\t\t});\n\t});\n\n\tit(\"Ungrouping multiple times does not mess up groupedBatch messages\", () => {\n\t\tconst groupedBatch = {\n\t\t\ttype: \"op\",\n\t\t\tsequenceNumber: 10,\n\t\t\tclientSequenceNumber: 12,\n\t\t\tcontents: {\n\t\t\t\ttype: OpGroupingManager.groupedBatchOp,\n\t\t\t\tcontents: [\n\t\t\t\t\t{\n\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\t\tcontents: \"a\",\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\t\tcontents: \"b\",\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t},\n\t\t\t\t],\n\t\t\t},\n\t\t} as any;\n\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t{\n\t\t\t\tgroupedBatchingEnabled: false,\n\t\t\t\topCountThreshold: 2,\n\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t},\n\t\t\tmockLogger,\n\t\t);\n\n\t\t// Run the groupedBatch through a couple times to ensure it cannot get messed up\n\t\tlet messagesToUngroup: ISequencedDocumentMessage[] = [groupedBatch];\n\t\tlet result: ISequencedDocumentMessage[] = [];\n\t\tfor (let i = 0; i < 4; i++) {\n\t\t\tresult = [];\n\t\t\tfor (const message of messagesToUngroup) {\n\t\t\t\tfor (const ungroupedOp of opGroupingManager.ungroupOp(message)) {\n\t\t\t\t\tresult.push(ungroupedOp);\n\t\t\t\t}\n\t\t\t}\n\t\t\tmessagesToUngroup = [...result];\n\t\t}\n\n\t\tconst expected = [\n\t\t\t{\n\t\t\t\ttype: \"op\",\n\t\t\t\tsequenceNumber: 10,\n\t\t\t\tclientSequenceNumber: 1,\n\t\t\t\tmetadata: undefined,\n\t\t\t\tcompression: undefined,\n\t\t\t\tcontents: {\n\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t\tcontents: {\n\t\t\t\t\t\tcontents: \"a\",\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t},\n\t\t\t{\n\t\t\t\ttype: \"op\",\n\t\t\t\tsequenceNumber: 10,\n\t\t\t\tclientSequenceNumber: 2,\n\t\t\t\tmetadata: undefined,\n\t\t\t\tcompression: undefined,\n\t\t\t\tcontents: {\n\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t\tcontents: {\n\t\t\t\t\t\tcontents: \"b\",\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t},\n\t\t];\n\t\tassert.deepStrictEqual(result, expected, \"ungrouping should work as expected\");\n\t});\n});\n"]}
1
+ {"version":3,"file":"OpGroupingManager.spec.js","sourceRoot":"","sources":["../../../src/test/opLifecycle/OpGroupingManager.spec.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,MAAM,IAAI,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAGN,iBAAiB,EACjB,cAAc,GACd,MAAM,4BAA4B,CAAC;AAEpC,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IAClC,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;IACpC,MAAM,WAAW,GAAG,CACnB,MAAc,EACd,eAAyB,EACzB,gBAAyB,KAAK,EACrB,EAAE,CAAC,CAAC;QACb,GAAG,eAAe,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC;QACxE,eAAe;KACf,CAAC,CAAC;IACH,MAAM,eAAe,GAAG,CAAC,QAAwB,EAAU,EAAE,CAAC,CAAC;QAC9D,OAAO,EAAE,QAAQ;QACjB,kBAAkB,EAAE,QAAQ;aAC1B,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC;aAChD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;QACzB,uBAAuB,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,uBAAuB;KAC5D,CAAC,CAAC;IACH,MAAM,aAAa,GAAG,CAAC,aAAsB,EAAE,EAAE,CAAC,CAAC;QAClD,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,SAAS;QACpD,IAAI,EAAE,oBAAoB,CAAC,gBAAgB;QAC3C,QAAQ,EAAE,GAAG;QACb,uBAAuB,EAAE,CAAC;KAC1B,CAAC,CAAC;IAEH,QAAQ,CAAC,SAAS,EAAE,GAAG,EAAE;QAQxB,MAAM,OAAO,GAAmB;YAC/B,EAAE,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,KAAK,EAAE;YACzC,EAAE,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;YACxD,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE;YACzD,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,cAAc,EAAE,IAAI,EAAE,cAAc,EAAE,IAAI,EAAE;YAC9E,EAAE,OAAO,EAAE,IAAI,EAAE,cAAc,EAAE,IAAI,EAAE;SACvC,CAAC;QAEF,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YAC1B,EAAE,CAAC,wCAAwC,MAAM,CAAC,OAAO,eACxD,MAAM,CAAC,QAAQ,KAAK,IACrB,gBAAgB,MAAM,CAAC,SAAS,KAAK,IAAI,qBACxC,MAAM,CAAC,cAAc,KAAK,IAC3B,GAAG,EAAE,GAAG,EAAE;gBACT,MAAM,CAAC,WAAW,CACjB,IAAI,iBAAiB,CACpB;oBACC,sBAAsB,EAAE,MAAM,CAAC,OAAO;oBACtC,gBAAgB,EAAE,MAAM,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;oBACnD,6BAA6B,EAAE,MAAM,CAAC,cAAc,IAAI,KAAK;iBAC7D,EACD,UAAU,CACV,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC,EAC/C,MAAM,CAAC,cAAc,CACrB,CAAC;YACH,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;QAC3B,EAAE,CAAC,2BAA2B,EAAE,GAAG,EAAE;YACpC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;gBAClB,IAAI,iBAAiB,CACpB;oBACC,sBAAsB,EAAE,KAAK;oBAC7B,gBAAgB,EAAE,CAAC;oBACnB,6BAA6B,EAAE,KAAK;iBACpC,EACD,UAAU,CACV,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;YACnC,MAAM,MAAM,GAAG,IAAI,iBAAiB,CACnC;gBACC,sBAAsB,EAAE,IAAI;gBAC5B,gBAAgB,EAAE,CAAC;gBACnB,6BAA6B,EAAE,KAAK;aACpC,EACD,UAAU,CACV,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7B,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YAC7C,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,EAAE;gBACtC;oBACC,QAAQ,EACP,iHAAiH;oBAClH,QAAQ,EAAE,SAAS;oBACnB,uBAAuB,EAAE,CAAC;iBAC1B;aACD,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;YACrD,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;gBAClB,IAAI,iBAAiB,CACpB;oBACC,sBAAsB,EAAE,IAAI;oBAC5B,gBAAgB,EAAE,EAAE;oBACpB,6BAA6B,EAAE,KAAK;iBACpC,EACD,UAAU,CACV,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9B,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,mDAAmD,EAAE,GAAG,EAAE;YAC5D,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;gBAClB,IAAI,iBAAiB,CACpB;oBACC,sBAAsB,EAAE,IAAI;oBAC5B,gBAAgB,EAAE,CAAC;oBACnB,6BAA6B,EAAE,KAAK;iBACpC,EACD,UAAU,CACV,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC;YAC3C,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;QAC1B,EAAE,CAAC,mBAAmB,EAAE,GAAG,EAAE;YAC5B,MAAM,iBAAiB,GAAG,IAAI,iBAAiB,CAC9C;gBACC,sBAAsB,EAAE,IAAI;gBAC5B,gBAAgB,EAAE,CAAC;gBACnB,6BAA6B,EAAE,IAAI;aACnC,EACD,UAAU,CACV,CAAC;YAEF,MAAM,EAAE,GAAG;gBACV,oBAAoB,EAAE,EAAE;gBACxB,QAAQ,EAAE;oBACT,IAAI,EAAE,iBAAiB,CAAC,cAAc;oBACtC,QAAQ,EAAE;wBACT;4BACC,QAAQ,EAAE,GAAG;yBACb;wBACD;4BACC,QAAQ,EAAE,GAAG;yBACb;wBACD;4BACC,QAAQ,EAAE,GAAG;yBACb;qBACD;iBACD;aACM,CAAC;YAET,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,CAAC;YAC7C,MAAM,MAAM,GAAG,iBAAiB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAE/C,MAAM,CAAC,eAAe,CAAC,MAAM,EAAE;gBAC9B;oBACC,oBAAoB,EAAE,CAAC;oBACvB,QAAQ,EAAE,GAAG;oBACb,WAAW,EAAE,SAAS;oBACtB,QAAQ,EAAE,SAAS;iBACnB;gBACD;oBACC,oBAAoB,EAAE,CAAC;oBACvB,QAAQ,EAAE,GAAG;oBACb,WAAW,EAAE,SAAS;oBACtB,QAAQ,EAAE,SAAS;iBACnB;gBACD;oBACC,oBAAoB,EAAE,CAAC;oBACvB,QAAQ,EAAE,GAAG;oBACb,WAAW,EAAE,SAAS;oBACtB,QAAQ,EAAE,SAAS;iBACnB;aACD,CAAC,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;YACvD,MAAM,iBAAiB,GAAG,IAAI,iBAAiB,CAC9C;gBACC,sBAAsB,EAAE,IAAI;gBAC5B,gBAAgB,EAAE,CAAC;gBACnB,6BAA6B,EAAE,IAAI;aACnC,EACD,UAAU,CACV,CAAC;YAEF,MAAM,EAAE,GAAG;gBACV,oBAAoB,EAAE,EAAE;gBACxB,QAAQ,EAAE,GAAG;aACN,CAAC;YAET,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;YAC9C,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;YACxD,MAAM,iBAAiB,GAAG,IAAI,iBAAiB,CAC9C;gBACC,sBAAsB,EAAE,KAAK;gBAC7B,gBAAgB,EAAE,CAAC;gBACnB,6BAA6B,EAAE,IAAI;aACnC,EACD,UAAU,CACV,CAAC;YAEF,MAAM,EAAE,GAAG;gBACV,oBAAoB,EAAE,EAAE;gBACxB,QAAQ,EAAE,GAAG;aACN,CAAC;YAET,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC;YAC9C,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;YACnD,MAAM,YAAY,GAAG;gBACpB,IAAI,EAAE,IAAI;gBACV,cAAc,EAAE,EAAE;gBAClB,oBAAoB,EAAE,EAAE;gBACxB,QAAQ,EAAE;oBACT,IAAI,EAAE,iBAAiB,CAAC,cAAc;oBACtC,QAAQ,EAAE;wBACT;4BACC,QAAQ,EAAE;gCACT,IAAI,EAAE,oBAAoB,CAAC,gBAAgB;gCAC3C,QAAQ,EAAE;oCACT,QAAQ,EAAE,GAAG;iCACb;6BACD;yBACD;wBACD;4BACC,QAAQ,EAAE;gCACT,IAAI,EAAE,oBAAoB,CAAC,gBAAgB;gCAC3C,QAAQ,EAAE;oCACT,QAAQ,EAAE,GAAG;iCACb;6BACD;yBACD;qBACD;iBACD;aACM,CAAC;YACT,MAAM,iBAAiB,GAAG,IAAI,iBAAiB,CAC9C;gBACC,sBAAsB,EAAE,KAAK;gBAC7B,gBAAgB,EAAE,CAAC;gBACnB,6BAA6B,EAAE,IAAI;aACnC,EACD,UAAU,CACV,CAAC;YAEF,KAAK,MAAM,WAAW,IAAI,iBAAiB,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE;gBACpE,MAAM,CAAC,WAAW,CAAC,cAAc,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,CAAC;gBACvD,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,SAAS,CAAC,WAAW,CAAC,CAAC,CAAC;aAC9D;QACF,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 */\n\nimport { strict as assert } from \"assert\";\nimport { MockLogger } from \"@fluidframework/telemetry-utils\";\nimport { ContainerMessageType } from \"../../index.js\";\nimport {\n\tBatchMessage,\n\tIBatch,\n\tOpGroupingManager,\n\tisGroupedBatch,\n} from \"../../opLifecycle/index.js\";\n\ndescribe(\"OpGroupingManager\", () => {\n\tconst mockLogger = new MockLogger();\n\tconst createBatch = (\n\t\tlength: number,\n\t\thasReentrantOps?: boolean,\n\t\topHasMetadata: boolean = false,\n\t): IBatch => ({\n\t\t...messagesToBatch(new Array(length).fill(createMessage(opHasMetadata))),\n\t\thasReentrantOps,\n\t});\n\tconst messagesToBatch = (messages: BatchMessage[]): IBatch => ({\n\t\tcontent: messages,\n\t\tcontentSizeInBytes: messages\n\t\t\t.map((message) => JSON.stringify(message).length)\n\t\t\t.reduce((a, b) => a + b),\n\t\treferenceSequenceNumber: messages[0].referenceSequenceNumber,\n\t});\n\tconst createMessage = (opHasMetadata: boolean) => ({\n\t\tmetadata: opHasMetadata ? { flag: true } : undefined,\n\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\tcontents: \"0\",\n\t\treferenceSequenceNumber: 0,\n\t});\n\n\tdescribe(\"Configs\", () => {\n\t\tinterface ConfigOption {\n\t\t\tenabled: boolean;\n\t\t\ttooSmall?: boolean;\n\t\t\treentrant?: boolean;\n\t\t\treentryEnabled?: boolean;\n\t\t\texpectedResult: boolean;\n\t\t}\n\t\tconst options: ConfigOption[] = [\n\t\t\t{ enabled: false, expectedResult: false },\n\t\t\t{ enabled: true, tooSmall: true, expectedResult: false },\n\t\t\t{ enabled: true, reentrant: true, expectedResult: false },\n\t\t\t{ enabled: true, reentrant: true, reentryEnabled: true, expectedResult: true },\n\t\t\t{ enabled: true, expectedResult: true },\n\t\t];\n\n\t\toptions.forEach((option) => {\n\t\t\tit(`shouldGroup: groupedBatchingEnabled [${option.enabled}] tooSmall [${\n\t\t\t\toption.tooSmall === true\n\t\t\t}] reentrant [${option.reentrant === true}] reentryEnabled [${\n\t\t\t\toption.reentryEnabled === true\n\t\t\t}]`, () => {\n\t\t\t\tassert.strictEqual(\n\t\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tgroupedBatchingEnabled: option.enabled,\n\t\t\t\t\t\t\topCountThreshold: option.tooSmall === true ? 10 : 2,\n\t\t\t\t\t\t\treentrantBatchGroupingEnabled: option.reentryEnabled ?? false,\n\t\t\t\t\t\t},\n\t\t\t\t\t\tmockLogger,\n\t\t\t\t\t).shouldGroup(createBatch(5, option.reentrant)),\n\t\t\t\t\toption.expectedResult,\n\t\t\t\t);\n\t\t\t});\n\t\t});\n\t});\n\n\tdescribe(\"groupBatch\", () => {\n\t\tit(\"grouped batching disabled\", () => {\n\t\t\tassert.throws(() => {\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: false,\n\t\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: false,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).groupBatch(createBatch(5));\n\t\t\t});\n\t\t});\n\n\t\tit(\"grouped batching enabled\", () => {\n\t\t\tconst result = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: false,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t).groupBatch(createBatch(5));\n\t\t\tassert.strictEqual(result.content.length, 1);\n\t\t\tassert.deepStrictEqual(result.content, [\n\t\t\t\t{\n\t\t\t\t\tcontents:\n\t\t\t\t\t\t'{\"type\":\"groupedBatch\",\"contents\":[{\"contents\":0},{\"contents\":0},{\"contents\":0},{\"contents\":0},{\"contents\":0}]}',\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t\treferenceSequenceNumber: 0,\n\t\t\t\t},\n\t\t\t]);\n\t\t});\n\n\t\tit(\"grouped batching enabled, not large enough\", () => {\n\t\t\tassert.throws(() => {\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\t\topCountThreshold: 10,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: false,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).groupBatch(createBatch(5));\n\t\t\t});\n\t\t});\n\n\t\tit(\"grouped batching enabled, op metadata not allowed\", () => {\n\t\t\tassert.throws(() => {\n\t\t\t\tnew OpGroupingManager(\n\t\t\t\t\t{\n\t\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\t\treentrantBatchGroupingEnabled: false,\n\t\t\t\t\t},\n\t\t\t\t\tmockLogger,\n\t\t\t\t).groupBatch(createBatch(5, false, true));\n\t\t\t});\n\t\t});\n\t});\n\n\tdescribe(\"ungroupOp\", () => {\n\t\tit(\"packed grouped op\", () => {\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tconst op = {\n\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\tcontents: {\n\t\t\t\t\ttype: OpGroupingManager.groupedBatchOp,\n\t\t\t\t\tcontents: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: \"1\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: \"2\",\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: \"3\",\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t} as any;\n\n\t\t\tassert.strictEqual(isGroupedBatch(op), true);\n\t\t\tconst result = opGroupingManager.ungroupOp(op);\n\n\t\t\tassert.deepStrictEqual(result, [\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 1,\n\t\t\t\t\tcontents: \"1\",\n\t\t\t\t\tcompression: undefined,\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 2,\n\t\t\t\t\tcontents: \"2\",\n\t\t\t\t\tcompression: undefined,\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tclientSequenceNumber: 3,\n\t\t\t\t\tcontents: \"3\",\n\t\t\t\t\tcompression: undefined,\n\t\t\t\t\tmetadata: undefined,\n\t\t\t\t},\n\t\t\t]);\n\t\t});\n\n\t\tit(\"non-grouped op with grouped batching enabled\", () => {\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: true,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tconst op = {\n\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\tcontents: \"1\",\n\t\t\t} as any;\n\n\t\t\tassert.strictEqual(isGroupedBatch(op), false);\n\t\t\tassert.throws(() => opGroupingManager.ungroupOp(op));\n\t\t});\n\n\t\tit(\"non-grouped op with grouped batching disabled\", () => {\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: false,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tconst op = {\n\t\t\t\tclientSequenceNumber: 10,\n\t\t\t\tcontents: \"1\",\n\t\t\t} as any;\n\n\t\t\tassert.strictEqual(isGroupedBatch(op), false);\n\t\t\tassert.throws(() => opGroupingManager.ungroupOp(op));\n\t\t});\n\n\t\tit(\"Ungrouping multiple times is not allowed\", () => {\n\t\t\tconst groupedBatch = {\n\t\t\t\ttype: \"op\",\n\t\t\t\tsequenceNumber: 10,\n\t\t\t\tclientSequenceNumber: 12,\n\t\t\t\tcontents: {\n\t\t\t\t\ttype: OpGroupingManager.groupedBatchOp,\n\t\t\t\t\tcontents: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\t\t\tcontents: \"a\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t\t\t\t\tcontents: {\n\t\t\t\t\t\t\t\t\tcontents: \"b\",\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t},\n\t\t\t} as any;\n\t\t\tconst opGroupingManager = new OpGroupingManager(\n\t\t\t\t{\n\t\t\t\t\tgroupedBatchingEnabled: false,\n\t\t\t\t\topCountThreshold: 2,\n\t\t\t\t\treentrantBatchGroupingEnabled: true,\n\t\t\t\t},\n\t\t\t\tmockLogger,\n\t\t\t);\n\n\t\t\tfor (const ungroupedOp of opGroupingManager.ungroupOp(groupedBatch)) {\n\t\t\t\tassert.strictEqual(isGroupedBatch(ungroupedOp), false);\n\t\t\t\tassert.throws(() => opGroupingManager.ungroupOp(ungroupedOp));\n\t\t\t}\n\t\t});\n\t});\n});\n"]}
@@ -3,8 +3,8 @@
3
3
  * Licensed under the MIT License.
4
4
  */
5
5
  import { strict as assert } from "assert";
6
- import { BatchManager, estimateSocketSize } from "../../opLifecycle/index.js";
7
6
  import { ContainerMessageType } from "../../messageTypes.js";
7
+ import { BatchManager, estimateSocketSize } from "../../opLifecycle/index.js";
8
8
  describe("BatchManager", () => {
9
9
  const softLimit = 1024;
10
10
  const hardLimit = 950 * 1024;
@@ -1 +1 @@
1
- {"version":3,"file":"batchManager.spec.js","sourceRoot":"","sources":["../../../src/test/opLifecycle/batchManager.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 */\n\nimport { strict as assert } from \"assert\";\nimport { BatchManager, BatchMessage, estimateSocketSize } from \"../../opLifecycle/index.js\";\nimport { ContainerMessageType } from \"../../messageTypes.js\";\n\ndescribe(\"BatchManager\", () => {\n\tconst softLimit = 1024;\n\tconst hardLimit = 950 * 1024;\n\tconst smallMessageSize = 10;\n\n\tconst generateStringOfSize = (sizeInBytes: number): string =>\n\t\tnew Array(sizeInBytes + 1).join(\"0\");\n\n\tconst smallMessage = (): BatchMessage =>\n\t\t({\n\t\t\tcontents: generateStringOfSize(smallMessageSize),\n\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t}) as any as BatchMessage;\n\n\tit(\"BatchManager's soft limit: a bunch of small messages\", () => {\n\t\tconst message = { contents: generateStringOfSize(softLimit / 2) } as any as BatchMessage;\n\t\tconst batchManager = new BatchManager({ hardLimit, softLimit });\n\n\t\t// Can push one large message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can't push another large message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// But can push one small message\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 2);\n\t\tassert.equal(batch.contentSizeInBytes, softLimit / 2 + smallMessageSize);\n\n\t\t// Validate that can push large message again\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\t});\n\n\tit(\"BatchManager's soft limit: single large message\", () => {\n\t\tconst message = { contents: generateStringOfSize(softLimit * 2) } as any as BatchMessage;\n\t\tconst batchManager = new BatchManager({ hardLimit, softLimit });\n\n\t\t// Can push one large message, even above soft limit\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can't push another small message\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 1);\n\t\tassert.equal(batch.contentSizeInBytes, softLimit * 2);\n\n\t\t// Validate that we can't push large message above soft limit if we have already at least one message.\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\t});\n\n\tit(\"BatchManager: no soft limit\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tconst third = Math.floor(hardLimit / 3) + 1;\n\t\tconst message = { contents: generateStringOfSize(third) } as any as BatchMessage;\n\n\t\t// Can push one large message, even above soft limit\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can push second large message, even above soft limit\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\t// Can't push another message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 2);\n\n\t\t// Can push messages again\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 3);\n\t});\n\n\tit(\"BatchManager: soft limit is higher than hard limit\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit, softLimit: hardLimit * 2 });\n\t\tconst twoThird = Math.floor((hardLimit * 2) / 3);\n\t\tconst message = { contents: generateStringOfSize(twoThird) } as any as BatchMessage;\n\t\tconst largeMessage = {\n\t\t\tcontents: generateStringOfSize(hardLimit + 1),\n\t\t} as any as BatchMessage;\n\n\t\t// Can't push very large message, above hard limit\n\t\tassert.equal(batchManager.push(largeMessage, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 0);\n\n\t\t// Can push one message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can't push second message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 1);\n\t});\n\n\tit(\"BatchManager: 'infinity' hard limit allows everything\", () => {\n\t\tconst message = { contents: generateStringOfSize(softLimit) } as any as BatchMessage;\n\t\tconst batchManager = new BatchManager({ hardLimit: Infinity });\n\n\t\tfor (let i = 1; i <= 10; i++) {\n\t\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\t\tassert.equal(batchManager.length, i);\n\t\t}\n\t});\n\n\tit(\"Batch metadata is set correctly\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content[0].metadata?.batch, true);\n\t\tassert.equal(batch.content[1].metadata?.batch, undefined);\n\t\tassert.equal(batch.content[2].metadata?.batch, false);\n\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tconst singleOpBatch = batchManager.popBatch();\n\t\tassert.equal(singleOpBatch.content[0].metadata?.batch, undefined);\n\t});\n\n\tit(\"Batch content size is tracked correctly\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.contentSizeInBytes, smallMessageSize * batchManager.length);\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.contentSizeInBytes, smallMessageSize * batchManager.length);\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.contentSizeInBytes, smallMessageSize * batchManager.length);\n\t});\n\n\tit(\"Batch reference sequence number maps to the last message\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\n\t\tassert.equal(batchManager.sequenceNumbers.referenceSequenceNumber, 2);\n\t});\n\n\tit(\"Batch size estimates\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tbatchManager.push(smallMessage(), /* reentrant */ false);\n\t\t// 10 bytes of content + 200 bytes overhead\n\t\tassert.equal(estimateSocketSize(batchManager.popBatch()), 210);\n\n\t\tfor (let i = 0; i < 10; i++) {\n\t\t\tbatchManager.push(smallMessage(), /* reentrant */ false);\n\t\t}\n\n\t\t// (10 bytes of content + 200 bytes overhead) x 10\n\t\tassert.equal(estimateSocketSize(batchManager.popBatch()), 2100);\n\n\t\tbatchManager.push(smallMessage(), /* reentrant */ false);\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tbatchManager.push(\n\t\t\t\t{\n\t\t\t\t\tcontents: undefined,\n\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t} as any as BatchMessage,\n\t\t\t\t/* reentrant */ false,\n\t\t\t); // empty op\n\t\t}\n\n\t\t// 10 bytes of content + 200 bytes overhead x 10\n\t\tassert.equal(estimateSocketSize(batchManager.popBatch()), 2010);\n\t});\n\n\tit(\"Batch op reentry state preserved during its lifetime\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\n\t\tassert.equal(batchManager.popBatch().hasReentrantOps, false);\n\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ true,\n\t\t\t\t/* currentClientSequenceNumber */ undefined,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(batchManager.popBatch().hasReentrantOps, true);\n\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(batchManager.popBatch().hasReentrantOps, false);\n\t});\n});\n"]}
1
+ {"version":3,"file":"batchManager.spec.js","sourceRoot":"","sources":["../../../src/test/opLifecycle/batchManager.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 */\n\nimport { strict as assert } from \"assert\";\nimport { ContainerMessageType } from \"../../messageTypes.js\";\nimport { BatchManager, BatchMessage, estimateSocketSize } from \"../../opLifecycle/index.js\";\n\ndescribe(\"BatchManager\", () => {\n\tconst softLimit = 1024;\n\tconst hardLimit = 950 * 1024;\n\tconst smallMessageSize = 10;\n\n\tconst generateStringOfSize = (sizeInBytes: number): string =>\n\t\tnew Array(sizeInBytes + 1).join(\"0\");\n\n\tconst smallMessage = (): BatchMessage =>\n\t\t({\n\t\t\tcontents: generateStringOfSize(smallMessageSize),\n\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t}) as any as BatchMessage;\n\n\tit(\"BatchManager's soft limit: a bunch of small messages\", () => {\n\t\tconst message = { contents: generateStringOfSize(softLimit / 2) } as any as BatchMessage;\n\t\tconst batchManager = new BatchManager({ hardLimit, softLimit });\n\n\t\t// Can push one large message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can't push another large message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// But can push one small message\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 2);\n\t\tassert.equal(batch.contentSizeInBytes, softLimit / 2 + smallMessageSize);\n\n\t\t// Validate that can push large message again\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\t});\n\n\tit(\"BatchManager's soft limit: single large message\", () => {\n\t\tconst message = { contents: generateStringOfSize(softLimit * 2) } as any as BatchMessage;\n\t\tconst batchManager = new BatchManager({ hardLimit, softLimit });\n\n\t\t// Can push one large message, even above soft limit\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can't push another small message\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 1);\n\t\tassert.equal(batch.contentSizeInBytes, softLimit * 2);\n\n\t\t// Validate that we can't push large message above soft limit if we have already at least one message.\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\t});\n\n\tit(\"BatchManager: no soft limit\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tconst third = Math.floor(hardLimit / 3) + 1;\n\t\tconst message = { contents: generateStringOfSize(third) } as any as BatchMessage;\n\n\t\t// Can push one large message, even above soft limit\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can push second large message, even above soft limit\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\t// Can't push another message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 2);\n\n\t\t// Can push messages again\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 2);\n\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 3);\n\t});\n\n\tit(\"BatchManager: soft limit is higher than hard limit\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit, softLimit: hardLimit * 2 });\n\t\tconst twoThird = Math.floor((hardLimit * 2) / 3);\n\t\tconst message = { contents: generateStringOfSize(twoThird) } as any as BatchMessage;\n\t\tconst largeMessage = {\n\t\t\tcontents: generateStringOfSize(hardLimit + 1),\n\t\t} as any as BatchMessage;\n\n\t\t// Can't push very large message, above hard limit\n\t\tassert.equal(batchManager.push(largeMessage, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 0);\n\n\t\t// Can push one message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Can't push second message\n\t\tassert.equal(batchManager.push(message, /* reentrant */ false), false);\n\t\tassert.equal(batchManager.length, 1);\n\n\t\t// Pop and check batch\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content.length, 1);\n\t});\n\n\tit(\"BatchManager: 'infinity' hard limit allows everything\", () => {\n\t\tconst message = { contents: generateStringOfSize(softLimit) } as any as BatchMessage;\n\t\tconst batchManager = new BatchManager({ hardLimit: Infinity });\n\n\t\tfor (let i = 1; i <= 10; i++) {\n\t\t\tassert.equal(batchManager.push(message, /* reentrant */ false), true);\n\t\t\tassert.equal(batchManager.length, i);\n\t\t}\n\t});\n\n\tit(\"Batch metadata is set correctly\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\n\t\tconst batch = batchManager.popBatch();\n\t\tassert.equal(batch.content[0].metadata?.batch, true);\n\t\tassert.equal(batch.content[1].metadata?.batch, undefined);\n\t\tassert.equal(batch.content[2].metadata?.batch, false);\n\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tconst singleOpBatch = batchManager.popBatch();\n\t\tassert.equal(singleOpBatch.content[0].metadata?.batch, undefined);\n\t});\n\n\tit(\"Batch content size is tracked correctly\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.contentSizeInBytes, smallMessageSize * batchManager.length);\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.contentSizeInBytes, smallMessageSize * batchManager.length);\n\t\tassert.equal(batchManager.push(smallMessage(), /* reentrant */ false), true);\n\t\tassert.equal(batchManager.contentSizeInBytes, smallMessageSize * batchManager.length);\n\t});\n\n\tit(\"Batch reference sequence number maps to the last message\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\n\t\tassert.equal(batchManager.sequenceNumbers.referenceSequenceNumber, 2);\n\t});\n\n\tit(\"Batch size estimates\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tbatchManager.push(smallMessage(), /* reentrant */ false);\n\t\t// 10 bytes of content + 200 bytes overhead\n\t\tassert.equal(estimateSocketSize(batchManager.popBatch()), 210);\n\n\t\tfor (let i = 0; i < 10; i++) {\n\t\t\tbatchManager.push(smallMessage(), /* reentrant */ false);\n\t\t}\n\n\t\t// (10 bytes of content + 200 bytes overhead) x 10\n\t\tassert.equal(estimateSocketSize(batchManager.popBatch()), 2100);\n\n\t\tbatchManager.push(smallMessage(), /* reentrant */ false);\n\t\tfor (let i = 0; i < 9; i++) {\n\t\t\tbatchManager.push(\n\t\t\t\t{\n\t\t\t\t\tcontents: undefined,\n\t\t\t\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\t\t\t} as any as BatchMessage,\n\t\t\t\t/* reentrant */ false,\n\t\t\t); // empty op\n\t\t}\n\n\t\t// 10 bytes of content + 200 bytes overhead x 10\n\t\tassert.equal(estimateSocketSize(batchManager.popBatch()), 2010);\n\t});\n\n\tit(\"Batch op reentry state preserved during its lifetime\", () => {\n\t\tconst batchManager = new BatchManager({ hardLimit });\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\n\t\tassert.equal(batchManager.popBatch().hasReentrantOps, false);\n\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 1 },\n\t\t\t\t/* reentrant */ true,\n\t\t\t\t/* currentClientSequenceNumber */ undefined,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 2 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(batchManager.popBatch().hasReentrantOps, true);\n\n\t\tassert.equal(\n\t\t\tbatchManager.push(\n\t\t\t\t{ ...smallMessage(), referenceSequenceNumber: 0 },\n\t\t\t\t/* reentrant */ false,\n\t\t\t),\n\t\t\ttrue,\n\t\t);\n\t\tassert.equal(batchManager.popBatch().hasReentrantOps, false);\n\t});\n});\n"]}
@@ -23,7 +23,6 @@ describe("OpCompressor", () => {
23
23
  });
24
24
  const createMessage = (contents) => ({
25
25
  metadata: { flag: true },
26
- localOpMetadata: undefined,
27
26
  type: ContainerMessageType.FluidDataStoreOp,
28
27
  contents,
29
28
  referenceSequenceNumber: 0,
@@ -1 +1 @@
1
- {"version":3,"file":"opCompressor.spec.js","sourceRoot":"","sources":["../../../src/test/opLifecycle/opCompressor.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 */\n\nimport { strict as assert } from \"assert\";\nimport { MockLogger } from \"@fluidframework/telemetry-utils\";\nimport { ContainerMessageType } from \"../../index.js\";\nimport { BatchMessage, IBatch, OpCompressor } from \"../../opLifecycle/index.js\";\n\ndescribe(\"OpCompressor\", () => {\n\tlet compressor: OpCompressor;\n\tconst mockLogger = new MockLogger();\n\tbeforeEach(() => {\n\t\tcompressor = new OpCompressor(mockLogger);\n\t\tmockLogger.clear();\n\t});\n\n\tconst createBatch = (length: number, messageSize: number) =>\n\t\tmessagesToBatch(new Array(length).fill(createMessage(generateStringOfSize(messageSize))));\n\tconst messagesToBatch = (messages: BatchMessage[]): IBatch => ({\n\t\tcontent: messages,\n\t\tcontentSizeInBytes: messages\n\t\t\t.map((message) => JSON.stringify(message).length)\n\t\t\t.reduce((a, b) => a + b),\n\t\treferenceSequenceNumber: messages[0].referenceSequenceNumber,\n\t});\n\tconst createMessage = (contents: string) => ({\n\t\tmetadata: { flag: true },\n\t\tlocalOpMetadata: undefined,\n\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\tcontents,\n\t\treferenceSequenceNumber: 0,\n\t});\n\tconst generateStringOfSize = (sizeInBytes: number): string =>\n\t\tnew Array(sizeInBytes + 1).join(\"0\");\n\tconst toMB = (bytes: number) => (bytes / (1024 * 1024)).toFixed(2);\n\n\tdescribe(\"Compressing batches\", () =>\n\t\t[\n\t\t\t// small batch with one small message\n\t\t\tcreateBatch(1, 100 * 1024),\n\t\t\t// small batch with small messages\n\t\t\tcreateBatch(10, 100 * 1024),\n\t\t\t// small batch with large messages\n\t\t\tcreateBatch(2, 100 * 1024 * 1024),\n\t\t\t// large batch with small messages\n\t\t\tcreateBatch(1000, 100 * 1024),\n\t\t].forEach((batch) => {\n\t\t\tit(`Batch of ${batch.content.length} ops of total size ${toMB(\n\t\t\t\tbatch.contentSizeInBytes,\n\t\t\t)} MB`, () => {\n\t\t\t\tconst compressedBatch = compressor.compressBatch(batch);\n\t\t\t\tassert.strictEqual(compressedBatch.content.length, batch.content.length);\n\t\t\t\tassert.strictEqual(compressedBatch.content[0].compression, \"lz4\");\n\t\t\t\tassert.strictEqual(compressedBatch.content[0].metadata?.flag, true);\n\t\t\t\tif (compressedBatch.content.length > 1) {\n\t\t\t\t\tassert.strictEqual(compressedBatch.content[1].contents, undefined);\n\t\t\t\t\tassert.strictEqual(compressedBatch.content[1].compression, undefined);\n\t\t\t\t\tassert.strictEqual(compressedBatch.content[1].contents, undefined);\n\t\t\t\t}\n\t\t\t}).timeout(3000);\n\t\t}));\n\n\tdescribe(\"Unsupported batches\", () =>\n\t\t[\n\t\t\t// large batch with small messages\n\t\t\tcreateBatch(6000, 100 * 1024),\n\t\t\t// small batch with large messages\n\t\t\tcreateBatch(6, 100 * 1024 * 1024),\n\t\t].forEach((batch) => {\n\t\t\tit(`Not compressing batch of ${batch.content.length} ops of total size ${toMB(\n\t\t\t\tbatch.contentSizeInBytes,\n\t\t\t)} MB`, () => {\n\t\t\t\tassert.throws(() => compressor.compressBatch(batch));\n\t\t\t\tmockLogger.assertMatch([\n\t\t\t\t\t{\n\t\t\t\t\t\teventName: \"OpCompressor:BatchTooLarge\",\n\t\t\t\t\t\tcategory: \"error\",\n\t\t\t\t\t\tlength: batch.content.length,\n\t\t\t\t\t\tsize: batch.contentSizeInBytes,\n\t\t\t\t\t},\n\t\t\t\t]);\n\t\t\t});\n\t\t}));\n});\n"]}
1
+ {"version":3,"file":"opCompressor.spec.js","sourceRoot":"","sources":["../../../src/test/opLifecycle/opCompressor.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 */\n\nimport { strict as assert } from \"assert\";\nimport { MockLogger } from \"@fluidframework/telemetry-utils\";\nimport { ContainerMessageType } from \"../../index.js\";\nimport { BatchMessage, IBatch, OpCompressor } from \"../../opLifecycle/index.js\";\n\ndescribe(\"OpCompressor\", () => {\n\tlet compressor: OpCompressor;\n\tconst mockLogger = new MockLogger();\n\tbeforeEach(() => {\n\t\tcompressor = new OpCompressor(mockLogger);\n\t\tmockLogger.clear();\n\t});\n\n\tconst createBatch = (length: number, messageSize: number) =>\n\t\tmessagesToBatch(new Array(length).fill(createMessage(generateStringOfSize(messageSize))));\n\tconst messagesToBatch = (messages: BatchMessage[]): IBatch => ({\n\t\tcontent: messages,\n\t\tcontentSizeInBytes: messages\n\t\t\t.map((message) => JSON.stringify(message).length)\n\t\t\t.reduce((a, b) => a + b),\n\t\treferenceSequenceNumber: messages[0].referenceSequenceNumber,\n\t});\n\tconst createMessage = (contents: string) => ({\n\t\tmetadata: { flag: true },\n\t\ttype: ContainerMessageType.FluidDataStoreOp,\n\t\tcontents,\n\t\treferenceSequenceNumber: 0,\n\t});\n\tconst generateStringOfSize = (sizeInBytes: number): string =>\n\t\tnew Array(sizeInBytes + 1).join(\"0\");\n\tconst toMB = (bytes: number) => (bytes / (1024 * 1024)).toFixed(2);\n\n\tdescribe(\"Compressing batches\", () =>\n\t\t[\n\t\t\t// small batch with one small message\n\t\t\tcreateBatch(1, 100 * 1024),\n\t\t\t// small batch with small messages\n\t\t\tcreateBatch(10, 100 * 1024),\n\t\t\t// small batch with large messages\n\t\t\tcreateBatch(2, 100 * 1024 * 1024),\n\t\t\t// large batch with small messages\n\t\t\tcreateBatch(1000, 100 * 1024),\n\t\t].forEach((batch) => {\n\t\t\tit(`Batch of ${batch.content.length} ops of total size ${toMB(\n\t\t\t\tbatch.contentSizeInBytes,\n\t\t\t)} MB`, () => {\n\t\t\t\tconst compressedBatch = compressor.compressBatch(batch);\n\t\t\t\tassert.strictEqual(compressedBatch.content.length, batch.content.length);\n\t\t\t\tassert.strictEqual(compressedBatch.content[0].compression, \"lz4\");\n\t\t\t\tassert.strictEqual(compressedBatch.content[0].metadata?.flag, true);\n\t\t\t\tif (compressedBatch.content.length > 1) {\n\t\t\t\t\tassert.strictEqual(compressedBatch.content[1].contents, undefined);\n\t\t\t\t\tassert.strictEqual(compressedBatch.content[1].compression, undefined);\n\t\t\t\t\tassert.strictEqual(compressedBatch.content[1].contents, undefined);\n\t\t\t\t}\n\t\t\t}).timeout(3000);\n\t\t}));\n\n\tdescribe(\"Unsupported batches\", () =>\n\t\t[\n\t\t\t// large batch with small messages\n\t\t\tcreateBatch(6000, 100 * 1024),\n\t\t\t// small batch with large messages\n\t\t\tcreateBatch(6, 100 * 1024 * 1024),\n\t\t].forEach((batch) => {\n\t\t\tit(`Not compressing batch of ${batch.content.length} ops of total size ${toMB(\n\t\t\t\tbatch.contentSizeInBytes,\n\t\t\t)} MB`, () => {\n\t\t\t\tassert.throws(() => compressor.compressBatch(batch));\n\t\t\t\tmockLogger.assertMatch([\n\t\t\t\t\t{\n\t\t\t\t\t\teventName: \"OpCompressor:BatchTooLarge\",\n\t\t\t\t\t\tcategory: \"error\",\n\t\t\t\t\t\tlength: batch.content.length,\n\t\t\t\t\t\tsize: batch.contentSizeInBytes,\n\t\t\t\t\t},\n\t\t\t\t]);\n\t\t\t});\n\t\t}));\n});\n"]}