@webex/plugin-meetings 3.0.0-beta.36 → 3.0.0-beta.360

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 (391) hide show
  1. package/README.md +58 -8
  2. package/dist/annotation/annotation.types.js +7 -0
  3. package/dist/annotation/annotation.types.js.map +1 -0
  4. package/dist/annotation/constants.js +49 -0
  5. package/dist/annotation/constants.js.map +1 -0
  6. package/dist/annotation/index.js +342 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +94 -15
  9. package/dist/breakouts/breakout.js.map +1 -1
  10. package/dist/breakouts/events.js +45 -0
  11. package/dist/breakouts/events.js.map +1 -0
  12. package/dist/breakouts/index.js +671 -81
  13. package/dist/breakouts/index.js.map +1 -1
  14. package/dist/breakouts/utils.js +45 -1
  15. package/dist/breakouts/utils.js.map +1 -1
  16. package/dist/common/errors/no-meeting-info.js +51 -0
  17. package/dist/common/errors/no-meeting-info.js.map +1 -0
  18. package/dist/common/errors/reclaim-host-role-errors.js +158 -0
  19. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  20. package/dist/common/errors/webex-errors.js +48 -7
  21. package/dist/common/errors/webex-errors.js.map +1 -1
  22. package/dist/common/logs/logger-proxy.js +1 -1
  23. package/dist/common/logs/logger-proxy.js.map +1 -1
  24. package/dist/common/logs/request.js +5 -1
  25. package/dist/common/logs/request.js.map +1 -1
  26. package/dist/common/queue.js +24 -9
  27. package/dist/common/queue.js.map +1 -1
  28. package/dist/config.js +5 -10
  29. package/dist/config.js.map +1 -1
  30. package/dist/constants.js +226 -33
  31. package/dist/constants.js.map +1 -1
  32. package/dist/controls-options-manager/enums.js +14 -2
  33. package/dist/controls-options-manager/enums.js.map +1 -1
  34. package/dist/controls-options-manager/index.js +109 -15
  35. package/dist/controls-options-manager/index.js.map +1 -1
  36. package/dist/controls-options-manager/types.js +7 -0
  37. package/dist/controls-options-manager/types.js.map +1 -0
  38. package/dist/controls-options-manager/util.js +309 -18
  39. package/dist/controls-options-manager/util.js.map +1 -1
  40. package/dist/index.js +117 -2
  41. package/dist/index.js.map +1 -1
  42. package/dist/interceptors/index.js +15 -0
  43. package/dist/interceptors/index.js.map +1 -0
  44. package/dist/interceptors/locusRetry.js +93 -0
  45. package/dist/interceptors/locusRetry.js.map +1 -0
  46. package/dist/interpretation/collection.js +23 -0
  47. package/dist/interpretation/collection.js.map +1 -0
  48. package/dist/interpretation/index.js +366 -0
  49. package/dist/interpretation/index.js.map +1 -0
  50. package/dist/interpretation/siLanguage.js +25 -0
  51. package/dist/interpretation/siLanguage.js.map +1 -0
  52. package/dist/locus-info/controlsUtils.js +91 -2
  53. package/dist/locus-info/controlsUtils.js.map +1 -1
  54. package/dist/locus-info/index.js +383 -62
  55. package/dist/locus-info/index.js.map +1 -1
  56. package/dist/locus-info/infoUtils.js +7 -1
  57. package/dist/locus-info/infoUtils.js.map +1 -1
  58. package/dist/locus-info/mediaSharesUtils.js +57 -1
  59. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  60. package/dist/locus-info/parser.js +249 -72
  61. package/dist/locus-info/parser.js.map +1 -1
  62. package/dist/locus-info/selfUtils.js +89 -14
  63. package/dist/locus-info/selfUtils.js.map +1 -1
  64. package/dist/media/index.js +61 -101
  65. package/dist/media/index.js.map +1 -1
  66. package/dist/media/properties.js +73 -124
  67. package/dist/media/properties.js.map +1 -1
  68. package/dist/mediaQualityMetrics/config.js +1 -204
  69. package/dist/mediaQualityMetrics/config.js.map +1 -1
  70. package/dist/meeting/in-meeting-actions.js +86 -2
  71. package/dist/meeting/in-meeting-actions.js.map +1 -1
  72. package/dist/meeting/index.js +3938 -2803
  73. package/dist/meeting/index.js.map +1 -1
  74. package/dist/meeting/locusMediaRequest.js +292 -0
  75. package/dist/meeting/locusMediaRequest.js.map +1 -0
  76. package/dist/meeting/muteState.js +224 -136
  77. package/dist/meeting/muteState.js.map +1 -1
  78. package/dist/meeting/request.js +166 -152
  79. package/dist/meeting/request.js.map +1 -1
  80. package/dist/meeting/util.js +601 -417
  81. package/dist/meeting/util.js.map +1 -1
  82. package/dist/meeting-info/index.js +73 -7
  83. package/dist/meeting-info/index.js.map +1 -1
  84. package/dist/meeting-info/meeting-info-v2.js +192 -51
  85. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  86. package/dist/meeting-info/util.js +1 -1
  87. package/dist/meeting-info/util.js.map +1 -1
  88. package/dist/meeting-info/utilv2.js +36 -36
  89. package/dist/meeting-info/utilv2.js.map +1 -1
  90. package/dist/meetings/collection.js +39 -0
  91. package/dist/meetings/collection.js.map +1 -1
  92. package/dist/meetings/index.js +478 -118
  93. package/dist/meetings/index.js.map +1 -1
  94. package/dist/meetings/meetings.types.js +7 -0
  95. package/dist/meetings/meetings.types.js.map +1 -0
  96. package/dist/meetings/request.js +2 -0
  97. package/dist/meetings/request.js.map +1 -1
  98. package/dist/meetings/util.js +72 -6
  99. package/dist/meetings/util.js.map +1 -1
  100. package/dist/member/index.js +58 -0
  101. package/dist/member/index.js.map +1 -1
  102. package/dist/member/types.js +25 -0
  103. package/dist/member/types.js.map +1 -0
  104. package/dist/member/util.js +132 -25
  105. package/dist/member/util.js.map +1 -1
  106. package/dist/members/collection.js +10 -0
  107. package/dist/members/collection.js.map +1 -1
  108. package/dist/members/index.js +102 -6
  109. package/dist/members/index.js.map +1 -1
  110. package/dist/members/request.js +106 -38
  111. package/dist/members/request.js.map +1 -1
  112. package/dist/members/types.js +15 -0
  113. package/dist/members/types.js.map +1 -0
  114. package/dist/members/util.js +326 -232
  115. package/dist/members/util.js.map +1 -1
  116. package/dist/metrics/constants.js +16 -1
  117. package/dist/metrics/constants.js.map +1 -1
  118. package/dist/metrics/index.js +1 -446
  119. package/dist/metrics/index.js.map +1 -1
  120. package/dist/multistream/mediaRequestManager.js +228 -58
  121. package/dist/multistream/mediaRequestManager.js.map +1 -1
  122. package/dist/multistream/receiveSlot.js +29 -16
  123. package/dist/multistream/receiveSlot.js.map +1 -1
  124. package/dist/multistream/receiveSlotManager.js +39 -36
  125. package/dist/multistream/receiveSlotManager.js.map +1 -1
  126. package/dist/multistream/remoteMedia.js +44 -18
  127. package/dist/multistream/remoteMedia.js.map +1 -1
  128. package/dist/multistream/remoteMediaGroup.js +60 -3
  129. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  130. package/dist/multistream/remoteMediaManager.js +209 -59
  131. package/dist/multistream/remoteMediaManager.js.map +1 -1
  132. package/dist/multistream/sendSlotManager.js +233 -0
  133. package/dist/multistream/sendSlotManager.js.map +1 -0
  134. package/dist/reachability/clusterReachability.js +356 -0
  135. package/dist/reachability/clusterReachability.js.map +1 -0
  136. package/dist/reachability/index.js +269 -390
  137. package/dist/reachability/index.js.map +1 -1
  138. package/dist/reachability/request.js +6 -4
  139. package/dist/reachability/request.js.map +1 -1
  140. package/dist/reachability/util.js +29 -0
  141. package/dist/reachability/util.js.map +1 -0
  142. package/dist/reconnection-manager/index.js +217 -170
  143. package/dist/reconnection-manager/index.js.map +1 -1
  144. package/dist/recording-controller/index.js +21 -2
  145. package/dist/recording-controller/index.js.map +1 -1
  146. package/dist/recording-controller/util.js +9 -8
  147. package/dist/recording-controller/util.js.map +1 -1
  148. package/dist/roap/index.js +51 -28
  149. package/dist/roap/index.js.map +1 -1
  150. package/dist/roap/request.js +48 -64
  151. package/dist/roap/request.js.map +1 -1
  152. package/dist/roap/turnDiscovery.js +95 -38
  153. package/dist/roap/turnDiscovery.js.map +1 -1
  154. package/dist/rtcMetrics/constants.js +12 -0
  155. package/dist/rtcMetrics/constants.js.map +1 -0
  156. package/dist/rtcMetrics/index.js +142 -0
  157. package/dist/rtcMetrics/index.js.map +1 -0
  158. package/dist/statsAnalyzer/index.js +182 -215
  159. package/dist/statsAnalyzer/index.js.map +1 -1
  160. package/dist/statsAnalyzer/mqaUtil.js +35 -28
  161. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  162. package/dist/types/annotation/annotation.types.d.ts +42 -0
  163. package/dist/types/annotation/constants.d.ts +31 -0
  164. package/dist/types/annotation/index.d.ts +117 -0
  165. package/dist/types/breakouts/events.d.ts +8 -0
  166. package/dist/types/breakouts/utils.d.ts +14 -0
  167. package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
  168. package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
  169. package/dist/types/common/errors/webex-errors.d.ts +25 -1
  170. package/dist/types/common/logs/request.d.ts +2 -0
  171. package/dist/types/common/queue.d.ts +9 -7
  172. package/dist/types/config.d.ts +2 -7
  173. package/dist/types/constants.d.ts +191 -31
  174. package/dist/types/controls-options-manager/enums.d.ts +11 -1
  175. package/dist/types/controls-options-manager/index.d.ts +17 -1
  176. package/dist/types/controls-options-manager/types.d.ts +43 -0
  177. package/dist/types/controls-options-manager/util.d.ts +1 -7
  178. package/dist/types/index.d.ts +6 -4
  179. package/dist/types/interceptors/index.d.ts +2 -0
  180. package/dist/types/interceptors/locusRetry.d.ts +27 -0
  181. package/dist/types/interpretation/collection.d.ts +5 -0
  182. package/dist/types/interpretation/index.d.ts +5 -0
  183. package/dist/types/interpretation/siLanguage.d.ts +5 -0
  184. package/dist/types/locus-info/index.d.ts +57 -4
  185. package/dist/types/locus-info/parser.d.ts +66 -6
  186. package/dist/types/media/index.d.ts +2 -0
  187. package/dist/types/media/properties.d.ts +34 -49
  188. package/dist/types/mediaQualityMetrics/config.d.ts +0 -128
  189. package/dist/types/meeting/in-meeting-actions.d.ts +86 -2
  190. package/dist/types/meeting/index.d.ts +557 -496
  191. package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
  192. package/dist/types/meeting/muteState.d.ts +93 -25
  193. package/dist/types/meeting/request.d.ts +62 -43
  194. package/dist/types/meeting/util.d.ts +101 -1
  195. package/dist/types/meeting-info/index.d.ts +13 -1
  196. package/dist/types/meeting-info/meeting-info-v2.d.ts +31 -1
  197. package/dist/types/meetings/collection.d.ts +17 -0
  198. package/dist/types/meetings/index.d.ts +112 -20
  199. package/dist/types/meetings/meetings.types.d.ts +4 -0
  200. package/dist/types/member/index.d.ts +14 -0
  201. package/dist/types/member/types.d.ts +32 -0
  202. package/dist/types/members/collection.d.ts +5 -0
  203. package/dist/types/members/index.d.ts +35 -2
  204. package/dist/types/members/request.d.ts +73 -9
  205. package/dist/types/members/types.d.ts +25 -0
  206. package/dist/types/members/util.d.ts +214 -1
  207. package/dist/types/metrics/constants.d.ts +15 -0
  208. package/dist/types/metrics/index.d.ts +4 -111
  209. package/dist/types/multistream/mediaRequestManager.d.ts +72 -5
  210. package/dist/types/multistream/receiveSlot.d.ts +13 -11
  211. package/dist/types/multistream/receiveSlotManager.d.ts +14 -4
  212. package/dist/types/multistream/remoteMedia.d.ts +8 -29
  213. package/dist/types/multistream/remoteMediaGroup.d.ts +0 -9
  214. package/dist/types/multistream/remoteMediaManager.d.ts +46 -2
  215. package/dist/types/multistream/sendSlotManager.d.ts +61 -0
  216. package/dist/types/reachability/clusterReachability.d.ts +109 -0
  217. package/dist/types/reachability/index.d.ts +60 -95
  218. package/dist/types/reachability/request.d.ts +3 -1
  219. package/dist/types/reachability/util.d.ts +8 -0
  220. package/dist/types/reconnection-manager/index.d.ts +19 -0
  221. package/dist/types/recording-controller/index.d.ts +15 -1
  222. package/dist/types/recording-controller/util.d.ts +5 -4
  223. package/dist/types/roap/index.d.ts +2 -1
  224. package/dist/types/roap/request.d.ts +9 -8
  225. package/dist/types/roap/turnDiscovery.d.ts +21 -3
  226. package/dist/types/rtcMetrics/constants.d.ts +4 -0
  227. package/dist/types/rtcMetrics/index.d.ts +54 -0
  228. package/dist/types/statsAnalyzer/index.d.ts +29 -11
  229. package/dist/types/webinar/collection.d.ts +16 -0
  230. package/dist/types/webinar/index.d.ts +5 -0
  231. package/dist/webinar/collection.js +44 -0
  232. package/dist/webinar/collection.js.map +1 -0
  233. package/dist/webinar/index.js +69 -0
  234. package/dist/webinar/index.js.map +1 -0
  235. package/package.json +22 -19
  236. package/src/annotation/annotation.types.ts +50 -0
  237. package/src/annotation/constants.ts +36 -0
  238. package/src/annotation/index.ts +328 -0
  239. package/src/breakouts/README.md +35 -11
  240. package/src/breakouts/breakout.ts +67 -9
  241. package/src/breakouts/events.ts +56 -0
  242. package/src/breakouts/index.ts +558 -59
  243. package/src/breakouts/utils.ts +42 -0
  244. package/src/common/errors/no-meeting-info.ts +24 -0
  245. package/src/common/errors/reclaim-host-role-errors.ts +134 -0
  246. package/src/common/errors/webex-errors.ts +44 -2
  247. package/src/common/logs/logger-proxy.ts +1 -1
  248. package/src/common/logs/request.ts +5 -1
  249. package/src/common/queue.ts +22 -8
  250. package/src/config.ts +4 -9
  251. package/src/constants.ts +214 -21
  252. package/src/controls-options-manager/enums.ts +12 -0
  253. package/src/controls-options-manager/index.ts +116 -21
  254. package/src/controls-options-manager/types.ts +59 -0
  255. package/src/controls-options-manager/util.ts +294 -14
  256. package/src/index.ts +44 -0
  257. package/src/interceptors/index.ts +3 -0
  258. package/src/interceptors/locusRetry.ts +67 -0
  259. package/src/interpretation/README.md +60 -0
  260. package/src/interpretation/collection.ts +19 -0
  261. package/src/interpretation/index.ts +332 -0
  262. package/src/interpretation/siLanguage.ts +18 -0
  263. package/src/locus-info/controlsUtils.ts +108 -0
  264. package/src/locus-info/index.ts +414 -59
  265. package/src/locus-info/infoUtils.ts +10 -2
  266. package/src/locus-info/mediaSharesUtils.ts +64 -0
  267. package/src/locus-info/parser.ts +258 -47
  268. package/src/locus-info/selfUtils.ts +81 -5
  269. package/src/media/index.ts +97 -107
  270. package/src/media/properties.ts +88 -117
  271. package/src/mediaQualityMetrics/config.ts +0 -135
  272. package/src/meeting/in-meeting-actions.ts +171 -3
  273. package/src/meeting/index.ts +3253 -2408
  274. package/src/meeting/locusMediaRequest.ts +313 -0
  275. package/src/meeting/muteState.ts +223 -136
  276. package/src/meeting/request.ts +142 -120
  277. package/src/meeting/util.ts +588 -395
  278. package/src/meeting-info/index.ts +81 -8
  279. package/src/meeting-info/meeting-info-v2.ts +170 -14
  280. package/src/meeting-info/util.ts +1 -1
  281. package/src/meeting-info/utilv2.ts +23 -23
  282. package/src/meetings/collection.ts +33 -0
  283. package/src/meetings/index.ts +497 -126
  284. package/src/meetings/meetings.types.ts +12 -0
  285. package/src/meetings/request.ts +2 -0
  286. package/src/meetings/util.ts +80 -11
  287. package/src/member/index.ts +58 -0
  288. package/src/member/types.ts +38 -0
  289. package/src/member/util.ts +141 -25
  290. package/src/members/collection.ts +8 -0
  291. package/src/members/index.ts +134 -8
  292. package/src/members/request.ts +97 -17
  293. package/src/members/types.ts +29 -0
  294. package/src/members/util.ts +333 -240
  295. package/src/metrics/constants.ts +15 -0
  296. package/src/metrics/index.ts +1 -469
  297. package/src/multistream/mediaRequestManager.ts +277 -82
  298. package/src/multistream/receiveSlot.ts +31 -17
  299. package/src/multistream/receiveSlotManager.ts +34 -24
  300. package/src/multistream/remoteMedia.ts +27 -2
  301. package/src/multistream/remoteMediaGroup.ts +59 -0
  302. package/src/multistream/remoteMediaManager.ts +148 -30
  303. package/src/multistream/sendSlotManager.ts +170 -0
  304. package/src/reachability/clusterReachability.ts +320 -0
  305. package/src/reachability/index.ts +229 -340
  306. package/src/reachability/request.ts +8 -4
  307. package/src/reachability/util.ts +24 -0
  308. package/src/reconnection-manager/index.ts +128 -106
  309. package/src/recording-controller/index.ts +20 -3
  310. package/src/recording-controller/util.ts +26 -9
  311. package/src/roap/index.ts +52 -23
  312. package/src/roap/request.ts +48 -67
  313. package/src/roap/turnDiscovery.ts +48 -26
  314. package/src/rtcMetrics/constants.ts +3 -0
  315. package/src/rtcMetrics/index.ts +124 -0
  316. package/src/statsAnalyzer/index.ts +220 -291
  317. package/src/statsAnalyzer/mqaUtil.ts +43 -44
  318. package/src/webinar/collection.ts +31 -0
  319. package/src/webinar/index.ts +62 -0
  320. package/test/integration/spec/converged-space-meetings.js +60 -3
  321. package/test/integration/spec/journey.js +320 -261
  322. package/test/integration/spec/space-meeting.js +76 -3
  323. package/test/unit/spec/annotation/index.ts +418 -0
  324. package/test/unit/spec/breakouts/breakout.ts +118 -28
  325. package/test/unit/spec/breakouts/events.ts +89 -0
  326. package/test/unit/spec/breakouts/index.ts +1349 -114
  327. package/test/unit/spec/breakouts/utils.js +52 -1
  328. package/test/unit/spec/common/queue.js +31 -2
  329. package/test/unit/spec/controls-options-manager/index.js +163 -0
  330. package/test/unit/spec/controls-options-manager/util.js +576 -60
  331. package/test/unit/spec/fixture/locus.js +1 -0
  332. package/test/unit/spec/interceptors/locusRetry.ts +131 -0
  333. package/test/unit/spec/interpretation/collection.ts +15 -0
  334. package/test/unit/spec/interpretation/index.ts +589 -0
  335. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  336. package/test/unit/spec/locus-info/controlsUtils.js +316 -43
  337. package/test/unit/spec/locus-info/index.js +1352 -33
  338. package/test/unit/spec/locus-info/infoUtils.js +37 -15
  339. package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
  340. package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
  341. package/test/unit/spec/locus-info/parser.js +116 -35
  342. package/test/unit/spec/locus-info/selfConstant.js +27 -4
  343. package/test/unit/spec/locus-info/selfUtils.js +208 -17
  344. package/test/unit/spec/media/index.ts +118 -37
  345. package/test/unit/spec/media/properties.ts +2 -2
  346. package/test/unit/spec/meeting/in-meeting-actions.ts +85 -3
  347. package/test/unit/spec/meeting/index.js +6686 -2212
  348. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  349. package/test/unit/spec/meeting/muteState.js +402 -212
  350. package/test/unit/spec/meeting/request.js +459 -52
  351. package/test/unit/spec/meeting/utils.js +680 -67
  352. package/test/unit/spec/meeting-info/index.js +300 -0
  353. package/test/unit/spec/meeting-info/meetinginfov2.js +526 -5
  354. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  355. package/test/unit/spec/meetings/collection.js +26 -0
  356. package/test/unit/spec/meetings/index.js +1393 -212
  357. package/test/unit/spec/meetings/utils.js +202 -2
  358. package/test/unit/spec/member/index.js +61 -6
  359. package/test/unit/spec/member/util.js +510 -34
  360. package/test/unit/spec/members/index.js +432 -1
  361. package/test/unit/spec/members/request.js +206 -27
  362. package/test/unit/spec/members/utils.js +210 -0
  363. package/test/unit/spec/metrics/index.js +1 -50
  364. package/test/unit/spec/multistream/mediaRequestManager.ts +776 -162
  365. package/test/unit/spec/multistream/receiveSlot.ts +28 -20
  366. package/test/unit/spec/multistream/receiveSlotManager.ts +32 -30
  367. package/test/unit/spec/multistream/remoteMedia.ts +30 -0
  368. package/test/unit/spec/multistream/remoteMediaGroup.ts +266 -0
  369. package/test/unit/spec/multistream/remoteMediaManager.ts +326 -0
  370. package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
  371. package/test/unit/spec/reachability/clusterReachability.ts +279 -0
  372. package/test/unit/spec/reachability/index.ts +477 -14
  373. package/test/unit/spec/reachability/request.js +3 -1
  374. package/test/unit/spec/reachability/util.ts +40 -0
  375. package/test/unit/spec/reconnection-manager/index.js +118 -11
  376. package/test/unit/spec/recording-controller/index.js +294 -218
  377. package/test/unit/spec/recording-controller/util.js +223 -96
  378. package/test/unit/spec/roap/index.ts +180 -83
  379. package/test/unit/spec/roap/request.ts +100 -62
  380. package/test/unit/spec/roap/turnDiscovery.ts +76 -34
  381. package/test/unit/spec/rtcMetrics/index.ts +93 -0
  382. package/test/unit/spec/stats-analyzer/index.js +621 -12
  383. package/test/unit/spec/webinar/collection.ts +13 -0
  384. package/test/unit/spec/webinar/index.ts +60 -0
  385. package/test/utils/integrationTestUtils.js +46 -0
  386. package/test/utils/testUtils.js +0 -57
  387. package/dist/metrics/config.js +0 -289
  388. package/dist/metrics/config.js.map +0 -1
  389. package/dist/types/metrics/config.d.ts +0 -169
  390. package/src/index.js +0 -16
  391. package/src/metrics/config.ts +0 -485
@@ -1,5 +1,6 @@
1
1
  import {assert} from '@webex/test-helper-chai';
2
2
  import ControlsUtils from '@webex/plugin-meetings/src/locus-info/controlsUtils';
3
+ import controlsUtils from "@webex/plugin-meetings/src/locus-info/controlsUtils";
3
4
 
4
5
  const defaultControls = {
5
6
  entryExitTone: {
@@ -39,64 +40,336 @@ describe('plugin-meetings', () => {
39
40
 
40
41
  assert.equal(parsedControls.entryExitTone, null);
41
42
  });
42
- });
43
- });
44
43
 
45
- describe('getControls', () => {
46
- it('returns hasEntryExitToneChanged = true when mode changed', () => {
47
- const newControls = {
48
- entryExitTone: {
49
- enabled: true,
50
- mode: 'bar',
51
- },
52
- };
53
- const {updates} = ControlsUtils.getControls(defaultControls, newControls);
54
-
55
- assert.equal(updates.hasEntryExitToneChanged, true);
44
+ it('should parse the muteOnEntry control', () => {
45
+ const newControls = {muteOnEntry: {enabled: true}};
46
+
47
+ const parsedControls = ControlsUtils.parse(newControls);
48
+
49
+ assert.equal(parsedControls.muteOnEntry.enabled, newControls.muteOnEntry.enabled);
50
+ });
51
+
52
+ it('should parse the shareControl control', () => {
53
+ const newControls = {shareControl: {control: 'example-value'}};
54
+
55
+ const parsedControls = ControlsUtils.parse(newControls);
56
+
57
+ assert.equal(parsedControls.shareControl.control, newControls.shareControl.control);
58
+ });
59
+
60
+ it('should parse the disallowUnmute control', () => {
61
+ const newControls = {disallowUnmute: {enabled: true}};
62
+
63
+ const parsedControls = ControlsUtils.parse(newControls);
64
+
65
+ assert.equal(parsedControls.disallowUnmute.enabled, newControls.disallowUnmute.enabled);
66
+ });
67
+
68
+ it('should parse the reactions control', () => {
69
+ const newControls = {reactions: {enabled: true}};
70
+
71
+ const parsedControls = ControlsUtils.parse(newControls);
72
+
73
+ assert.equal(parsedControls.reactions.enabled, newControls.reactions.enabled);
74
+ });
75
+
76
+ it('should parse the reactionDisplayNames control', () => {
77
+ const newControls = {reactions: {showDisplayNameWithReactions: true}};
78
+
79
+ const parsedControls = ControlsUtils.parse(newControls);
80
+
81
+ assert.equal(parsedControls.reactions.showDisplayNameWithReactions, newControls.reactions.showDisplayNameWithReactions);
82
+ });
83
+
84
+ it('should parse the viewTheParticipantList control', () => {
85
+ const newControls = {viewTheParticipantList: {enabled: true}};
86
+
87
+ const parsedControls = ControlsUtils.parse(newControls);
88
+
89
+ assert.equal(parsedControls.viewTheParticipantList.enabled, newControls.viewTheParticipantList.enabled);
90
+ });
91
+
92
+ it('should parse the raiseHand control', () => {
93
+ const newControls = {raiseHand: {enabled: true}};
94
+
95
+ const parsedControls = ControlsUtils.parse(newControls);
96
+
97
+ assert.equal(parsedControls.raiseHand.enabled, newControls.raiseHand.enabled);
98
+ });
99
+
100
+ it('should parse the video control', () => {
101
+ const newControls = {video: {enabled: true}};
102
+
103
+ const parsedControls = ControlsUtils.parse(newControls);
104
+
105
+ assert.equal(parsedControls.video.enabled, newControls.video.enabled);
106
+ });
107
+
108
+ describe('videoEnabled', () => {
109
+ it('returns expected', () => {
110
+ const result = ControlsUtils.parse({video: {enabled: true}});
111
+ assert.deepEqual(result, {
112
+ video: {
113
+ enabled: true,
114
+ },
115
+ videoEnabled: true,
116
+ });
117
+ });
118
+
119
+ it('returns expected from undefined', () => {
120
+ const result = ControlsUtils.parse();
121
+ assert.deepEqual(result, {});
122
+ });
123
+
124
+ it('returns expected from undefined controls', () => {
125
+ const result = ControlsUtils.parse({});
126
+ assert.deepEqual(result, {});
127
+ });
128
+ });
56
129
  });
57
130
 
58
- it('returns hasEntryExitToneChanged = true when enabled changed', () => {
59
- const newControls = {
60
- entryExitTone: {
61
- enabled: false,
62
- mode: 'foo',
63
- },
64
- };
65
- const {updates} = ControlsUtils.getControls(defaultControls, newControls);
131
+ describe('getControls', () => {
132
+ it('returns hasMuteOnEntryChanged = true when changed', () => {
133
+ const newControls = {muteOnEntry: {enabled: true}};
134
+
135
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
136
+
137
+ assert.equal(updates.hasMuteOnEntryChanged, true);
138
+ });
139
+
140
+ it('returns hasShareControlChanged = true when changed', () => {
141
+ const newControls = {shareControl: {control: 'example-value'}};
142
+
143
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
144
+
145
+ assert.equal(updates.hasShareControlChanged, true);
146
+ });
147
+
148
+ it('returns hasDisallowUnmuteChanged = true when changed', () => {
149
+ const newControls = {disallowUnmute: {enabled: true}};
150
+
151
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
152
+
153
+ assert.equal(updates.hasDisallowUnmuteChanged, true);
154
+ });
155
+
156
+ it('returns hasReactionsChanged = true when changed', () => {
157
+ const newControls = {reactions: {enabled: true}};
158
+
159
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
160
+
161
+ assert.equal(updates.hasReactionsChanged, true);
162
+ });
163
+
164
+ it('returns hasReactionDisplayNamesChanged = true when changed', () => {
165
+ const newControls = {reactions: {showDisplayNameWithReactions: true}};
166
+
167
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
168
+
169
+ assert.equal(updates.hasReactionDisplayNamesChanged, true);
170
+ });
171
+
172
+ it('returns hasViewTheParticipantListChanged = true when changed', () => {
173
+ const newControls = {viewTheParticipantList: {enabled: true}};
174
+
175
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
176
+
177
+ assert.equal(updates.hasViewTheParticipantListChanged, true);
178
+ });
179
+
180
+ it('returns hasRaiseHandChanged = true when changed', () => {
181
+ const newControls = {raiseHand: {enabled: true}};
66
182
 
67
- assert.equal(updates.hasEntryExitToneChanged, true);
183
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
184
+
185
+ assert.equal(updates.hasRaiseHandChanged, true);
186
+ });
187
+
188
+ it('returns hasVideoChanged = true when changed', () => {
189
+ const newControls = {video: {enabled: true}};
190
+
191
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
192
+
193
+ assert.equal(updates.hasVideoChanged, true);
194
+ });
195
+
196
+ it('returns hasEntryExitToneChanged = true when mode changed', () => {
197
+ const newControls = {
198
+ entryExitTone: {
199
+ enabled: true,
200
+ mode: 'bar',
201
+ },
202
+ };
203
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
204
+
205
+ assert.equal(updates.hasEntryExitToneChanged, true);
206
+ });
207
+
208
+ it('returns hasEntryExitToneChanged = true when enabled changed', () => {
209
+ const newControls = {
210
+ entryExitTone: {
211
+ enabled: false,
212
+ mode: 'foo',
213
+ },
214
+ };
215
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
216
+
217
+ assert.equal(updates.hasEntryExitToneChanged, true);
218
+ });
219
+
220
+ it('returns hasEntryExitToneChanged = false when nothing changed', () => {
221
+ const newControls = {
222
+ entryExitTone: {
223
+ enabled: true,
224
+ mode: 'foo',
225
+ },
226
+ };
227
+ const {updates} = ControlsUtils.getControls(defaultControls, newControls);
228
+
229
+ assert.equal(updates.hasEntryExitToneChanged, false);
230
+ });
231
+
232
+ it('returns hasBreakoutChanged = true when it has changed', () => {
233
+ const newControls = {
234
+ breakout: 'breakout',
235
+ };
236
+
237
+ const {updates} = ControlsUtils.getControls({breakout: 'old breakout'}, newControls);
238
+
239
+ assert.equal(updates.hasBreakoutChanged, true);
240
+ });
241
+
242
+ it('returns hasBreakoutChanged = false when it has not changed', () => {
243
+ const newControls = {
244
+ breakout: 'breakout',
245
+ };
246
+
247
+ const {updates} = ControlsUtils.getControls({breakout: 'breakout'}, newControls);
248
+
249
+ assert.equal(updates.hasBreakoutChanged, false);
250
+ });
251
+
252
+ it('returns hasInterpretationChanged = true when it has changed', () => {
253
+ const newControls = {
254
+ interpretation: 'interpretation',
255
+ };
256
+
257
+ const {updates} = ControlsUtils.getControls({interpretation: 'old one'}, newControls);
258
+
259
+ assert.equal(updates.hasInterpretationChanged, true);
260
+ });
261
+
262
+ it('returns hasInterpretationChanged = false when it has not changed', () => {
263
+ const newControls = {
264
+ interpretation: 'interpretation',
265
+ };
266
+
267
+ const {updates} = ControlsUtils.getControls({interpretation: 'interpretation'}, newControls);
268
+
269
+ assert.equal(updates.hasInterpretationChanged, false);
270
+ });
271
+
272
+ describe('videoEnabled', () => {
273
+ const testVideoEnabled = (oldControls, newControls, updatedProperty) => {
274
+ const result = ControlsUtils.getControls(oldControls, newControls);
275
+
276
+ let expectedPrevious = oldControls;
277
+ if (Object.keys(oldControls).length) {
278
+ expectedPrevious = {
279
+ ...expectedPrevious,
280
+ ...{videoEnabled: oldControls.video.enabled},
281
+ };
282
+ }
283
+ const expectedCurrent = {...newControls, ...{videoEnabled: newControls.video.enabled}};
284
+
285
+ assert.deepEqual(result.previous, expectedPrevious);
286
+ assert.deepEqual(result.current, expectedCurrent);
287
+ if (updatedProperty !== undefined) {
288
+ assert.deepEqual(
289
+ result.updates.hasVideoEnabledChanged,
290
+ !isEqual(oldControls, newControls)
291
+ );
292
+ }
293
+ };
294
+
295
+ it('returns expected from undefined', () => {
296
+ testVideoEnabled({}, {video: {enabled: true}});
297
+ });
298
+
299
+ it('returns expected from defined', () => {
300
+ testVideoEnabled({video: {enabled: false}}, {video: {enabled: true}});
301
+ });
302
+
303
+ it('returns expected for unchanged', () => {
304
+ testVideoEnabled({video: {enabled: false}}, {video: {enabled: false}});
305
+ });
306
+ });
68
307
  });
69
308
 
70
- it('returns hasEntryExitToneChanged = false when nothing changed', () => {
71
- const newControls = {
72
- entryExitTone: {
73
- enabled: true,
74
- mode: 'foo',
75
- },
76
- };
77
- const {updates} = ControlsUtils.getControls(defaultControls, newControls);
309
+ describe('isNeedReplaceMembers', () => {
310
+ it('if no breakout control, return false', () => {
311
+ const oldControls = {};
312
+ const newControls = {};
313
+ assert.equal(controlsUtils.isNeedReplaceMembers(oldControls, newControls), false);
314
+ });
315
+
316
+ it('if current session moved, return true', () => {
317
+ const oldControls = {breakout: {sessionId: 'sessionId1', groupId: 'groupId1'}};
318
+ const newControls = {breakout: {sessionId: 'sessionId2', groupId: 'groupId2'}};
319
+ assert.equal(controlsUtils.isNeedReplaceMembers(oldControls, newControls), true);
320
+ });
78
321
 
79
- assert.equal(updates.hasEntryExitToneChanged, false);
322
+ it('if in same session, return false', () => {
323
+ const oldControls = {breakout: {sessionId: 'sessionId1', groupId: 'groupId'}};
324
+ const newControls = {breakout: {sessionId: 'sessionId1', groupId: 'groupId'}};
325
+ assert.equal(controlsUtils.isNeedReplaceMembers(oldControls, newControls), false);
326
+ });
80
327
  });
81
328
 
82
- it('returns hasBreakoutChanged = true when it has changed', () => {
83
- const newControls = {
84
- breakout: 'breakout'
85
- };
329
+ describe('getSessionSwitchStatus', () => {
330
+ it('if no breakout control, return switch status both false', () => {
331
+ const oldControls = {};
332
+ const newControls = {};
333
+ assert.deepEqual(controlsUtils.getSessionSwitchStatus(oldControls, newControls), {
334
+ isReturnToMain: false, isJoinToBreakout: false
335
+ });
336
+ });
86
337
 
87
- const {updates} = ControlsUtils.getControls({breakout: 'old breakout'}, newControls);
338
+ it('if switch session from breakout to main, return isReturnToMain as true', () => {
339
+ const oldControls = {breakout: {sessionType: 'BREAKOUT'}};
340
+ const newControls = {breakout: {sessionType: 'MAIN'}};
341
+ assert.deepEqual(controlsUtils.getSessionSwitchStatus(oldControls, newControls), {
342
+ isReturnToMain: true, isJoinToBreakout: false
343
+ });
344
+ });
88
345
 
89
- assert.equal(updates.hasBreakoutChanged, true);
346
+ it('if switch session from main to breakout, return isJoinToBreakout as true', () => {
347
+ const oldControls = {breakout: {sessionType: 'MAIN'}};
348
+ const newControls = {breakout: {sessionType: 'BREAKOUT'}};
349
+ assert.deepEqual(controlsUtils.getSessionSwitchStatus(oldControls, newControls), {
350
+ isReturnToMain: false, isJoinToBreakout: true
351
+ });
352
+ });
90
353
  });
91
354
 
92
- it('returns hasBreakoutChanged = false when it has not changed', () => {
93
- const newControls = {
94
- breakout: 'breakout'
95
- };
355
+ describe('#isMainSessionDTO', () => {
356
+ it('return false is sessionType is BREAKOUT', () => {
357
+ const locus = {
358
+ controls: {breakout: {sessionType: 'BREAKOUT'}}
359
+ };
96
360
 
97
- const {updates} = ControlsUtils.getControls({breakout: 'breakout'}, newControls);
361
+ assert.equal(controlsUtils.isMainSessionDTO(locus), false);
362
+ });
363
+
364
+ it('return true is sessionType is not BREAKOUT', () => {
365
+ const locus = {
366
+ controls: {breakout: {sessionType: 'MAIN'}}
367
+ };
98
368
 
99
- assert.equal(updates.hasBreakoutChanged, false);
369
+ assert.equal(controlsUtils.isMainSessionDTO(locus), true);
370
+
371
+ assert.equal(controlsUtils.isMainSessionDTO({}), true);
372
+ });
100
373
  });
101
374
  });
102
375
  });