@webex/plugin-meetings 3.0.0-beta.16 → 3.0.0-beta.161

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 (424) hide show
  1. package/README.md +45 -1
  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 +359 -0
  7. package/dist/annotation/index.js.map +1 -0
  8. package/dist/breakouts/breakout.js +212 -0
  9. package/dist/breakouts/breakout.js.map +1 -0
  10. package/dist/breakouts/collection.js +23 -0
  11. package/dist/breakouts/collection.js.map +1 -0
  12. package/dist/breakouts/edit-lock-error.js +52 -0
  13. package/dist/breakouts/edit-lock-error.js.map +1 -0
  14. package/dist/breakouts/events.js +43 -0
  15. package/dist/breakouts/events.js.map +1 -0
  16. package/dist/breakouts/index.js +1046 -0
  17. package/dist/breakouts/index.js.map +1 -0
  18. package/dist/breakouts/request.js +78 -0
  19. package/dist/breakouts/request.js.map +1 -0
  20. package/dist/breakouts/utils.js +67 -0
  21. package/dist/breakouts/utils.js.map +1 -0
  22. package/dist/common/errors/webex-errors.js +3 -2
  23. package/dist/common/errors/webex-errors.js.map +1 -1
  24. package/dist/common/logs/logger-proxy.js +1 -1
  25. package/dist/common/logs/logger-proxy.js.map +1 -1
  26. package/dist/config.js +6 -8
  27. package/dist/config.js.map +1 -1
  28. package/dist/constants.js +175 -26
  29. package/dist/constants.js.map +1 -1
  30. package/dist/controls-options-manager/constants.js +14 -0
  31. package/dist/controls-options-manager/constants.js.map +1 -0
  32. package/dist/controls-options-manager/enums.js +27 -0
  33. package/dist/controls-options-manager/enums.js.map +1 -0
  34. package/dist/controls-options-manager/index.js +297 -0
  35. package/dist/controls-options-manager/index.js.map +1 -0
  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 +300 -0
  39. package/dist/controls-options-manager/util.js.map +1 -0
  40. package/dist/index.js +77 -0
  41. package/dist/index.js.map +1 -1
  42. package/dist/interpretation/collection.js +23 -0
  43. package/dist/interpretation/collection.js.map +1 -0
  44. package/dist/interpretation/index.js +214 -0
  45. package/dist/interpretation/index.js.map +1 -0
  46. package/dist/interpretation/siLanguage.js +25 -0
  47. package/dist/interpretation/siLanguage.js.map +1 -0
  48. package/dist/locus-info/controlsUtils.js +92 -2
  49. package/dist/locus-info/controlsUtils.js.map +1 -1
  50. package/dist/locus-info/index.js +317 -24
  51. package/dist/locus-info/index.js.map +1 -1
  52. package/dist/locus-info/mediaSharesUtils.js +43 -1
  53. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  54. package/dist/locus-info/parser.js +2 -1
  55. package/dist/locus-info/parser.js.map +1 -1
  56. package/dist/locus-info/selfUtils.js +97 -14
  57. package/dist/locus-info/selfUtils.js.map +1 -1
  58. package/dist/media/index.js +39 -134
  59. package/dist/media/index.js.map +1 -1
  60. package/dist/media/properties.js +19 -97
  61. package/dist/media/properties.js.map +1 -1
  62. package/dist/mediaQualityMetrics/config.js +505 -493
  63. package/dist/mediaQualityMetrics/config.js.map +1 -1
  64. package/dist/meeting/in-meeting-actions.js +79 -1
  65. package/dist/meeting/in-meeting-actions.js.map +1 -1
  66. package/dist/meeting/index.js +2349 -2178
  67. package/dist/meeting/index.js.map +1 -1
  68. package/dist/meeting/locusMediaRequest.js +291 -0
  69. package/dist/meeting/locusMediaRequest.js.map +1 -0
  70. package/dist/meeting/muteState.js +229 -124
  71. package/dist/meeting/muteState.js.map +1 -1
  72. package/dist/meeting/request.js +191 -167
  73. package/dist/meeting/request.js.map +1 -1
  74. package/dist/meeting/request.type.js.map +1 -1
  75. package/dist/meeting/util.js +444 -443
  76. package/dist/meeting/util.js.map +1 -1
  77. package/dist/meeting-info/meeting-info-v2.js +157 -49
  78. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  79. package/dist/meeting-info/utilv2.js +20 -5
  80. package/dist/meeting-info/utilv2.js.map +1 -1
  81. package/dist/meetings/collection.js +22 -0
  82. package/dist/meetings/collection.js.map +1 -1
  83. package/dist/meetings/index.js +365 -73
  84. package/dist/meetings/index.js.map +1 -1
  85. package/dist/meetings/meetings.types.js +7 -0
  86. package/dist/meetings/meetings.types.js.map +1 -0
  87. package/dist/meetings/request.js +16 -12
  88. package/dist/meetings/request.js.map +1 -1
  89. package/dist/meetings/util.js +88 -1
  90. package/dist/meetings/util.js.map +1 -1
  91. package/dist/member/index.js +43 -0
  92. package/dist/member/index.js.map +1 -1
  93. package/dist/member/types.js +15 -0
  94. package/dist/member/types.js.map +1 -0
  95. package/dist/member/util.js +97 -3
  96. package/dist/member/util.js.map +1 -1
  97. package/dist/members/collection.js +10 -0
  98. package/dist/members/collection.js.map +1 -1
  99. package/dist/members/index.js +94 -11
  100. package/dist/members/index.js.map +1 -1
  101. package/dist/members/request.js +109 -39
  102. package/dist/members/request.js.map +1 -1
  103. package/dist/members/types.js +15 -0
  104. package/dist/members/types.js.map +1 -0
  105. package/dist/members/util.js +316 -233
  106. package/dist/members/util.js.map +1 -1
  107. package/dist/metrics/config.js +50 -14
  108. package/dist/metrics/config.js.map +1 -1
  109. package/dist/metrics/constants.js +3 -5
  110. package/dist/metrics/constants.js.map +1 -1
  111. package/dist/metrics/index.js +48 -29
  112. package/dist/metrics/index.js.map +1 -1
  113. package/dist/multistream/mediaRequestManager.js +265 -36
  114. package/dist/multistream/mediaRequestManager.js.map +1 -1
  115. package/dist/multistream/receiveSlot.js +52 -19
  116. package/dist/multistream/receiveSlot.js.map +1 -1
  117. package/dist/multistream/receiveSlotManager.js +53 -33
  118. package/dist/multistream/receiveSlotManager.js.map +1 -1
  119. package/dist/multistream/remoteMedia.js +44 -18
  120. package/dist/multistream/remoteMedia.js.map +1 -1
  121. package/dist/multistream/remoteMediaGroup.js +60 -3
  122. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  123. package/dist/multistream/remoteMediaManager.js +322 -103
  124. package/dist/multistream/remoteMediaManager.js.map +1 -1
  125. package/dist/networkQualityMonitor/index.js +4 -2
  126. package/dist/networkQualityMonitor/index.js.map +1 -1
  127. package/dist/reachability/index.js +117 -60
  128. package/dist/reachability/index.js.map +1 -1
  129. package/dist/reachability/request.js +12 -5
  130. package/dist/reachability/request.js.map +1 -1
  131. package/dist/reactions/constants.js +13 -0
  132. package/dist/reactions/constants.js.map +1 -0
  133. package/dist/reactions/reactions.js +2 -2
  134. package/dist/reactions/reactions.js.map +1 -1
  135. package/dist/reactions/reactions.type.js +18 -18
  136. package/dist/reactions/reactions.type.js.map +1 -1
  137. package/dist/reconnection-manager/index.js +190 -145
  138. package/dist/reconnection-manager/index.js.map +1 -1
  139. package/dist/recording-controller/enums.js +17 -0
  140. package/dist/recording-controller/enums.js.map +1 -0
  141. package/dist/recording-controller/index.js +343 -0
  142. package/dist/recording-controller/index.js.map +1 -0
  143. package/dist/recording-controller/util.js +63 -0
  144. package/dist/recording-controller/util.js.map +1 -0
  145. package/dist/roap/index.js +21 -29
  146. package/dist/roap/index.js.map +1 -1
  147. package/dist/roap/request.js +127 -92
  148. package/dist/roap/request.js.map +1 -1
  149. package/dist/roap/turnDiscovery.js +135 -53
  150. package/dist/roap/turnDiscovery.js.map +1 -1
  151. package/dist/statsAnalyzer/global.js +1 -93
  152. package/dist/statsAnalyzer/global.js.map +1 -1
  153. package/dist/statsAnalyzer/index.js +329 -314
  154. package/dist/statsAnalyzer/index.js.map +1 -1
  155. package/dist/statsAnalyzer/mqaUtil.js +103 -54
  156. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  157. package/dist/types/annotation/annotation.types.d.ts +43 -0
  158. package/dist/types/annotation/constants.d.ts +31 -0
  159. package/dist/types/annotation/index.d.ts +124 -0
  160. package/dist/types/breakouts/breakout.d.ts +8 -0
  161. package/dist/types/breakouts/collection.d.ts +5 -0
  162. package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
  163. package/dist/types/breakouts/events.d.ts +2 -0
  164. package/dist/types/breakouts/index.d.ts +5 -0
  165. package/dist/types/breakouts/request.d.ts +22 -0
  166. package/dist/types/breakouts/utils.d.ts +15 -0
  167. package/dist/types/common/browser-detection.d.ts +9 -0
  168. package/dist/types/common/collection.d.ts +48 -0
  169. package/dist/types/common/config.d.ts +2 -0
  170. package/dist/types/common/errors/captcha-error.d.ts +15 -0
  171. package/dist/types/common/errors/intent-to-join.d.ts +16 -0
  172. package/dist/types/common/errors/join-meeting.d.ts +17 -0
  173. package/dist/types/common/errors/media.d.ts +15 -0
  174. package/dist/types/common/errors/parameter.d.ts +15 -0
  175. package/dist/types/common/errors/password-error.d.ts +15 -0
  176. package/dist/types/common/errors/permission.d.ts +14 -0
  177. package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
  178. package/dist/types/common/errors/reconnection.d.ts +15 -0
  179. package/dist/types/common/errors/stats.d.ts +15 -0
  180. package/dist/types/common/errors/webex-errors.d.ts +69 -0
  181. package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
  182. package/dist/types/common/events/events-scope.d.ts +17 -0
  183. package/dist/types/common/events/events.d.ts +12 -0
  184. package/dist/types/common/events/trigger-proxy.d.ts +2 -0
  185. package/dist/types/common/events/util.d.ts +2 -0
  186. package/dist/types/common/logs/logger-config.d.ts +2 -0
  187. package/dist/types/common/logs/logger-proxy.d.ts +2 -0
  188. package/dist/types/common/logs/request.d.ts +34 -0
  189. package/dist/types/common/queue.d.ts +32 -0
  190. package/dist/types/config.d.ts +72 -0
  191. package/dist/types/constants.d.ts +987 -0
  192. package/dist/types/controls-options-manager/constants.d.ts +4 -0
  193. package/dist/types/controls-options-manager/enums.d.ts +15 -0
  194. package/dist/types/controls-options-manager/index.d.ts +136 -0
  195. package/dist/types/controls-options-manager/types.d.ts +43 -0
  196. package/dist/types/controls-options-manager/util.d.ts +1 -0
  197. package/dist/types/index.d.ts +7 -0
  198. package/dist/types/interpretation/collection.d.ts +5 -0
  199. package/dist/types/interpretation/index.d.ts +5 -0
  200. package/dist/types/interpretation/siLanguage.d.ts +5 -0
  201. package/dist/types/locus-info/controlsUtils.d.ts +2 -0
  202. package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
  203. package/dist/types/locus-info/fullState.d.ts +2 -0
  204. package/dist/types/locus-info/hostUtils.d.ts +2 -0
  205. package/dist/types/locus-info/index.d.ts +315 -0
  206. package/dist/types/locus-info/infoUtils.d.ts +2 -0
  207. package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
  208. package/dist/types/locus-info/parser.d.ts +212 -0
  209. package/dist/types/locus-info/selfUtils.d.ts +2 -0
  210. package/dist/types/media/index.d.ts +34 -0
  211. package/dist/types/media/properties.d.ts +86 -0
  212. package/dist/types/media/util.d.ts +2 -0
  213. package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
  214. package/dist/types/meeting/in-meeting-actions.d.ts +149 -0
  215. package/dist/types/meeting/index.d.ts +1524 -0
  216. package/dist/types/meeting/locusMediaRequest.d.ts +70 -0
  217. package/dist/types/meeting/muteState.d.ts +184 -0
  218. package/dist/types/meeting/request.d.ts +270 -0
  219. package/dist/types/meeting/request.type.d.ts +11 -0
  220. package/dist/types/meeting/state.d.ts +9 -0
  221. package/dist/types/meeting/util.d.ts +75 -0
  222. package/dist/types/meeting-info/collection.d.ts +20 -0
  223. package/dist/types/meeting-info/index.d.ts +57 -0
  224. package/dist/types/meeting-info/meeting-info-v2.d.ts +122 -0
  225. package/dist/types/meeting-info/request.d.ts +22 -0
  226. package/dist/types/meeting-info/util.d.ts +2 -0
  227. package/dist/types/meeting-info/utilv2.d.ts +2 -0
  228. package/dist/types/meetings/collection.d.ts +31 -0
  229. package/dist/types/meetings/index.d.ts +364 -0
  230. package/dist/types/meetings/meetings.types.d.ts +4 -0
  231. package/dist/types/meetings/request.d.ts +27 -0
  232. package/dist/types/meetings/util.d.ts +18 -0
  233. package/dist/types/member/index.d.ts +158 -0
  234. package/dist/types/member/types.d.ts +21 -0
  235. package/dist/types/member/util.d.ts +2 -0
  236. package/dist/types/members/collection.d.ts +29 -0
  237. package/dist/types/members/index.d.ts +353 -0
  238. package/dist/types/members/request.d.ts +114 -0
  239. package/dist/types/members/types.d.ts +24 -0
  240. package/dist/types/members/util.d.ts +210 -0
  241. package/dist/types/metrics/config.d.ts +195 -0
  242. package/dist/types/metrics/constants.d.ts +55 -0
  243. package/dist/types/metrics/index.d.ts +169 -0
  244. package/dist/types/multistream/mediaRequestManager.d.ts +118 -0
  245. package/dist/types/multistream/receiveSlot.d.ts +68 -0
  246. package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
  247. package/dist/types/multistream/remoteMedia.d.ts +72 -0
  248. package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
  249. package/dist/types/multistream/remoteMediaManager.d.ts +277 -0
  250. package/dist/types/networkQualityMonitor/index.d.ts +70 -0
  251. package/dist/types/personal-meeting-room/index.d.ts +47 -0
  252. package/dist/types/personal-meeting-room/request.d.ts +14 -0
  253. package/dist/types/personal-meeting-room/util.d.ts +2 -0
  254. package/dist/types/reachability/index.d.ts +152 -0
  255. package/dist/types/reachability/request.d.ts +37 -0
  256. package/dist/types/reactions/constants.d.ts +3 -0
  257. package/dist/types/reactions/reactions.d.ts +4 -0
  258. package/dist/types/reactions/reactions.type.d.ts +52 -0
  259. package/dist/types/reconnection-manager/index.d.ts +126 -0
  260. package/dist/types/recording-controller/enums.d.ts +7 -0
  261. package/dist/types/recording-controller/index.d.ts +193 -0
  262. package/dist/types/recording-controller/util.d.ts +13 -0
  263. package/dist/types/roap/index.d.ts +77 -0
  264. package/dist/types/roap/request.d.ts +36 -0
  265. package/dist/types/roap/turnDiscovery.d.ts +91 -0
  266. package/dist/types/statsAnalyzer/global.d.ts +36 -0
  267. package/dist/types/statsAnalyzer/index.d.ts +200 -0
  268. package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
  269. package/dist/types/transcription/index.d.ts +64 -0
  270. package/package.json +28 -21
  271. package/src/annotation/annotation.types.ts +52 -0
  272. package/src/annotation/constants.ts +36 -0
  273. package/src/annotation/index.ts +343 -0
  274. package/src/breakouts/README.md +220 -0
  275. package/src/breakouts/breakout.ts +180 -0
  276. package/src/breakouts/collection.ts +19 -0
  277. package/src/breakouts/edit-lock-error.ts +25 -0
  278. package/src/breakouts/events.ts +37 -0
  279. package/src/breakouts/index.ts +921 -0
  280. package/src/breakouts/request.ts +55 -0
  281. package/src/breakouts/utils.ts +57 -0
  282. package/src/common/errors/webex-errors.ts +6 -2
  283. package/src/common/logs/logger-proxy.ts +1 -1
  284. package/src/config.ts +5 -7
  285. package/src/constants.ts +165 -20
  286. package/src/controls-options-manager/constants.ts +5 -0
  287. package/src/controls-options-manager/enums.ts +18 -0
  288. package/src/controls-options-manager/index.ts +278 -0
  289. package/src/controls-options-manager/types.ts +59 -0
  290. package/src/controls-options-manager/util.ts +286 -0
  291. package/src/index.ts +34 -0
  292. package/src/interpretation/README.md +51 -0
  293. package/src/interpretation/collection.ts +19 -0
  294. package/src/interpretation/index.ts +182 -0
  295. package/src/interpretation/siLanguage.ts +18 -0
  296. package/src/locus-info/controlsUtils.ts +110 -0
  297. package/src/locus-info/index.ts +339 -21
  298. package/src/locus-info/mediaSharesUtils.ts +48 -0
  299. package/src/locus-info/parser.ts +2 -1
  300. package/src/locus-info/selfUtils.ts +86 -2
  301. package/src/media/index.ts +70 -142
  302. package/src/media/properties.ts +41 -104
  303. package/src/mediaQualityMetrics/config.ts +379 -377
  304. package/src/meeting/in-meeting-actions.ts +156 -0
  305. package/src/meeting/index.ts +1779 -1741
  306. package/src/meeting/locusMediaRequest.ts +309 -0
  307. package/src/meeting/muteState.ts +228 -132
  308. package/src/meeting/request.ts +100 -91
  309. package/src/meeting/request.type.ts +2 -0
  310. package/src/meeting/util.ts +422 -421
  311. package/src/meeting-info/meeting-info-v2.ts +134 -13
  312. package/src/meeting-info/utilv2.ts +13 -3
  313. package/src/meetings/collection.ts +20 -0
  314. package/src/meetings/index.ts +385 -83
  315. package/src/meetings/meetings.types.ts +12 -0
  316. package/src/meetings/request.ts +3 -1
  317. package/src/meetings/util.ts +103 -4
  318. package/src/member/index.ts +42 -0
  319. package/src/member/types.ts +24 -0
  320. package/src/member/util.ts +95 -1
  321. package/src/members/collection.ts +8 -0
  322. package/src/members/index.ts +108 -6
  323. package/src/members/request.ts +98 -17
  324. package/src/members/types.ts +28 -0
  325. package/src/members/util.ts +319 -240
  326. package/src/metrics/config.ts +49 -10
  327. package/src/metrics/constants.ts +2 -4
  328. package/src/metrics/index.ts +43 -27
  329. package/src/multistream/mediaRequestManager.ts +337 -63
  330. package/src/multistream/receiveSlot.ts +68 -26
  331. package/src/multistream/receiveSlotManager.ts +61 -38
  332. package/src/multistream/remoteMedia.ts +29 -3
  333. package/src/multistream/remoteMediaGroup.ts +61 -2
  334. package/src/multistream/remoteMediaManager.ts +260 -66
  335. package/src/networkQualityMonitor/index.ts +6 -6
  336. package/src/reachability/index.ts +75 -25
  337. package/src/reachability/request.ts +10 -5
  338. package/src/reactions/constants.ts +4 -0
  339. package/src/reactions/reactions.ts +4 -4
  340. package/src/reactions/reactions.type.ts +28 -3
  341. package/src/reconnection-manager/index.ts +53 -32
  342. package/src/recording-controller/enums.ts +8 -0
  343. package/src/recording-controller/index.ts +315 -0
  344. package/src/recording-controller/util.ts +58 -0
  345. package/src/roap/index.ts +21 -30
  346. package/src/roap/request.ts +51 -52
  347. package/src/roap/turnDiscovery.ts +51 -27
  348. package/src/statsAnalyzer/global.ts +1 -94
  349. package/src/statsAnalyzer/index.ts +380 -390
  350. package/src/statsAnalyzer/mqaUtil.ts +106 -99
  351. package/test/integration/spec/converged-space-meetings.js +233 -0
  352. package/test/integration/spec/journey.js +331 -254
  353. package/test/integration/spec/space-meeting.js +77 -4
  354. package/test/unit/spec/annotation/index.ts +436 -0
  355. package/test/unit/spec/breakouts/breakout.ts +233 -0
  356. package/test/unit/spec/breakouts/collection.ts +15 -0
  357. package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
  358. package/test/unit/spec/breakouts/events.ts +77 -0
  359. package/test/unit/spec/breakouts/index.ts +1790 -0
  360. package/test/unit/spec/breakouts/request.ts +104 -0
  361. package/test/unit/spec/breakouts/utils.js +72 -0
  362. package/test/unit/spec/controls-options-manager/index.js +287 -0
  363. package/test/unit/spec/controls-options-manager/util.js +518 -0
  364. package/test/unit/spec/fixture/locus.js +1 -0
  365. package/test/unit/spec/interpretation/collection.ts +15 -0
  366. package/test/unit/spec/interpretation/index.ts +329 -0
  367. package/test/unit/spec/interpretation/siLanguage.ts +26 -0
  368. package/test/unit/spec/locus-info/controlsUtils.js +323 -30
  369. package/test/unit/spec/locus-info/index.js +680 -4
  370. package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
  371. package/test/unit/spec/locus-info/selfConstant.js +48 -0
  372. package/test/unit/spec/locus-info/selfUtils.js +275 -0
  373. package/test/unit/spec/media/index.ts +118 -22
  374. package/test/unit/spec/media/properties.ts +9 -9
  375. package/test/unit/spec/meeting/in-meeting-actions.ts +76 -0
  376. package/test/unit/spec/meeting/index.js +2695 -1513
  377. package/test/unit/spec/meeting/locusMediaRequest.ts +436 -0
  378. package/test/unit/spec/meeting/muteState.js +370 -208
  379. package/test/unit/spec/meeting/request.js +354 -42
  380. package/test/unit/spec/meeting/utils.js +270 -156
  381. package/test/unit/spec/meeting-info/meetinginfov2.js +383 -5
  382. package/test/unit/spec/meeting-info/utilv2.js +21 -0
  383. package/test/unit/spec/meetings/collection.js +14 -0
  384. package/test/unit/spec/meetings/index.js +866 -120
  385. package/test/unit/spec/meetings/utils.js +206 -2
  386. package/test/unit/spec/member/index.js +31 -0
  387. package/test/unit/spec/member/util.js +408 -32
  388. package/test/unit/spec/members/index.js +320 -1
  389. package/test/unit/spec/members/request.js +206 -27
  390. package/test/unit/spec/members/utils.js +184 -0
  391. package/test/unit/spec/metrics/index.js +98 -0
  392. package/test/unit/spec/multistream/mediaRequestManager.ts +1012 -109
  393. package/test/unit/spec/multistream/receiveSlot.ts +77 -18
  394. package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
  395. package/test/unit/spec/multistream/remoteMedia.ts +32 -2
  396. package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
  397. package/test/unit/spec/multistream/remoteMediaManager.ts +672 -65
  398. package/test/unit/spec/networkQualityMonitor/index.js +4 -4
  399. package/test/unit/spec/reachability/index.ts +176 -25
  400. package/test/unit/spec/reachability/request.js +66 -0
  401. package/test/unit/spec/reconnection-manager/index.js +46 -13
  402. package/test/unit/spec/recording-controller/index.js +231 -0
  403. package/test/unit/spec/recording-controller/util.js +102 -0
  404. package/test/unit/spec/roap/index.ts +21 -51
  405. package/test/unit/spec/roap/request.ts +187 -0
  406. package/test/unit/spec/roap/turnDiscovery.ts +73 -34
  407. package/test/unit/spec/stats-analyzer/index.js +94 -43
  408. package/test/utils/constants.js +9 -0
  409. package/test/utils/integrationTestUtils.js +46 -0
  410. package/test/utils/testUtils.js +0 -45
  411. package/test/utils/webex-config.js +4 -0
  412. package/test/utils/webex-test-users.js +7 -3
  413. package/tsconfig.json +6 -0
  414. package/dist/media/internal-media-core-wrapper.js +0 -18
  415. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  416. package/dist/meeting/effectsState.js +0 -262
  417. package/dist/meeting/effectsState.js.map +0 -1
  418. package/dist/multistream/multistreamMedia.js +0 -106
  419. package/dist/multistream/multistreamMedia.js.map +0 -1
  420. package/src/index.js +0 -15
  421. package/src/media/internal-media-core-wrapper.ts +0 -9
  422. package/src/meeting/effectsState.ts +0 -211
  423. package/src/multistream/multistreamMedia.ts +0 -93
  424. package/test/unit/spec/meeting/effectsState.js +0 -281
@@ -14,6 +14,9 @@ import ParameterError from '@webex/plugin-meetings/src/common/errors/parameter';
14
14
  import Meetings from '@webex/plugin-meetings';
15
15
  import Members from '@webex/plugin-meetings/src/members';
16
16
  import MembersUtil from '@webex/plugin-meetings/src/members/util';
17
+ import * as MembersRequestImport from '@webex/plugin-meetings/src/members/request';
18
+ import Trigger from '@webex/plugin-meetings/src/common/events/trigger-proxy';
19
+ import {EVENT_TRIGGERS} from '@webex/plugin-meetings/src/constants';
17
20
 
18
21
  const {assert} = chai;
19
22
 
@@ -79,6 +82,8 @@ describe('plugin-meetings', () => {
79
82
  describe('members', () => {
80
83
  const sandbox = sinon.createSandbox();
81
84
  let createMembers;
85
+ let meeting;
86
+ let membersRequestSpy;
82
87
 
83
88
  beforeEach(() => {
84
89
  webex = new MockWebex({
@@ -104,13 +109,31 @@ describe('plugin-meetings', () => {
104
109
 
105
110
  url1 = `https://example.com/${uuid.v4()}`;
106
111
 
107
- createMembers = (options) => new Members({locusUrl: options.url}, {parent: webex});
112
+ membersRequestSpy = sinon.spy(MembersRequestImport, 'default');
113
+
114
+ meeting = {
115
+ request: sinon.mock().returns(Promise.resolve()),
116
+ locusInfo: {
117
+ sequence: {}
118
+ }
119
+ }
120
+
121
+ createMembers = (options) => new Members({locusUrl: options.url, meeting}, {parent: webex});
108
122
  });
109
123
 
110
124
  afterEach(() => {
125
+ membersRequestSpy.restore();
111
126
  sandbox.restore();
112
127
  });
113
128
 
129
+ describe('constructor', () => {
130
+ it('passes the meeting to the MembersRequest', () => {
131
+ createMembers({});
132
+
133
+ assert.calledOnceWithExactly(membersRequestSpy, {meeting}, {parent: webex});
134
+ });
135
+ });
136
+
114
137
  describe('#addMembers', () => {
115
138
  it('should invoke isInvalidInvitee and generateAddMemberOptions from MembersUtil when addMember is called with valid params', async () => {
116
139
  sandbox.spy(MembersUtil, 'isInvalidInvitee');
@@ -130,6 +153,129 @@ describe('plugin-meetings', () => {
130
153
  });
131
154
  });
132
155
 
156
+ describe('#admitMembers', () => {
157
+ let members;
158
+ beforeEach(() => {
159
+ members = createMembers({url: url1});
160
+ members.membersRequest.admitMember = sinon.stub().returns(Promise.resolve(true));
161
+ });
162
+ it('should return error if param memberIds is not provided', async () => {
163
+ let error;
164
+ await members.admitMembers().catch((e) => {
165
+ error = e;
166
+ });
167
+ assert.deepEqual(error, new ParameterError('No member ids provided to admit.'));
168
+ });
169
+
170
+ it('should call membersRequest.admitMember as expected', async () => {
171
+ await members.admitMembers(['uuid']);
172
+ const arg1 = members.membersRequest.admitMember.getCall(0).args[0];
173
+ assert.equal(arg1.sessionLocusUrls, undefined);
174
+ assert.equal(arg1.locusUrl.includes('https://example.com/'), true);
175
+ assert.deepEqual(arg1.memberIds, ['uuid']);
176
+
177
+ const sessionLocusUrls = {
178
+ authorizingLocusUrl: 'authorizingLocusUrl',
179
+ mainLocusUrl: 'mainLocusUrl',
180
+ };
181
+ await members.admitMembers(['uuid'], sessionLocusUrls);
182
+ const arg2 = members.membersRequest.admitMember.getCall(1).args[0];
183
+ assert.equal(arg2.sessionLocusUrls, sessionLocusUrls);
184
+ assert.equal(arg1.locusUrl.includes('https://example.com/'), true);
185
+ assert.deepEqual(arg1.memberIds, ['uuid']);
186
+ });
187
+ });
188
+
189
+ describe('#muteMember', () => {
190
+ const testMuteMember = async (mute, isAudio) => {
191
+ sandbox.spy(MembersUtil, 'generateMuteMemberOptions');
192
+
193
+ const locusUrl = 'locus-url';
194
+ const members = createMembers({url: locusUrl});
195
+ const {membersRequest} = members;
196
+ sandbox.spy(membersRequest, 'muteMember');
197
+
198
+ const memberId = 'bob';
199
+
200
+ await members.muteMember(memberId, mute, isAudio);
201
+ assert.calledOnce(MembersUtil.generateMuteMemberOptions);
202
+ assert.calledWith(
203
+ MembersUtil.generateMuteMemberOptions,
204
+ memberId,
205
+ mute,
206
+ members.locusUrl,
207
+ isAudio
208
+ );
209
+
210
+ assert.calledOnce(membersRequest.muteMember);
211
+ assert.calledWith(membersRequest.muteMember, {memberId, muted: mute, locusUrl, isAudio});
212
+ };
213
+
214
+ it('invokes expected functions when muteMember is called for mute=true, isAudio=true', async () => {
215
+ testMuteMember(true, true);
216
+ });
217
+
218
+ it('invokes expected functions when muteMember is called for mute=true, isAudio=false', async () => {
219
+ testMuteMember(true, false);
220
+ });
221
+
222
+ it('invokes expected functions when muteMember is called for mute=false, isAudio=true', async () => {
223
+ testMuteMember(false, true);
224
+ });
225
+
226
+ it('invokes expected functions when muteMember is called for mute=false, isAudio=false', async () => {
227
+ testMuteMember(false, false);
228
+ });
229
+ });
230
+
231
+ describe('#clearMembers', () => {
232
+ it('should send clear event if clear members', () => {
233
+ const members = createMembers({url: url1});
234
+ members.membersCollection.setAll(fakeMembersCollection);
235
+ Trigger.trigger = sinon.stub();
236
+ members.clearMembers();
237
+ assert.deepEqual(members.membersCollection.members, {});
238
+ assert.calledWith(
239
+ Trigger.trigger,
240
+ members,
241
+ {
242
+ file: 'members',
243
+ function: 'clearMembers',
244
+ },
245
+ EVENT_TRIGGERS.MEMBERS_CLEAR,
246
+ {}
247
+ );
248
+ });
249
+ });
250
+ describe('#locusParticipantsUpdate', () => {
251
+ it('should send member update event with session info', () => {
252
+ const members = createMembers({url: url1});
253
+ Trigger.trigger = sinon.stub();
254
+ const fakePayload = {
255
+ participants: {
256
+ forEach: sinon.stub(),
257
+ },
258
+ isReplace: true,
259
+ };
260
+
261
+ members.locusParticipantsUpdate(fakePayload);
262
+
263
+ assert.calledWith(
264
+ Trigger.trigger,
265
+ members,
266
+ {
267
+ file: 'members',
268
+ function: 'locusParticipantsUpdate',
269
+ },
270
+ EVENT_TRIGGERS.MEMBERS_UPDATE,
271
+ {
272
+ delta: {added: [], updated: []},
273
+ full: {},
274
+ isReplace: true,
275
+ }
276
+ );
277
+ });
278
+ });
133
279
  describe('#sendDialPadKey', () => {
134
280
  it('should throw a rejection when calling sendDialPadKey with no tones', async () => {
135
281
  const members = createMembers({url: url1});
@@ -191,6 +337,97 @@ describe('plugin-meetings', () => {
191
337
  });
192
338
  });
193
339
 
340
+ describe('#assignRoles', () => {
341
+ const setup = (locusUrl) => {
342
+ const members = createMembers({url: locusUrl});
343
+
344
+ const spies = {
345
+ generateRoleAssignmentMemberOptions: sandbox.spy(
346
+ MembersUtil,
347
+ 'generateRoleAssignmentMemberOptions'
348
+ ),
349
+ assignRolesMember: sandbox.spy(members.membersRequest, 'assignRolesMember'),
350
+ };
351
+
352
+ return {members, spies};
353
+ };
354
+
355
+ const checkInvalid = async (resultPromise, expectedMessage, spies) => {
356
+ await assert.isRejected(resultPromise, ParameterError, expectedMessage);
357
+ assert.notCalled(spies.generateRoleAssignmentMemberOptions);
358
+ assert.notCalled(spies.assignRolesMember);
359
+ };
360
+
361
+ const checkValid = async (
362
+ resultPromise,
363
+ spies,
364
+ expectedMemberId,
365
+ expectedRoles,
366
+ expectedLocusUrl
367
+ ) => {
368
+ await assert.isFulfilled(resultPromise);
369
+ assert.calledOnceWithExactly(
370
+ spies.generateRoleAssignmentMemberOptions,
371
+ expectedMemberId,
372
+ expectedRoles,
373
+ expectedLocusUrl
374
+ );
375
+ assert.calledOnceWithExactly(spies.assignRolesMember, {
376
+ memberId: expectedMemberId,
377
+ roles: expectedRoles,
378
+ locusUrl: expectedLocusUrl,
379
+ });
380
+ assert.strictEqual(resultPromise, spies.assignRolesMember.getCall(0).returnValue);
381
+ };
382
+
383
+ it('should not make a request if there is no member id', async () => {
384
+ const {members, spies} = setup(url1);
385
+
386
+ const resultPromise = members.assignRoles();
387
+
388
+ await checkInvalid(
389
+ resultPromise,
390
+ 'The member id must be defined to assign the roles to a member.',
391
+ spies
392
+ );
393
+ });
394
+
395
+ it('should not make a request if there is no locus url', async () => {
396
+ const {members, spies} = setup();
397
+
398
+ const resultPromise = members.assignRoles(uuid.v4());
399
+
400
+ await checkInvalid(
401
+ resultPromise,
402
+ 'The associated locus url for this meetings members object must be defined.',
403
+ spies
404
+ );
405
+ });
406
+
407
+ it('should make the correct request when called with roles', async () => {
408
+ const memberId = uuid.v4();
409
+ const {members, spies} = setup(url1);
410
+
411
+ const resultPromise = members.assignRoles(memberId, [
412
+ {type: 'PRESENTER', hasRole: true},
413
+ {type: 'MODERATOR', hasRole: false},
414
+ {type: 'COHOST', hasRole: true},
415
+ ]);
416
+
417
+ await checkValid(
418
+ resultPromise,
419
+ spies,
420
+ memberId,
421
+ [
422
+ {type: 'PRESENTER', hasRole: true},
423
+ {type: 'MODERATOR', hasRole: false},
424
+ {type: 'COHOST', hasRole: true},
425
+ ],
426
+ url1
427
+ );
428
+ });
429
+ });
430
+
194
431
  describe('#raiseOrLowerHand', () => {
195
432
  const setup = (locusUrl) => {
196
433
  const members = createMembers({url: locusUrl});
@@ -360,6 +597,88 @@ describe('plugin-meetings', () => {
360
597
  });
361
598
  });
362
599
 
600
+ describe('#editDisplayName', () => {
601
+ const setup = (locusUrl) => {
602
+ const members = createMembers({url: locusUrl});
603
+
604
+ const spies = {
605
+ generateEditDisplayNameMemberOptions: sandbox.spy(
606
+ MembersUtil,
607
+ 'generateEditDisplayNameMemberOptions'
608
+ ),
609
+ editDisplayNameMember: sandbox.spy(members.membersRequest, 'editDisplayNameMember'),
610
+ };
611
+
612
+ return {members, spies};
613
+ };
614
+
615
+ const checkInvalid = async (resultPromise, expectedMessage, spies) => {
616
+ await assert.isRejected(resultPromise, ParameterError, expectedMessage);
617
+ assert.notCalled(spies.generateEditDisplayNameMemberOptions);
618
+ assert.notCalled(spies.editDisplayNameMember);
619
+ };
620
+
621
+ const checkValid = async (
622
+ resultPromise,
623
+ spies,
624
+ expectedMemberId,
625
+ expectedRequestingParticipantId,
626
+ expectedAlias,
627
+ expectedLocusUrl
628
+ ) => {
629
+ await assert.isFulfilled(resultPromise);
630
+ assert.calledOnceWithExactly(
631
+ spies.generateEditDisplayNameMemberOptions,
632
+ expectedMemberId,
633
+ expectedRequestingParticipantId,
634
+ expectedAlias,
635
+ expectedLocusUrl
636
+ );
637
+ assert.calledOnceWithExactly(spies.editDisplayNameMember, {
638
+ memberId: expectedMemberId,
639
+ requestingParticipantId: expectedRequestingParticipantId,
640
+ alias: expectedAlias,
641
+ locusUrl: expectedLocusUrl,
642
+ });
643
+ assert.strictEqual(resultPromise, spies.editDisplayNameMember.getCall(0).returnValue);
644
+ };
645
+
646
+ it('should not make a request if there is no memberId', async () => {
647
+ const {members, spies} = setup(url1);
648
+
649
+ const resultPromise = members.editDisplayName();
650
+
651
+ await checkInvalid(
652
+ resultPromise,
653
+ 'The member id must be defined to edit display name of the member.',
654
+ spies
655
+ );
656
+ });
657
+
658
+ it('should not make a request if there is no locus url', async () => {
659
+ const {members, spies} = setup();
660
+
661
+ const resultPromise = members.editDisplayName(uuid.v4());
662
+
663
+ await checkInvalid(
664
+ resultPromise,
665
+ 'The associated locus url for this meetings members object must be defined.',
666
+ spies
667
+ );
668
+ });
669
+
670
+ it('should make the correct request when called with respective parameters', async () => {
671
+ const requestingParticipantId = uuid.v4();
672
+ const memberId = uuid.v4();
673
+ const alias = 'aliasName';
674
+ const {members, spies} = setup(url1);
675
+
676
+ const resultPromise = members.editDisplayName(memberId, requestingParticipantId, alias);
677
+
678
+ await checkValid(resultPromise, spies, memberId, requestingParticipantId, alias, url1);
679
+ });
680
+ });
681
+
363
682
  describe('findMemberByCsi()', () => {
364
683
  let members;
365
684
 
@@ -8,6 +8,7 @@ import Meetings from '@webex/plugin-meetings';
8
8
  import MembersRequest from '@webex/plugin-meetings/src/members/request';
9
9
  import membersUtil from '@webex/plugin-meetings/src/members/util';
10
10
  import ParameterError from '@webex/plugin-meetings/src/common/errors/parameter';
11
+ import { merge } from 'lodash';
11
12
 
12
13
  const {assert} = chai;
13
14
 
@@ -18,6 +19,10 @@ describe('plugin-meetings', () => {
18
19
  let membersRequest;
19
20
  let url1;
20
21
  let sandbox;
22
+ const sequence = {some: 'sequenceData'};
23
+ const requestResponse = {some: 'data'};
24
+ let locusDeltaRequestSpy;
25
+ const correlationId = '12345';
21
26
 
22
27
  beforeEach(() => {
23
28
  const webex = new MockWebex({
@@ -28,21 +33,43 @@ describe('plugin-meetings', () => {
28
33
 
29
34
  sandbox = sinon.createSandbox();
30
35
 
36
+ sinon.stub(uuid, 'v4').returns(correlationId);
37
+
31
38
  url1 = `https://example.com/${uuid.v4()}`;
32
39
 
40
+ const request = sinon.mock().returns(Promise.resolve(requestResponse));
41
+
33
42
  membersRequest = new MembersRequest(
34
- {},
43
+ {
44
+ meeting: {
45
+ request,
46
+ locusInfo: {
47
+ sequence,
48
+ },
49
+ },
50
+ },
35
51
  {
36
52
  parent: webex,
37
53
  }
38
54
  );
39
- membersRequest.request = sinon.mock().returns(Promise.resolve({}));
55
+ locusDeltaRequestSpy = sinon.spy(membersRequest, 'locusDeltaRequest');
56
+
57
+ membersRequest.request = request;
40
58
  });
41
59
 
42
60
  afterEach(() => {
43
61
  sandbox.restore();
62
+ uuid.v4.restore();
44
63
  });
45
64
 
65
+ const checkRequest = (expectedParams) => {
66
+ assert.calledOnceWithExactly(locusDeltaRequestSpy, expectedParams);
67
+ assert.calledOnceWithExactly(
68
+ membersRequest.request,
69
+ merge(expectedParams, {body: {sequence}})
70
+ );
71
+ };
72
+
46
73
  describe('members request library', () => {
47
74
  describe('#sendDialPadKey', () => {
48
75
  it('sends a POST to the sendDtmf locus endpoint', async () => {
@@ -57,12 +84,22 @@ describe('plugin-meetings', () => {
57
84
  memberId,
58
85
  locusUrl,
59
86
  });
60
- const requestParams = membersRequest.request.getCall(0).args[0];
61
87
 
62
- assert.equal(requestParams.method, 'POST');
63
- assert.equal(requestParams.uri, `${locusUrl}/participant/${memberId}/sendDtmf`);
64
- assert.equal(requestParams.body.dtmf.tones, tones);
65
- assert.equal(requestParams.body.device.url, url);
88
+ checkRequest({
89
+ method: 'POST',
90
+ uri: `${locusUrl}/participant/${memberId}/sendDtmf`,
91
+ body: {
92
+ memberId,
93
+ dtmf: {
94
+ direction: 'transmit',
95
+ correlationId,
96
+ tones,
97
+ },
98
+ device: {
99
+ url,
100
+ }
101
+ }
102
+ });
66
103
  });
67
104
  });
68
105
 
@@ -76,11 +113,91 @@ describe('plugin-meetings', () => {
76
113
  };
77
114
 
78
115
  await membersRequest.addMembers(options);
79
- const requestParams = membersRequest.request.getCall(0).args[0];
80
116
 
81
- assert.equal(requestParams.method, 'PUT');
82
- assert.equal(requestParams.uri, url1);
83
- assert.equal(requestParams.body.invitees[0].address, '+18578675309');
117
+ checkRequest({
118
+ method: 'PUT',
119
+ uri: url1,
120
+ body: {
121
+ alertIfActive: undefined,
122
+ invitees: [{address: '+18578675309'}]
123
+ }
124
+ })
125
+ });
126
+ });
127
+
128
+ describe('#admitMember', () => {
129
+ it('sends a request to admit members', async () => {
130
+ const options = {
131
+ locusUrl: url1,
132
+ memberIds: ['1', '2'],
133
+ };
134
+
135
+ await membersRequest.admitMember(options)
136
+
137
+ checkRequest({
138
+ method: 'PUT',
139
+ uri: 'https://example.com/12345/controls',
140
+ body: {
141
+ admit: {
142
+ participantIds: options.memberIds
143
+ }
144
+ }
145
+ });
146
+ });
147
+ });
148
+
149
+ describe('#removeMember', () => {
150
+ it('sends a request to remove a member', async () => {
151
+ const options = {
152
+ locusUrl: url1,
153
+ memberId: 'member1',
154
+ };
155
+
156
+ await membersRequest.removeMember(options);
157
+
158
+ checkRequest({
159
+ method: 'PUT',
160
+ uri: 'https://example.com/12345/participant/member1/leave',
161
+ body: {
162
+ reason: undefined
163
+ },
164
+ });
165
+ });
166
+ });
167
+
168
+ describe('#muteMember', () => {
169
+ it('sends a request to mute a member', async () => {
170
+ const options = {
171
+ locusUrl: url1,
172
+ memberId: 'member1',
173
+ muted: true,
174
+ };
175
+
176
+ await membersRequest.muteMember(options);
177
+
178
+ checkRequest({
179
+ method: 'PATCH',
180
+ uri: 'https://example.com/12345/participant/member1/controls',
181
+ body: {audio: {muted: true}},
182
+ });
183
+ });
184
+ });
185
+
186
+ describe('#transferHostToMember', () => {
187
+ it('sends a request to transfer host to a member', async () => {
188
+ const options = {
189
+ locusUrl: url1,
190
+ memberId: 'member1',
191
+ moderator: true,
192
+ };
193
+
194
+ await membersRequest.transferHostToMember(options);
195
+
196
+ checkRequest({
197
+ method: 'PATCH',
198
+ uri: 'https://example.com/12345/participant/member1/controls',
199
+ body: {role: {moderator: true}},
200
+ });
84
201
  });
85
202
  });
86
203
 
@@ -94,12 +211,45 @@ describe('plugin-meetings', () => {
94
211
  };
95
212
 
96
213
  await membersRequest.cancelPhoneInvite(options);
97
- const requestParams = membersRequest.request.getCall(0).args[0];
98
214
 
99
- assert.equal(requestParams.method, 'PUT');
100
- assert.equal(requestParams.uri, url1);
101
- assert.equal(requestParams.body.invitees[0].address, '+18578675309');
102
- assert.equal(requestParams.body.actionType, 'REMOVE');
215
+ checkRequest({
216
+ method: 'PUT',
217
+ uri: url1,
218
+ body: {
219
+ invitees: [{address: '+18578675309'}],
220
+ actionType: 'REMOVE',
221
+ },
222
+ });
223
+ });
224
+ });
225
+
226
+ describe('#assignRolesMember', () => {
227
+ it('sends a PATCH to the locus endpoint', async () => {
228
+ const locusUrl = url1;
229
+ const memberId = 'test1';
230
+ const roles = [
231
+ {type: 'PRESENTER', hasRole: true},
232
+ {type: 'MODERATOR', hasRole: false},
233
+ {type: 'COHOST', hasRole: true},
234
+ ];
235
+
236
+ const options = {
237
+ memberId,
238
+ locusUrl,
239
+ roles,
240
+ };
241
+
242
+ await membersRequest.assignRolesMember(options);
243
+
244
+ checkRequest({
245
+ method: 'PATCH',
246
+ uri: `${locusUrl}/participant/${memberId}/controls`,
247
+ body: {
248
+ role: {
249
+ roles
250
+ }
251
+ }
252
+ });
103
253
  });
104
254
  });
105
255
 
@@ -115,11 +265,16 @@ describe('plugin-meetings', () => {
115
265
  };
116
266
 
117
267
  await membersRequest.raiseOrLowerHandMember(options);
118
- const requestParams = membersRequest.request.getCall(0).args[0];
119
268
 
120
- assert.equal(requestParams.method, 'PATCH');
121
- assert.equal(requestParams.uri, `${locusUrl}/participant/${memberId}/controls`);
122
- assert.equal(requestParams.body.hand.raised, true);
269
+ checkRequest({
270
+ method: 'PATCH',
271
+ uri: `${locusUrl}/participant/${memberId}/controls`,
272
+ body: {
273
+ hand: {
274
+ raised: true
275
+ }
276
+ }
277
+ });
123
278
  });
124
279
  });
125
280
 
@@ -158,10 +313,9 @@ describe('plugin-meetings', () => {
158
313
  locusUrl,
159
314
  };
160
315
 
161
- assert.strictEqual(
162
- membersRequest.lowerAllHandsMember(options),
163
- membersRequest.request.getCall(0).returnValue
164
- );
316
+ const result = await membersRequest.lowerAllHandsMember(options);
317
+
318
+ assert.strictEqual(result, requestResponse);
165
319
  });
166
320
 
167
321
  it('sends a PATCH to the locus endpoint', async () => {
@@ -182,9 +336,7 @@ describe('plugin-meetings', () => {
182
336
  locusUrl: url1,
183
337
  });
184
338
 
185
- const requestParams = membersRequest.request.getCall(0).args[0];
186
-
187
- assert.deepEqual(requestParams, {
339
+ checkRequest({
188
340
  method: 'PATCH',
189
341
  uri: `${locusUrl}/controls`,
190
342
  body: {
@@ -196,5 +348,32 @@ describe('plugin-meetings', () => {
196
348
  });
197
349
  });
198
350
  });
351
+
352
+ describe('#editDisplayName', () => {
353
+ it('sends a POST request to the locus endpoint', async () => {
354
+ const locusUrl = url1;
355
+ const memberId = 'test1';
356
+ const requestingParticipantId = 'test2';
357
+ const aliasValue = 'alias';
358
+
359
+ const options = {
360
+ memberId,
361
+ requestingParticipantId,
362
+ alias: aliasValue,
363
+ locusUrl,
364
+ };
365
+
366
+ await membersRequest.editDisplayNameMember(options);
367
+
368
+ checkRequest({
369
+ method: 'POST',
370
+ uri: `${locusUrl}/participant/${memberId}/alias`,
371
+ body: {
372
+ aliasValue,
373
+ requestingParticipantId,
374
+ }
375
+ });
376
+ });
377
+ });
199
378
  });
200
379
  });