@webex/plugin-meetings 2.60.0 → 2.60.1-next.2

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 (535) hide show
  1. package/README.md +46 -8
  2. package/dist/annotation/annotation.types.d.ts +42 -0
  3. package/dist/annotation/annotation.types.js +7 -0
  4. package/dist/annotation/annotation.types.js.map +1 -0
  5. package/dist/annotation/constants.d.ts +31 -0
  6. package/dist/annotation/constants.js +41 -0
  7. package/dist/annotation/constants.js.map +1 -0
  8. package/dist/annotation/index.d.ts +117 -0
  9. package/dist/annotation/index.js +357 -0
  10. package/dist/annotation/index.js.map +1 -0
  11. package/dist/breakouts/breakout.d.ts +8 -0
  12. package/dist/breakouts/breakout.js +215 -0
  13. package/dist/breakouts/breakout.js.map +1 -0
  14. package/dist/breakouts/collection.d.ts +5 -0
  15. package/dist/breakouts/collection.js +22 -0
  16. package/dist/breakouts/collection.js.map +1 -0
  17. package/dist/breakouts/edit-lock-error.d.ts +15 -0
  18. package/dist/breakouts/edit-lock-error.js +51 -0
  19. package/dist/breakouts/edit-lock-error.js.map +1 -0
  20. package/dist/breakouts/events.d.ts +8 -0
  21. package/dist/breakouts/events.js +44 -0
  22. package/dist/breakouts/events.js.map +1 -0
  23. package/dist/breakouts/index.d.ts +5 -0
  24. package/dist/breakouts/index.js +1047 -0
  25. package/dist/breakouts/index.js.map +1 -0
  26. package/dist/breakouts/request.d.ts +22 -0
  27. package/dist/breakouts/request.js +77 -0
  28. package/dist/breakouts/request.js.map +1 -0
  29. package/dist/breakouts/utils.d.ts +15 -0
  30. package/dist/breakouts/utils.js +64 -0
  31. package/dist/breakouts/utils.js.map +1 -0
  32. package/dist/common/browser-detection.js +2 -3
  33. package/dist/common/browser-detection.js.map +1 -1
  34. package/dist/common/collection.js +3 -4
  35. package/dist/common/collection.js.map +1 -1
  36. package/dist/common/config.js +1 -2
  37. package/dist/common/config.js.map +1 -1
  38. package/dist/common/errors/captcha-error.js +1 -2
  39. package/dist/common/errors/captcha-error.js.map +1 -1
  40. package/dist/common/errors/intent-to-join.js +1 -2
  41. package/dist/common/errors/intent-to-join.js.map +1 -1
  42. package/dist/common/errors/join-meeting.js +1 -2
  43. package/dist/common/errors/join-meeting.js.map +1 -1
  44. package/dist/common/errors/media.js +1 -2
  45. package/dist/common/errors/media.js.map +1 -1
  46. package/dist/common/errors/no-meeting-info.d.ts +14 -0
  47. package/dist/common/errors/no-meeting-info.js +50 -0
  48. package/dist/common/errors/no-meeting-info.js.map +1 -0
  49. package/dist/common/errors/parameter.js +3 -4
  50. package/dist/common/errors/parameter.js.map +1 -1
  51. package/dist/common/errors/password-error.js +1 -2
  52. package/dist/common/errors/password-error.js.map +1 -1
  53. package/dist/common/errors/permission.js +1 -2
  54. package/dist/common/errors/permission.js.map +1 -1
  55. package/dist/common/errors/{reclaim-host-role-error.js → reclaim-host-role-errors.js} +7 -11
  56. package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
  57. package/dist/common/errors/reconnection-in-progress.js +1 -2
  58. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  59. package/dist/common/errors/reconnection.js +1 -2
  60. package/dist/common/errors/reconnection.js.map +1 -1
  61. package/dist/common/errors/stats.js +1 -2
  62. package/dist/common/errors/stats.js.map +1 -1
  63. package/dist/common/errors/webex-errors.d.ts +20 -8
  64. package/dist/common/errors/webex-errors.js +48 -28
  65. package/dist/common/errors/webex-errors.js.map +1 -1
  66. package/dist/common/errors/webex-meetings-error.js +1 -2
  67. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  68. package/dist/common/events/events-scope.js +1 -2
  69. package/dist/common/events/events-scope.js.map +1 -1
  70. package/dist/common/events/events.js +1 -2
  71. package/dist/common/events/events.js.map +1 -1
  72. package/dist/common/events/trigger-proxy.js +1 -2
  73. package/dist/common/events/trigger-proxy.js.map +1 -1
  74. package/dist/common/events/util.js +1 -2
  75. package/dist/common/events/util.js.map +1 -1
  76. package/dist/common/logs/logger-config.js +1 -2
  77. package/dist/common/logs/logger-config.js.map +1 -1
  78. package/dist/common/logs/logger-proxy.js +2 -3
  79. package/dist/common/logs/logger-proxy.js.map +1 -1
  80. package/dist/common/logs/request.d.ts +3 -1
  81. package/dist/common/logs/request.js +8 -5
  82. package/dist/common/logs/request.js.map +1 -1
  83. package/dist/common/queue.d.ts +9 -7
  84. package/dist/common/queue.js +22 -9
  85. package/dist/common/queue.js.map +1 -1
  86. package/dist/config.d.ts +6 -7
  87. package/dist/config.js +8 -10
  88. package/dist/config.js.map +1 -1
  89. package/dist/constants.d.ts +217 -97
  90. package/dist/constants.js +416 -441
  91. package/dist/constants.js.map +1 -1
  92. package/dist/controls-options-manager/constants.js +3 -6
  93. package/dist/controls-options-manager/constants.js.map +1 -1
  94. package/dist/controls-options-manager/enums.d.ts +11 -1
  95. package/dist/controls-options-manager/enums.js +15 -6
  96. package/dist/controls-options-manager/enums.js.map +1 -1
  97. package/dist/controls-options-manager/index.d.ts +17 -1
  98. package/dist/controls-options-manager/index.js +127 -38
  99. package/dist/controls-options-manager/index.js.map +1 -1
  100. package/dist/controls-options-manager/types.d.ts +43 -0
  101. package/dist/controls-options-manager/types.js +7 -0
  102. package/dist/controls-options-manager/types.js.map +1 -0
  103. package/dist/controls-options-manager/util.d.ts +1 -7
  104. package/dist/controls-options-manager/util.js +309 -19
  105. package/dist/controls-options-manager/util.js.map +1 -1
  106. package/dist/index.d.ts +6 -3
  107. package/dist/index.js +121 -5
  108. package/dist/index.js.map +1 -1
  109. package/dist/interceptors/index.d.ts +2 -0
  110. package/dist/interceptors/index.js +15 -0
  111. package/dist/interceptors/index.js.map +1 -0
  112. package/dist/interceptors/locusRetry.d.ts +27 -0
  113. package/dist/interceptors/locusRetry.js +94 -0
  114. package/dist/interceptors/locusRetry.js.map +1 -0
  115. package/dist/interpretation/collection.d.ts +5 -0
  116. package/dist/interpretation/collection.js +22 -0
  117. package/dist/interpretation/collection.js.map +1 -0
  118. package/dist/interpretation/index.d.ts +5 -0
  119. package/dist/interpretation/index.js +365 -0
  120. package/dist/interpretation/index.js.map +1 -0
  121. package/dist/interpretation/siLanguage.d.ts +5 -0
  122. package/dist/interpretation/siLanguage.js +24 -0
  123. package/dist/interpretation/siLanguage.js.map +1 -0
  124. package/dist/locus-info/controlsUtils.js +100 -11
  125. package/dist/locus-info/controlsUtils.js.map +1 -1
  126. package/dist/locus-info/embeddedAppsUtils.js +3 -4
  127. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  128. package/dist/locus-info/fullState.js +1 -2
  129. package/dist/locus-info/fullState.js.map +1 -1
  130. package/dist/locus-info/hostUtils.js +1 -2
  131. package/dist/locus-info/hostUtils.js.map +1 -1
  132. package/dist/locus-info/index.d.ts +57 -4
  133. package/dist/locus-info/index.js +425 -84
  134. package/dist/locus-info/index.js.map +1 -1
  135. package/dist/locus-info/infoUtils.js +13 -5
  136. package/dist/locus-info/infoUtils.js.map +1 -1
  137. package/dist/locus-info/mediaSharesUtils.js +58 -3
  138. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  139. package/dist/locus-info/parser.d.ts +66 -6
  140. package/dist/locus-info/parser.js +253 -80
  141. package/dist/locus-info/parser.js.map +1 -1
  142. package/dist/locus-info/selfUtils.js +97 -13
  143. package/dist/locus-info/selfUtils.js.map +1 -1
  144. package/dist/media/index.d.ts +2 -0
  145. package/dist/media/index.js +107 -319
  146. package/dist/media/index.js.map +1 -1
  147. package/dist/media/properties.d.ts +38 -53
  148. package/dist/media/properties.js +96 -153
  149. package/dist/media/properties.js.map +1 -1
  150. package/dist/media/util.js +1 -22
  151. package/dist/media/util.js.map +1 -1
  152. package/dist/mediaQualityMetrics/config.d.ts +234 -230
  153. package/dist/mediaQualityMetrics/config.js +302 -498
  154. package/dist/mediaQualityMetrics/config.js.map +1 -1
  155. package/dist/meeting/in-meeting-actions.d.ts +88 -0
  156. package/dist/meeting/in-meeting-actions.js +94 -3
  157. package/dist/meeting/in-meeting-actions.js.map +1 -1
  158. package/dist/meeting/index.d.ts +591 -494
  159. package/dist/meeting/index.js +4732 -2990
  160. package/dist/meeting/index.js.map +1 -1
  161. package/dist/meeting/locusMediaRequest.d.ts +74 -0
  162. package/dist/meeting/locusMediaRequest.js +291 -0
  163. package/dist/meeting/locusMediaRequest.js.map +1 -0
  164. package/dist/meeting/muteState.d.ts +93 -25
  165. package/dist/meeting/muteState.js +224 -133
  166. package/dist/meeting/muteState.js.map +1 -1
  167. package/dist/meeting/request.d.ts +82 -47
  168. package/dist/meeting/request.js +297 -199
  169. package/dist/meeting/request.js.map +1 -1
  170. package/dist/meeting/request.type.d.ts +11 -0
  171. package/dist/meeting/request.type.js +7 -0
  172. package/dist/meeting/request.type.js.map +1 -0
  173. package/dist/meeting/state.js +1 -2
  174. package/dist/meeting/state.js.map +1 -1
  175. package/dist/meeting/util.d.ts +102 -1
  176. package/dist/meeting/util.js +605 -435
  177. package/dist/meeting/util.js.map +1 -1
  178. package/dist/meeting-info/collection.js +3 -4
  179. package/dist/meeting-info/collection.js.map +1 -1
  180. package/dist/meeting-info/index.d.ts +13 -1
  181. package/dist/meeting-info/index.js +74 -7
  182. package/dist/meeting-info/index.js.map +1 -1
  183. package/dist/meeting-info/meeting-info-v2.d.ts +31 -1
  184. package/dist/meeting-info/meeting-info-v2.js +200 -63
  185. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  186. package/dist/meeting-info/request.js +1 -2
  187. package/dist/meeting-info/request.js.map +1 -1
  188. package/dist/meeting-info/util.js +2 -3
  189. package/dist/meeting-info/util.js.map +1 -1
  190. package/dist/meeting-info/utilv2.js +39 -41
  191. package/dist/meeting-info/utilv2.js.map +1 -1
  192. package/dist/meetings/collection.d.ts +17 -0
  193. package/dist/meetings/collection.js +42 -4
  194. package/dist/meetings/collection.js.map +1 -1
  195. package/dist/meetings/index.d.ts +93 -21
  196. package/dist/meetings/index.js +490 -127
  197. package/dist/meetings/index.js.map +1 -1
  198. package/dist/meetings/meetings.types.d.ts +4 -0
  199. package/dist/meetings/meetings.types.js +7 -0
  200. package/dist/meetings/meetings.types.js.map +1 -0
  201. package/dist/meetings/request.js +4 -3
  202. package/dist/meetings/request.js.map +1 -1
  203. package/dist/meetings/util.js +107 -6
  204. package/dist/meetings/util.js.map +1 -1
  205. package/dist/member/index.d.ts +13 -1
  206. package/dist/member/index.js +45 -2
  207. package/dist/member/index.js.map +1 -1
  208. package/dist/member/member.types.js +3 -4
  209. package/dist/member/member.types.js.map +1 -1
  210. package/dist/member/types.d.ts +32 -0
  211. package/dist/member/types.js +23 -0
  212. package/dist/member/types.js.map +1 -0
  213. package/dist/member/util.js +120 -29
  214. package/dist/member/util.js.map +1 -1
  215. package/dist/members/collection.d.ts +5 -0
  216. package/dist/members/collection.js +11 -2
  217. package/dist/members/collection.js.map +1 -1
  218. package/dist/members/index.d.ts +56 -11
  219. package/dist/members/index.js +174 -47
  220. package/dist/members/index.js.map +1 -1
  221. package/dist/members/request.d.ts +67 -11
  222. package/dist/members/request.js +102 -54
  223. package/dist/members/request.js.map +1 -1
  224. package/dist/members/types.js +3 -4
  225. package/dist/members/types.js.map +1 -1
  226. package/dist/members/util.d.ts +214 -1
  227. package/dist/members/util.js +327 -284
  228. package/dist/members/util.js.map +1 -1
  229. package/dist/metrics/constants.d.ts +15 -6
  230. package/dist/metrics/constants.js +17 -9
  231. package/dist/metrics/constants.js.map +1 -1
  232. package/dist/metrics/index.d.ts +4 -111
  233. package/dist/metrics/index.js +4 -452
  234. package/dist/metrics/index.js.map +1 -1
  235. package/dist/multistream/mediaRequestManager.d.ts +118 -0
  236. package/dist/multistream/mediaRequestManager.js +344 -0
  237. package/dist/multistream/mediaRequestManager.js.map +1 -0
  238. package/dist/multistream/receiveSlot.d.ts +68 -0
  239. package/dist/multistream/receiveSlot.js +200 -0
  240. package/dist/multistream/receiveSlot.js.map +1 -0
  241. package/dist/multistream/receiveSlotManager.d.ts +56 -0
  242. package/dist/multistream/receiveSlotManager.js +174 -0
  243. package/dist/multistream/receiveSlotManager.js.map +1 -0
  244. package/dist/multistream/remoteMedia.d.ts +72 -0
  245. package/dist/multistream/remoteMedia.js +268 -0
  246. package/dist/multistream/remoteMedia.js.map +1 -0
  247. package/dist/multistream/remoteMediaGroup.d.ts +47 -0
  248. package/dist/multistream/remoteMediaGroup.js +267 -0
  249. package/dist/multistream/remoteMediaGroup.js.map +1 -0
  250. package/dist/multistream/remoteMediaManager.d.ts +285 -0
  251. package/dist/multistream/remoteMediaManager.js +1211 -0
  252. package/dist/multistream/remoteMediaManager.js.map +1 -0
  253. package/dist/multistream/sendSlotManager.d.ts +61 -0
  254. package/dist/multistream/sendSlotManager.js +236 -0
  255. package/dist/multistream/sendSlotManager.js.map +1 -0
  256. package/dist/networkQualityMonitor/index.js +5 -4
  257. package/dist/networkQualityMonitor/index.js.map +1 -1
  258. package/dist/personal-meeting-room/index.js +2 -3
  259. package/dist/personal-meeting-room/index.js.map +1 -1
  260. package/dist/personal-meeting-room/request.js +2 -3
  261. package/dist/personal-meeting-room/request.js.map +1 -1
  262. package/dist/personal-meeting-room/util.js +1 -2
  263. package/dist/personal-meeting-room/util.js.map +1 -1
  264. package/dist/reachability/clusterReachability.d.ts +109 -0
  265. package/dist/reachability/clusterReachability.js +357 -0
  266. package/dist/reachability/clusterReachability.js.map +1 -0
  267. package/dist/reachability/index.d.ts +61 -95
  268. package/dist/reachability/index.js +300 -393
  269. package/dist/reachability/index.js.map +1 -1
  270. package/dist/reachability/request.d.ts +7 -3
  271. package/dist/reachability/request.js +18 -10
  272. package/dist/reachability/request.js.map +1 -1
  273. package/dist/reachability/util.d.ts +8 -0
  274. package/dist/reachability/util.js +29 -0
  275. package/dist/reachability/util.js.map +1 -0
  276. package/dist/reactions/constants.d.ts +3 -0
  277. package/dist/reactions/constants.js +12 -0
  278. package/dist/reactions/constants.js.map +1 -0
  279. package/dist/reactions/reactions.d.ts +2 -2
  280. package/dist/reactions/reactions.js +4 -6
  281. package/dist/reactions/reactions.js.map +1 -1
  282. package/dist/reactions/reactions.type.d.ts +23 -3
  283. package/dist/reactions/reactions.type.js +21 -23
  284. package/dist/reactions/reactions.type.js.map +1 -1
  285. package/dist/reconnection-manager/index.d.ts +32 -8
  286. package/dist/reconnection-manager/index.js +282 -231
  287. package/dist/reconnection-manager/index.js.map +1 -1
  288. package/dist/recording-controller/enums.js +4 -5
  289. package/dist/recording-controller/enums.js.map +1 -1
  290. package/dist/recording-controller/index.d.ts +15 -1
  291. package/dist/recording-controller/index.js +57 -46
  292. package/dist/recording-controller/index.js.map +1 -1
  293. package/dist/recording-controller/util.d.ts +5 -4
  294. package/dist/recording-controller/util.js +10 -10
  295. package/dist/recording-controller/util.js.map +1 -1
  296. package/dist/roap/index.d.ts +9 -47
  297. package/dist/roap/index.js +101 -235
  298. package/dist/roap/index.js.map +1 -1
  299. package/dist/roap/request.d.ts +18 -12
  300. package/dist/roap/request.js +126 -180
  301. package/dist/roap/request.js.map +1 -1
  302. package/dist/roap/turnDiscovery.d.ts +27 -16
  303. package/dist/roap/turnDiscovery.js +115 -105
  304. package/dist/roap/turnDiscovery.js.map +1 -1
  305. package/dist/rtcMetrics/constants.d.ts +4 -0
  306. package/dist/rtcMetrics/constants.js +11 -0
  307. package/dist/rtcMetrics/constants.js.map +1 -0
  308. package/dist/rtcMetrics/index.d.ts +54 -0
  309. package/dist/rtcMetrics/index.js +140 -0
  310. package/dist/rtcMetrics/index.js.map +1 -0
  311. package/dist/statsAnalyzer/global.d.ts +1 -83
  312. package/dist/statsAnalyzer/global.js +2 -85
  313. package/dist/statsAnalyzer/global.js.map +1 -1
  314. package/dist/statsAnalyzer/index.d.ts +50 -30
  315. package/dist/statsAnalyzer/index.js +435 -510
  316. package/dist/statsAnalyzer/index.js.map +1 -1
  317. package/dist/statsAnalyzer/mqaUtil.d.ts +8 -6
  318. package/dist/statsAnalyzer/mqaUtil.js +120 -83
  319. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  320. package/dist/transcription/index.js +1 -2
  321. package/dist/transcription/index.js.map +1 -1
  322. package/dist/webinar/collection.d.ts +16 -0
  323. package/dist/webinar/collection.js +43 -0
  324. package/dist/webinar/collection.js.map +1 -0
  325. package/dist/webinar/index.d.ts +5 -0
  326. package/dist/webinar/index.js +68 -0
  327. package/dist/webinar/index.js.map +1 -0
  328. package/package.json +38 -26
  329. package/src/annotation/annotation.types.ts +50 -0
  330. package/src/annotation/constants.ts +36 -0
  331. package/src/annotation/index.ts +328 -0
  332. package/src/breakouts/README.md +220 -0
  333. package/src/breakouts/breakout.ts +188 -0
  334. package/src/breakouts/collection.ts +19 -0
  335. package/src/breakouts/edit-lock-error.ts +25 -0
  336. package/src/breakouts/events.ts +56 -0
  337. package/src/breakouts/index.ts +925 -0
  338. package/src/breakouts/request.ts +55 -0
  339. package/src/breakouts/utils.ts +57 -0
  340. package/src/common/errors/no-meeting-info.ts +24 -0
  341. package/src/common/errors/webex-errors.ts +36 -12
  342. package/src/common/logs/logger-proxy.ts +1 -1
  343. package/src/common/logs/request.ts +5 -1
  344. package/src/common/queue.ts +22 -8
  345. package/src/config.ts +6 -7
  346. package/src/constants.ts +244 -97
  347. package/src/controls-options-manager/enums.ts +12 -0
  348. package/src/controls-options-manager/index.ts +116 -21
  349. package/src/controls-options-manager/types.ts +59 -0
  350. package/src/controls-options-manager/util.ts +294 -14
  351. package/src/index.ts +44 -0
  352. package/src/interceptors/index.ts +3 -0
  353. package/src/interceptors/locusRetry.ts +67 -0
  354. package/src/interpretation/README.md +60 -0
  355. package/src/interpretation/collection.ts +19 -0
  356. package/src/interpretation/index.ts +332 -0
  357. package/src/interpretation/siLanguage.ts +18 -0
  358. package/src/locus-info/controlsUtils.ts +110 -0
  359. package/src/locus-info/index.ts +449 -61
  360. package/src/locus-info/infoUtils.ts +14 -2
  361. package/src/locus-info/mediaSharesUtils.ts +64 -0
  362. package/src/locus-info/parser.ts +258 -47
  363. package/src/locus-info/selfUtils.ts +85 -2
  364. package/src/media/index.ts +153 -370
  365. package/src/media/properties.ts +106 -136
  366. package/src/media/util.ts +0 -21
  367. package/src/mediaQualityMetrics/config.ts +244 -377
  368. package/src/meeting/in-meeting-actions.ts +176 -0
  369. package/src/meeting/index.ts +3944 -2489
  370. package/src/meeting/locusMediaRequest.ts +313 -0
  371. package/src/meeting/muteState.ts +224 -138
  372. package/src/meeting/request.ts +207 -127
  373. package/src/meeting/request.type.ts +13 -0
  374. package/src/meeting/util.ts +590 -423
  375. package/src/meeting-info/index.ts +81 -8
  376. package/src/meeting-info/meeting-info-v2.ts +163 -13
  377. package/src/meeting-info/util.ts +1 -1
  378. package/src/meeting-info/utilv2.ts +28 -28
  379. package/src/meetings/collection.ts +33 -0
  380. package/src/meetings/index.ts +487 -126
  381. package/src/meetings/meetings.types.ts +12 -0
  382. package/src/meetings/request.ts +2 -0
  383. package/src/meetings/util.ts +116 -5
  384. package/src/member/index.ts +43 -1
  385. package/src/member/types.ts +38 -0
  386. package/src/member/util.ts +125 -28
  387. package/src/members/collection.ts +8 -0
  388. package/src/members/index.ts +187 -52
  389. package/src/members/request.ts +87 -27
  390. package/src/members/util.ts +332 -291
  391. package/src/metrics/constants.ts +15 -6
  392. package/src/metrics/index.ts +1 -471
  393. package/src/multistream/mediaRequestManager.ts +440 -0
  394. package/src/multistream/receiveSlot.ts +184 -0
  395. package/src/multistream/receiveSlotManager.ts +166 -0
  396. package/src/multistream/remoteMedia.ts +254 -0
  397. package/src/multistream/remoteMediaGroup.ts +284 -0
  398. package/src/multistream/remoteMediaManager.ts +1145 -0
  399. package/src/multistream/sendSlotManager.ts +170 -0
  400. package/src/networkQualityMonitor/index.ts +6 -6
  401. package/src/reachability/clusterReachability.ts +320 -0
  402. package/src/reachability/index.ts +243 -347
  403. package/src/reachability/request.ts +17 -8
  404. package/src/reachability/util.ts +24 -0
  405. package/src/reactions/constants.ts +4 -0
  406. package/src/reactions/reactions.ts +4 -4
  407. package/src/reactions/reactions.type.ts +30 -4
  408. package/src/reconnection-manager/index.ts +168 -156
  409. package/src/recording-controller/index.ts +20 -3
  410. package/src/recording-controller/util.ts +26 -9
  411. package/src/roap/index.ts +98 -241
  412. package/src/roap/request.ts +74 -148
  413. package/src/roap/turnDiscovery.ts +62 -56
  414. package/src/rtcMetrics/constants.ts +3 -0
  415. package/src/rtcMetrics/index.ts +124 -0
  416. package/src/statsAnalyzer/global.ts +1 -84
  417. package/src/statsAnalyzer/index.ts +477 -643
  418. package/src/statsAnalyzer/mqaUtil.ts +115 -114
  419. package/src/webinar/collection.ts +31 -0
  420. package/src/webinar/index.ts +62 -0
  421. package/test/integration/spec/converged-space-meetings.js +233 -0
  422. package/test/integration/spec/journey.js +320 -264
  423. package/test/integration/spec/space-meeting.js +77 -4
  424. package/test/unit/spec/annotation/index.ts +418 -0
  425. package/test/unit/spec/breakouts/breakout.ts +237 -0
  426. package/test/unit/spec/breakouts/collection.ts +15 -0
  427. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  428. package/test/unit/spec/breakouts/events.ts +89 -0
  429. package/test/unit/spec/breakouts/index.ts +1790 -0
  430. package/test/unit/spec/breakouts/request.ts +104 -0
  431. package/test/unit/spec/breakouts/utils.js +72 -0
  432. package/test/unit/spec/common/queue.js +31 -2
  433. package/test/unit/spec/controls-options-manager/index.js +163 -0
  434. package/test/unit/spec/controls-options-manager/util.js +576 -60
  435. package/test/unit/spec/fixture/locus.js +1 -0
  436. package/test/unit/spec/interceptors/locusRetry.ts +131 -0
  437. package/test/unit/spec/interpretation/collection.ts +15 -0
  438. package/test/unit/spec/interpretation/index.ts +589 -0
  439. package/test/unit/spec/interpretation/siLanguage.ts +28 -0
  440. package/test/unit/spec/locus-info/controlsUtils.js +323 -30
  441. package/test/unit/spec/locus-info/index.js +1390 -16
  442. package/test/unit/spec/locus-info/infoUtils.js +54 -16
  443. package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
  444. package/test/unit/spec/locus-info/lib/selfConstant.js +48 -0
  445. package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
  446. package/test/unit/spec/locus-info/parser.js +116 -35
  447. package/test/unit/spec/locus-info/selfUtils.js +275 -0
  448. package/test/unit/spec/media/index.ts +290 -0
  449. package/test/unit/spec/media/properties.ts +75 -84
  450. package/test/unit/spec/meeting/in-meeting-actions.ts +86 -0
  451. package/test/unit/spec/meeting/index.js +8187 -2769
  452. package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
  453. package/test/unit/spec/meeting/muteState.js +409 -213
  454. package/test/unit/spec/meeting/request.js +512 -42
  455. package/test/unit/spec/meeting/utils.js +741 -24
  456. package/test/unit/spec/meeting-info/index.js +300 -0
  457. package/test/unit/spec/meeting-info/meetinginfov2.js +527 -5
  458. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  459. package/test/unit/spec/meetings/collection.js +26 -0
  460. package/test/unit/spec/meetings/index.js +1313 -243
  461. package/test/unit/spec/meetings/utils.js +202 -2
  462. package/test/unit/spec/member/index.js +32 -9
  463. package/test/unit/spec/member/util.js +499 -61
  464. package/test/unit/spec/members/index.js +394 -5
  465. package/test/unit/spec/members/request.js +206 -27
  466. package/test/unit/spec/members/utils.js +173 -38
  467. package/test/unit/spec/metrics/index.js +1 -50
  468. package/test/unit/spec/multistream/mediaRequestManager.ts +1418 -0
  469. package/test/unit/spec/multistream/receiveSlot.ts +163 -0
  470. package/test/unit/spec/multistream/receiveSlotManager.ts +203 -0
  471. package/test/unit/spec/multistream/remoteMedia.ts +255 -0
  472. package/test/unit/spec/multistream/remoteMediaGroup.ts +662 -0
  473. package/test/unit/spec/multistream/remoteMediaManager.ts +1924 -0
  474. package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
  475. package/test/unit/spec/networkQualityMonitor/index.js +4 -4
  476. package/test/unit/spec/reachability/clusterReachability.ts +279 -0
  477. package/test/unit/spec/reachability/index.ts +531 -24
  478. package/test/unit/spec/reachability/request.js +68 -0
  479. package/test/unit/spec/reachability/util.ts +40 -0
  480. package/test/unit/spec/reconnection-manager/index.js +162 -24
  481. package/test/unit/spec/recording-controller/index.js +293 -218
  482. package/test/unit/spec/recording-controller/util.js +223 -96
  483. package/test/unit/spec/roap/index.ts +200 -76
  484. package/test/unit/spec/roap/request.ts +255 -0
  485. package/test/unit/spec/roap/turnDiscovery.ts +86 -48
  486. package/test/unit/spec/rtcMetrics/index.ts +93 -0
  487. package/test/unit/spec/stats-analyzer/index.js +261 -167
  488. package/test/unit/spec/webinar/collection.ts +13 -0
  489. package/test/unit/spec/webinar/index.ts +60 -0
  490. package/test/utils/constants.js +9 -0
  491. package/test/utils/integrationTestUtils.js +46 -0
  492. package/test/utils/testUtils.js +0 -45
  493. package/test/utils/webex-config.js +4 -0
  494. package/test/utils/webex-test-users.js +7 -3
  495. package/dist/common/errors/reclaim-host-role-error.js.map +0 -1
  496. package/dist/meeting/effectsState.d.ts +0 -42
  497. package/dist/meeting/effectsState.js +0 -260
  498. package/dist/meeting/effectsState.js.map +0 -1
  499. package/dist/metrics/config.d.ts +0 -169
  500. package/dist/metrics/config.js +0 -289
  501. package/dist/metrics/config.js.map +0 -1
  502. package/dist/peer-connection-manager/index.d.ts +0 -6
  503. package/dist/peer-connection-manager/index.js +0 -671
  504. package/dist/peer-connection-manager/index.js.map +0 -1
  505. package/dist/peer-connection-manager/util.d.ts +0 -6
  506. package/dist/peer-connection-manager/util.js +0 -110
  507. package/dist/peer-connection-manager/util.js.map +0 -1
  508. package/dist/roap/collection.d.ts +0 -10
  509. package/dist/roap/collection.js +0 -63
  510. package/dist/roap/collection.js.map +0 -1
  511. package/dist/roap/handler.d.ts +0 -47
  512. package/dist/roap/handler.js +0 -279
  513. package/dist/roap/handler.js.map +0 -1
  514. package/dist/roap/state.d.ts +0 -9
  515. package/dist/roap/state.js +0 -127
  516. package/dist/roap/state.js.map +0 -1
  517. package/dist/roap/util.d.ts +0 -2
  518. package/dist/roap/util.js +0 -76
  519. package/dist/roap/util.js.map +0 -1
  520. package/src/index.js +0 -15
  521. package/src/meeting/effectsState.ts +0 -209
  522. package/src/metrics/config.ts +0 -485
  523. package/src/peer-connection-manager/index.ts +0 -847
  524. package/src/peer-connection-manager/util.ts +0 -119
  525. package/src/roap/collection.ts +0 -62
  526. package/src/roap/handler.ts +0 -294
  527. package/src/roap/state.ts +0 -156
  528. package/src/roap/util.ts +0 -100
  529. package/test/unit/spec/meeting/effectsState.js +0 -281
  530. package/test/unit/spec/peerconnection-manager/index.js +0 -218
  531. package/test/unit/spec/peerconnection-manager/utils.js +0 -49
  532. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -388
  533. package/test/unit/spec/roap/util.js +0 -30
  534. /package/dist/common/errors/{reclaim-host-role-error.d.ts → reclaim-host-role-errors.d.ts} +0 -0
  535. /package/src/common/errors/{reclaim-host-role-error.ts → reclaim-host-role-errors.ts} +0 -0
@@ -1,50 +1,520 @@
1
1
  import {assert} from '@webex/test-helper-chai';
2
-
3
2
  import MemberUtil from '@webex/plugin-meetings/src/member/util';
3
+ import {ServerRoles} from '../../../../src/member/types';
4
+ import {_SEND_RECEIVE_, _RECEIVE_ONLY_} from '../../../../src/constants';
4
5
 
5
- describe('isHandRaised', () => {
6
- it('throws error when there is no participant', () => {
7
- assert.throws(() => {
8
- MemberUtil.isHandRaised();
9
- }, 'Raise hand could not be processed, participant is undefined.');
6
+ describe('plugin-meetings', () => {
7
+ describe('isHandRaised', () => {
8
+ it('throws error when there is no participant', () => {
9
+ assert.throws(() => {
10
+ MemberUtil.isHandRaised();
11
+ }, 'Raise hand could not be processed, participant is undefined.');
12
+ });
13
+
14
+ it('returns false when controls is not there', () => {
15
+ const participant = {};
16
+
17
+ assert.isFalse(MemberUtil.isHandRaised(participant));
18
+ });
19
+
20
+ it('returns false when hand is not there in controls', () => {
21
+ const participant = {
22
+ controls: {},
23
+ };
24
+
25
+ assert.isFalse(MemberUtil.isHandRaised(participant));
26
+ });
27
+
28
+ it('returns true when hand raised is true', () => {
29
+ const participant = {
30
+ controls: {
31
+ hand: {
32
+ raised: true,
33
+ },
34
+ },
35
+ };
36
+
37
+ assert.isTrue(MemberUtil.isHandRaised(participant));
38
+ });
39
+
40
+ it('returns false when hand raised is false', () => {
41
+ const participant = {
42
+ controls: {
43
+ hand: {
44
+ raised: false,
45
+ },
46
+ },
47
+ };
48
+
49
+ assert.isFalse(MemberUtil.isHandRaised(participant));
50
+ });
10
51
  });
11
52
 
12
- it('returns false when controls is not there', () => {
13
- const participant = {};
53
+ describe('MemberUtil.canReclaimHost', () => {
54
+ it('throws error when there is no participant', () => {
55
+ assert.throws(() => {
56
+ MemberUtil.canReclaimHost();
57
+ }, 'canReclaimHostRole could not be processed, participant is undefined.');
58
+ });
59
+
60
+ it('returns true when canReclaimHostRole is true', () => {
61
+ const participant = {
62
+ canReclaimHostRole: true,
63
+ };
64
+
65
+ assert.isTrue(MemberUtil.canReclaimHost(participant));
66
+ });
14
67
 
15
- assert.isFalse(MemberUtil.isHandRaised(participant));
68
+ it('returns false when canReclaimHostRole is false', () => {
69
+ const participant = {
70
+ canReclaimHostRole: false,
71
+ };
72
+
73
+ assert.isFalse(MemberUtil.canReclaimHost(participant));
74
+ });
75
+
76
+ it('returns false when canReclaimHostRole is falsy', () => {
77
+ const participant = {
78
+ canReclaimHostRole: undefined,
79
+ };
80
+
81
+ assert.isFalse(MemberUtil.canReclaimHost(participant));
82
+ });
16
83
  });
17
84
 
18
- it('returns false when hand is not there in controls', () => {
19
- const participant = {
20
- controls: {},
21
- };
85
+ describe('MemberUtil.extractControlRoles', () => {
86
+ it('happy path extract control roles', () => {
87
+ const participant = {
88
+ controls: {
89
+ role: {
90
+ roles: [
91
+ {type: 'PRESENTER', hasRole: true},
92
+ {type: 'COHOST', hasRole: true},
93
+ {type: 'MODERATOR', hasRole: true},
94
+ ],
95
+ },
96
+ },
97
+ };
22
98
 
23
- assert.isFalse(MemberUtil.isHandRaised(participant));
99
+ assert.deepEqual(MemberUtil.extractControlRoles(participant), {
100
+ cohost: true,
101
+ moderator: true,
102
+ presenter: true,
103
+ });
104
+ });
24
105
  });
25
106
 
26
- it('returns true when hand raised is true', () => {
27
- const participant = {
28
- controls: {
29
- hand: {
30
- raised: true,
107
+ describe('MemberUtil.getControlsRoles', () => {
108
+ it('getControlsRoles', () => {
109
+ const participant = {
110
+ controls: {
111
+ role: {
112
+ roles: [{type: 'PRESENTER', hasRole: true}],
113
+ },
31
114
  },
32
- },
115
+ };
116
+
117
+ assert.deepEqual(MemberUtil.getControlsRoles(participant), [
118
+ {type: 'PRESENTER', hasRole: true},
119
+ ]);
120
+ });
121
+ });
122
+
123
+ describe('MemberUtil.hasRole', () => {
124
+ describe('PRESENTER', () => {
125
+ it('getControlsRoles PRESENTER true', () => {
126
+ const participant = {
127
+ controls: {
128
+ role: {
129
+ roles: [{type: 'PRESENTER', hasRole: true}],
130
+ },
131
+ },
132
+ };
133
+
134
+ assert.isTrue(MemberUtil.hasRole(participant, ServerRoles.Presenter));
135
+ });
136
+
137
+ it('getControlsRoles PRESENTER false', () => {
138
+ const participant = {
139
+ controls: {
140
+ role: {
141
+ roles: [{type: 'PRESENTER', hasRole: false}],
142
+ },
143
+ },
144
+ };
145
+
146
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Presenter));
147
+ });
148
+
149
+ it('getControlsRoles PRESENTER undefined', () => {
150
+ const participant = {
151
+ controls: {
152
+ role: {
153
+ roles: [{}],
154
+ },
155
+ },
156
+ };
157
+
158
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Presenter));
159
+ });
160
+ });
161
+
162
+ describe('MODERATOR', () => {
163
+ it('getControlsRoles MODERATOR true', () => {
164
+ const participant = {
165
+ controls: {
166
+ role: {
167
+ roles: [{type: 'MODERATOR', hasRole: true}],
168
+ },
169
+ },
170
+ };
171
+
172
+ assert.isTrue(MemberUtil.hasRole(participant, ServerRoles.Moderator));
173
+ });
174
+
175
+ it('getControlsRoles MODERATOR false', () => {
176
+ const participant = {
177
+ controls: {
178
+ role: {
179
+ roles: [{type: 'MODERATOR', hasRole: false}],
180
+ },
181
+ },
182
+ };
183
+
184
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Moderator));
185
+ });
186
+
187
+ it('getControlsRoles MODERATOR undefined', () => {
188
+ const participant = {
189
+ controls: {
190
+ role: {
191
+ roles: [{}],
192
+ },
193
+ },
194
+ };
195
+
196
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Moderator));
197
+ });
198
+ });
199
+
200
+ describe('COHOST', () => {
201
+ it('getControlsRoles COHOST true', () => {
202
+ const participant = {
203
+ controls: {
204
+ role: {
205
+ roles: [{type: 'COHOST', hasRole: true}],
206
+ },
207
+ },
208
+ };
209
+
210
+ assert.isTrue(MemberUtil.hasRole(participant, ServerRoles.Cohost));
211
+ });
212
+
213
+ it('getControlsRoles COHOST false', () => {
214
+ const participant = {
215
+ controls: {
216
+ role: {
217
+ roles: [{type: 'COHOST', hasRole: false}],
218
+ },
219
+ },
220
+ };
221
+
222
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Cohost));
223
+ });
224
+
225
+ it('getControlsRoles COHOST undefined', () => {
226
+ const participant = {
227
+ controls: {
228
+ role: {
229
+ roles: [{}],
230
+ },
231
+ },
232
+ };
233
+
234
+ assert.isFalse(MemberUtil.hasRole(participant, ServerRoles.Cohost));
235
+ });
236
+ });
237
+ });
238
+
239
+ describe('MemberUtil.is<Role>', () => {
240
+ describe('PRESENTER', () => {
241
+ it('getControlsRoles PRESENTER true', () => {
242
+ const participant = {
243
+ controls: {
244
+ role: {
245
+ roles: [{type: 'PRESENTER', hasRole: true}],
246
+ },
247
+ },
248
+ };
249
+
250
+ assert.isTrue(MemberUtil.hasPresenter(participant, ServerRoles.Presenter));
251
+ });
252
+
253
+ it('getControlsRoles PRESENTER false', () => {
254
+ const participant = {
255
+ controls: {
256
+ role: {
257
+ roles: [{type: 'PRESENTER', hasRole: false}],
258
+ },
259
+ },
260
+ };
261
+
262
+ assert.isFalse(MemberUtil.hasPresenter(participant));
263
+ });
264
+
265
+ it('getControlsRoles PRESENTER undefined', () => {
266
+ const participant = {
267
+ controls: {
268
+ role: {
269
+ roles: [{}],
270
+ },
271
+ },
272
+ };
273
+
274
+ assert.isFalse(MemberUtil.hasPresenter(participant));
275
+ });
276
+ });
277
+
278
+ describe('MODERATOR', () => {
279
+ it('getControlsRoles MODERATOR true', () => {
280
+ const participant = {
281
+ controls: {
282
+ role: {
283
+ roles: [{type: 'MODERATOR', hasRole: true}],
284
+ },
285
+ },
286
+ };
287
+
288
+ assert.isTrue(MemberUtil.hasModerator(participant));
289
+ });
290
+
291
+ it('getControlsRoles MODERATOR false', () => {
292
+ const participant = {
293
+ controls: {
294
+ role: {
295
+ roles: [{type: 'MODERATOR', hasRole: false}],
296
+ },
297
+ },
298
+ };
299
+
300
+ assert.isFalse(MemberUtil.hasModerator(participant));
301
+ });
302
+
303
+ it('getControlsRoles MODERATOR undefined', () => {
304
+ const participant = {
305
+ controls: {
306
+ role: {
307
+ roles: [{}],
308
+ },
309
+ },
310
+ };
311
+
312
+ assert.isFalse(MemberUtil.hasModerator(participant));
313
+ });
314
+ });
315
+
316
+ describe('COHOST', () => {
317
+ it('getControlsRoles COHOST true', () => {
318
+ const participant = {
319
+ controls: {
320
+ role: {
321
+ roles: [{type: 'COHOST', hasRole: true}],
322
+ },
323
+ },
324
+ };
325
+
326
+ assert.isTrue(MemberUtil.hasCohost(participant));
327
+ });
328
+
329
+ it('getControlsRoles COHOST false', () => {
330
+ const participant = {
331
+ controls: {
332
+ role: {
333
+ roles: [{type: 'COHOST', hasRole: false}],
334
+ },
335
+ },
336
+ };
337
+
338
+ assert.isFalse(MemberUtil.hasCohost(participant));
339
+ });
340
+
341
+ it('getControlsRoles COHOST undefined', () => {
342
+ const participant = {
343
+ controls: {
344
+ role: {
345
+ roles: [{}],
346
+ },
347
+ },
348
+ };
349
+
350
+ assert.isFalse(MemberUtil.hasCohost(participant));
351
+ });
352
+ });
353
+ });
354
+
355
+ describe('MemberUtil.isBreakoutsSupported', () => {
356
+ it('throws error when there is no participant', () => {
357
+ assert.throws(() => {
358
+ MemberUtil.isBreakoutsSupported();
359
+ }, 'Breakout support could not be processed, participant is undefined.');
360
+ });
361
+
362
+ it('returns true when hand breakouts are supported', () => {
363
+ const participant = {
364
+ doesNotSupportBreakouts: false,
365
+ };
366
+
367
+ assert.isTrue(MemberUtil.isBreakoutsSupported(participant));
368
+ });
369
+
370
+ it('returns false when hand breakouts are not supported', () => {
371
+ const participant = {
372
+ doesNotSupportBreakouts: true,
373
+ };
374
+
375
+ assert.isFalse(MemberUtil.isBreakoutsSupported(participant));
376
+ });
377
+ });
378
+
379
+ describe('MemberUtil.isLiveAnnotationSupported', () => {
380
+ it('throws error when there is no participant', () => {
381
+ assert.throws(() => {
382
+ MemberUtil.isLiveAnnotationSupported();
383
+ }, 'LiveAnnotation support could not be processed, participant is undefined.');
384
+ });
385
+
386
+ it('returns true when hand live annotation are supported', () => {
387
+ const participant = {
388
+ annotatorAssignmentNotAllowed: false,
389
+ };
390
+
391
+ assert.isTrue(MemberUtil.isLiveAnnotationSupported(participant));
392
+ });
393
+
394
+ it('returns false when hand live annotation are not supported', () => {
395
+ const participant = {
396
+ annotatorAssignmentNotAllowed: true,
397
+ };
398
+
399
+ assert.isFalse(MemberUtil.isLiveAnnotationSupported(participant));
400
+ });
401
+ });
402
+
403
+ describe('MemberUtil.isInterpretationSupported', () => {
404
+ it('throws error when there is no participant', () => {
405
+ assert.throws(() => {
406
+ MemberUtil.isInterpretationSupported();
407
+ }, 'Interpretation support could not be processed, participant is undefined.');
408
+ });
409
+
410
+ it('returns true when hand SiInterpreter are supported', () => {
411
+ const participant = {
412
+ doesNotSupportSiInterpreter: false,
413
+ };
414
+
415
+ assert.isTrue(MemberUtil.isInterpretationSupported(participant));
416
+ });
417
+
418
+ it('returns false when hand SiInterpreter are not supported', () => {
419
+ const participant = {
420
+ doesNotSupportSiInterpreter: true,
421
+ };
422
+
423
+ assert.isFalse(MemberUtil.isInterpretationSupported(participant));
424
+ });
425
+ });
426
+
427
+ const getMuteStatus = (muted) => {
428
+ if (muted === undefined) {
429
+ return undefined;
430
+ }
431
+ return muted ? _RECEIVE_ONLY_ : _SEND_RECEIVE_;
432
+ };
433
+
434
+ describe('MemberUtil.isAudioMuted', () => {
435
+ it('throws error when there is no participant', () => {
436
+ assert.throws(() => {
437
+ MemberUtil.isAudioMuted();
438
+ }, 'Audio could not be processed, participant is undefined.');
439
+ });
440
+
441
+ // NOTE: participant.controls.audio.muted represents remote video mute
442
+ // participant.status.audioStatus represents local video mute
443
+
444
+ const testResult = (remoteMuted, localMuted, expected) => {
445
+ const participant = {
446
+ controls: {audio: {muted: remoteMuted}},
447
+ status: {audioStatus: getMuteStatus(localMuted)},
448
+ };
449
+
450
+ assert.equal(MemberUtil.isAudioMuted(participant), expected);
33
451
  };
34
452
 
35
- assert.isTrue(MemberUtil.isHandRaised(participant));
453
+ it('returns true when remote is muted and local is not', () => {
454
+ testResult(true, false, true);
455
+ });
456
+
457
+ it('returns true when remote is not muted and local is muted', () => {
458
+ testResult(false, true, true);
459
+ });
460
+
461
+ it('returns false when both are not muted', () => {
462
+ testResult(false, false, false);
463
+ });
464
+
465
+ it('returns undefined when both are undefined', () => {
466
+ testResult(undefined, undefined, undefined);
467
+ });
468
+
469
+ it('returns defined status when the other is undefined', () => {
470
+ testResult(undefined, true, true);
471
+ testResult(undefined, false, false);
472
+ testResult(true, undefined, true);
473
+ testResult(false, undefined, false);
474
+ });
36
475
  });
37
476
 
38
- it('returns false when hand raised is false', () => {
39
- const participant = {
40
- controls: {
41
- hand: {
42
- raised: false,
43
- },
44
- },
477
+ describe('MemberUtil.isVideoMuted', () => {
478
+ it('throws error when there is no participant', () => {
479
+ assert.throws(() => {
480
+ MemberUtil.isVideoMuted();
481
+ }, 'Video could not be processed, participant is undefined.');
482
+ });
483
+
484
+ // NOTE: participant.controls.video.muted represents remote video mute
485
+ // participant.status.videoStatus represents local video mute
486
+
487
+ const testResult = (remoteMuted, localMuted, expected) => {
488
+ const participant = {
489
+ controls: {video: {muted: remoteMuted}},
490
+ status: {videoStatus: getMuteStatus(localMuted)},
491
+ };
492
+
493
+ assert.equal(MemberUtil.isVideoMuted(participant), expected);
45
494
  };
46
495
 
47
- assert.isFalse(MemberUtil.isHandRaised(participant));
496
+ it('returns true when remote is muted and local is not', () => {
497
+ testResult(true, false, true);
498
+ });
499
+
500
+ it('returns true when remote is not muted and local is muted', () => {
501
+ testResult(false, true, true);
502
+ });
503
+
504
+ it('returns false when both are not muted', () => {
505
+ testResult(false, false, false);
506
+ });
507
+
508
+ it('returns undefined when both are undefined', () => {
509
+ testResult(undefined, undefined, undefined);
510
+ });
511
+
512
+ it('returns defined status when the other is undefined', () => {
513
+ testResult(undefined, true, true);
514
+ testResult(undefined, false, false);
515
+ testResult(true, undefined, true);
516
+ testResult(false, undefined, false);
517
+ });
48
518
  });
49
519
  });
50
520
 
@@ -78,35 +548,3 @@ describe('extractMediaStatus', () => {
78
548
  assert.deepEqual(mediaStatus, {audio: 'RECVONLY', video: 'SENDRECV'});
79
549
  });
80
550
  });
81
-
82
- describe('MemberUtil.canReclaimHost', () => {
83
- it('throws error when there is no participant', () => {
84
- assert.throws(() => {
85
- MemberUtil.canReclaimHost();
86
- }, 'canReclaimHostRole could not be processed, participant is undefined.');
87
- });
88
-
89
- it('returns true when canReclaimHostRole is true', () => {
90
- const participant = {
91
- canReclaimHostRole: true,
92
- };
93
-
94
- assert.isTrue(MemberUtil.canReclaimHost(participant));
95
- });
96
-
97
- it('returns false when canReclaimHostRole is false', () => {
98
- const participant = {
99
- canReclaimHostRole: false,
100
- };
101
-
102
- assert.isFalse(MemberUtil.canReclaimHost(participant));
103
- });
104
-
105
- it('returns false when canReclaimHostRole is falsy', () => {
106
- const participant = {
107
- canReclaimHostRole: undefined,
108
- };
109
-
110
- assert.isFalse(MemberUtil.canReclaimHost(participant));
111
- });
112
- });