@webex/plugin-meetings 3.0.0-beta.2 → 3.0.0-beta.20

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 (365) hide show
  1. package/UPGRADING.md +9 -9
  2. package/browsers.js +19 -24
  3. package/dist/breakouts/breakout.js +116 -0
  4. package/dist/breakouts/breakout.js.map +1 -0
  5. package/dist/breakouts/collection.js +23 -0
  6. package/dist/breakouts/collection.js.map +1 -0
  7. package/dist/breakouts/index.js +226 -0
  8. package/dist/breakouts/index.js.map +1 -0
  9. package/dist/common/browser-detection.js +1 -20
  10. package/dist/common/browser-detection.js.map +1 -1
  11. package/dist/common/collection.js +5 -20
  12. package/dist/common/collection.js.map +1 -1
  13. package/dist/common/config.js +0 -7
  14. package/dist/common/config.js.map +1 -1
  15. package/dist/common/errors/captcha-error.js +10 -24
  16. package/dist/common/errors/captcha-error.js.map +1 -1
  17. package/dist/common/errors/intent-to-join.js +11 -24
  18. package/dist/common/errors/intent-to-join.js.map +1 -1
  19. package/dist/common/errors/join-meeting.js +12 -25
  20. package/dist/common/errors/join-meeting.js.map +1 -1
  21. package/dist/common/errors/media.js +10 -24
  22. package/dist/common/errors/media.js.map +1 -1
  23. package/dist/common/errors/parameter.js +5 -33
  24. package/dist/common/errors/parameter.js.map +1 -1
  25. package/dist/common/errors/password-error.js +10 -24
  26. package/dist/common/errors/password-error.js.map +1 -1
  27. package/dist/common/errors/permission.js +9 -23
  28. package/dist/common/errors/permission.js.map +1 -1
  29. package/dist/common/errors/reconnection-in-progress.js +0 -17
  30. package/dist/common/errors/reconnection-in-progress.js.map +1 -1
  31. package/dist/common/errors/reconnection.js +10 -24
  32. package/dist/common/errors/reconnection.js.map +1 -1
  33. package/dist/common/errors/stats.js +10 -24
  34. package/dist/common/errors/stats.js.map +1 -1
  35. package/dist/common/errors/webex-errors.js +6 -41
  36. package/dist/common/errors/webex-errors.js.map +1 -1
  37. package/dist/common/errors/webex-meetings-error.js +5 -25
  38. package/dist/common/errors/webex-meetings-error.js.map +1 -1
  39. package/dist/common/events/events-scope.js +0 -22
  40. package/dist/common/events/events-scope.js.map +1 -1
  41. package/dist/common/events/events.js +0 -23
  42. package/dist/common/events/events.js.map +1 -1
  43. package/dist/common/events/trigger-proxy.js +0 -12
  44. package/dist/common/events/trigger-proxy.js.map +1 -1
  45. package/dist/common/events/util.js +0 -15
  46. package/dist/common/events/util.js.map +1 -1
  47. package/dist/common/logs/logger-config.js +0 -4
  48. package/dist/common/logs/logger-config.js.map +1 -1
  49. package/dist/common/logs/logger-proxy.js +1 -8
  50. package/dist/common/logs/logger-proxy.js.map +1 -1
  51. package/dist/common/logs/request.js +37 -60
  52. package/dist/common/logs/request.js.map +1 -1
  53. package/dist/common/queue.js +4 -14
  54. package/dist/common/queue.js.map +1 -1
  55. package/dist/config.js +6 -6
  56. package/dist/config.js.map +1 -1
  57. package/dist/constants.js +88 -46
  58. package/dist/constants.js.map +1 -1
  59. package/dist/index.js +1 -17
  60. package/dist/index.js.map +1 -1
  61. package/dist/locus-info/controlsUtils.js +12 -29
  62. package/dist/locus-info/controlsUtils.js.map +1 -1
  63. package/dist/locus-info/embeddedAppsUtils.js +3 -26
  64. package/dist/locus-info/embeddedAppsUtils.js.map +1 -1
  65. package/dist/locus-info/fullState.js +0 -15
  66. package/dist/locus-info/fullState.js.map +1 -1
  67. package/dist/locus-info/hostUtils.js +4 -12
  68. package/dist/locus-info/hostUtils.js.map +1 -1
  69. package/dist/locus-info/index.js +184 -190
  70. package/dist/locus-info/index.js.map +1 -1
  71. package/dist/locus-info/infoUtils.js +3 -37
  72. package/dist/locus-info/infoUtils.js.map +1 -1
  73. package/dist/locus-info/mediaSharesUtils.js +12 -38
  74. package/dist/locus-info/mediaSharesUtils.js.map +1 -1
  75. package/dist/locus-info/parser.js +92 -118
  76. package/dist/locus-info/parser.js.map +1 -1
  77. package/dist/locus-info/selfUtils.js +34 -91
  78. package/dist/locus-info/selfUtils.js.map +1 -1
  79. package/dist/media/index.js +67 -111
  80. package/dist/media/index.js.map +1 -1
  81. package/dist/media/properties.js +80 -114
  82. package/dist/media/properties.js.map +1 -1
  83. package/dist/media/util.js +2 -9
  84. package/dist/media/util.js.map +1 -1
  85. package/dist/mediaQualityMetrics/config.js +10 -12
  86. package/dist/mediaQualityMetrics/config.js.map +1 -1
  87. package/dist/meeting/effectsState.js +125 -190
  88. package/dist/meeting/effectsState.js.map +1 -1
  89. package/dist/meeting/in-meeting-actions.js +5 -14
  90. package/dist/meeting/in-meeting-actions.js.map +1 -1
  91. package/dist/meeting/index.js +1692 -1925
  92. package/dist/meeting/index.js.map +1 -1
  93. package/dist/meeting/muteState.js +36 -77
  94. package/dist/meeting/muteState.js.map +1 -1
  95. package/dist/meeting/request.js +224 -230
  96. package/dist/meeting/request.js.map +1 -1
  97. package/dist/meeting/request.type.js +7 -0
  98. package/dist/meeting/request.type.js.map +1 -0
  99. package/dist/meeting/state.js +21 -31
  100. package/dist/meeting/state.js.map +1 -1
  101. package/dist/meeting/util.js +43 -215
  102. package/dist/meeting/util.js.map +1 -1
  103. package/dist/meeting-info/collection.js +6 -25
  104. package/dist/meeting-info/collection.js.map +1 -1
  105. package/dist/meeting-info/index.js +14 -32
  106. package/dist/meeting-info/index.js.map +1 -1
  107. package/dist/meeting-info/meeting-info-v2.js +193 -268
  108. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  109. package/dist/meeting-info/request.js +3 -15
  110. package/dist/meeting-info/request.js.map +1 -1
  111. package/dist/meeting-info/util.js +98 -183
  112. package/dist/meeting-info/util.js.map +1 -1
  113. package/dist/meeting-info/utilv2.js +137 -228
  114. package/dist/meeting-info/utilv2.js.map +1 -1
  115. package/dist/meetings/collection.js +5 -20
  116. package/dist/meetings/collection.js.map +1 -1
  117. package/dist/meetings/index.js +490 -560
  118. package/dist/meetings/index.js.map +1 -1
  119. package/dist/meetings/request.js +24 -41
  120. package/dist/meetings/request.js.map +1 -1
  121. package/dist/meetings/util.js +99 -155
  122. package/dist/meetings/util.js.map +1 -1
  123. package/dist/member/index.js +78 -86
  124. package/dist/member/index.js.map +1 -1
  125. package/dist/member/util.js +31 -68
  126. package/dist/member/util.js.map +1 -1
  127. package/dist/members/collection.js +3 -12
  128. package/dist/members/collection.js.map +1 -1
  129. package/dist/members/index.js +93 -200
  130. package/dist/members/index.js.map +1 -1
  131. package/dist/members/request.js +16 -39
  132. package/dist/members/request.js.map +1 -1
  133. package/dist/members/util.js +9 -38
  134. package/dist/members/util.js.map +1 -1
  135. package/dist/metrics/config.js +0 -2
  136. package/dist/metrics/config.js.map +1 -1
  137. package/dist/metrics/constants.js +1 -2
  138. package/dist/metrics/constants.js.map +1 -1
  139. package/dist/metrics/index.js +55 -135
  140. package/dist/metrics/index.js.map +1 -1
  141. package/dist/multistream/mediaRequestManager.js +57 -32
  142. package/dist/multistream/mediaRequestManager.js.map +1 -1
  143. package/dist/multistream/multistreamMedia.js +15 -21
  144. package/dist/multistream/multistreamMedia.js.map +1 -1
  145. package/dist/multistream/receiveSlot.js +10 -50
  146. package/dist/multistream/receiveSlot.js.map +1 -1
  147. package/dist/multistream/receiveSlotManager.js +45 -82
  148. package/dist/multistream/receiveSlotManager.js.map +1 -1
  149. package/dist/multistream/remoteMedia.js +18 -58
  150. package/dist/multistream/remoteMedia.js.map +1 -1
  151. package/dist/multistream/remoteMediaGroup.js +6 -40
  152. package/dist/multistream/remoteMediaGroup.js.map +1 -1
  153. package/dist/multistream/remoteMediaManager.js +362 -416
  154. package/dist/multistream/remoteMediaManager.js.map +1 -1
  155. package/dist/networkQualityMonitor/index.js +36 -57
  156. package/dist/networkQualityMonitor/index.js.map +1 -1
  157. package/dist/personal-meeting-room/index.js +21 -45
  158. package/dist/personal-meeting-room/index.js.map +1 -1
  159. package/dist/personal-meeting-room/request.js +1 -31
  160. package/dist/personal-meeting-room/request.js.map +1 -1
  161. package/dist/personal-meeting-room/util.js +0 -13
  162. package/dist/personal-meeting-room/util.js.map +1 -1
  163. package/dist/reachability/index.js +138 -182
  164. package/dist/reachability/index.js.map +1 -1
  165. package/dist/reachability/request.js +3 -18
  166. package/dist/reachability/request.js.map +1 -1
  167. package/dist/reactions/constants.js +13 -0
  168. package/dist/reactions/constants.js.map +1 -0
  169. package/dist/reactions/reactions.js +109 -0
  170. package/dist/reactions/reactions.js.map +1 -0
  171. package/dist/reactions/reactions.type.js +36 -0
  172. package/dist/reactions/reactions.type.js.map +1 -0
  173. package/dist/reconnection-manager/index.js +322 -455
  174. package/dist/reconnection-manager/index.js.map +1 -1
  175. package/dist/recording-controller/enums.js +17 -0
  176. package/dist/recording-controller/enums.js.map +1 -0
  177. package/dist/recording-controller/index.js +343 -0
  178. package/dist/recording-controller/index.js.map +1 -0
  179. package/dist/recording-controller/util.js +63 -0
  180. package/dist/recording-controller/util.js.map +1 -0
  181. package/dist/roap/index.js +39 -64
  182. package/dist/roap/index.js.map +1 -1
  183. package/dist/roap/request.js +94 -113
  184. package/dist/roap/request.js.map +1 -1
  185. package/dist/roap/turnDiscovery.js +85 -94
  186. package/dist/roap/turnDiscovery.js.map +1 -1
  187. package/dist/statsAnalyzer/global.js +0 -2
  188. package/dist/statsAnalyzer/global.js.map +1 -1
  189. package/dist/statsAnalyzer/index.js +85 -175
  190. package/dist/statsAnalyzer/index.js.map +1 -1
  191. package/dist/statsAnalyzer/mqaUtil.js +72 -53
  192. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  193. package/dist/transcription/index.js +22 -47
  194. package/dist/transcription/index.js.map +1 -1
  195. package/internal-README.md +7 -6
  196. package/package.json +25 -20
  197. package/src/breakouts/README.md +190 -0
  198. package/src/breakouts/breakout.ts +110 -0
  199. package/src/breakouts/collection.ts +19 -0
  200. package/src/breakouts/index.ts +225 -0
  201. package/src/common/{browser-detection.js → browser-detection.ts} +9 -6
  202. package/src/common/collection.ts +9 -7
  203. package/src/common/{config.js → config.ts} +1 -1
  204. package/src/common/errors/{captcha-error.js → captcha-error.ts} +11 -7
  205. package/src/common/errors/{intent-to-join.js → intent-to-join.ts} +12 -7
  206. package/src/common/errors/{join-meeting.js → join-meeting.ts} +17 -8
  207. package/src/common/errors/{media.js → media.ts} +11 -7
  208. package/src/common/errors/parameter.ts +11 -7
  209. package/src/common/errors/{password-error.js → password-error.ts} +11 -7
  210. package/src/common/errors/{permission.js → permission.ts} +10 -6
  211. package/src/common/errors/{reconnection-in-progress.js → reconnection-in-progress.ts} +0 -0
  212. package/src/common/errors/{reconnection.js → reconnection.ts} +11 -7
  213. package/src/common/errors/{stats.js → stats.ts} +11 -7
  214. package/src/common/errors/{webex-errors.js → webex-errors.ts} +8 -7
  215. package/src/common/errors/{webex-meetings-error.js → webex-meetings-error.ts} +4 -2
  216. package/src/common/events/{events-scope.js → events-scope.ts} +6 -2
  217. package/src/common/events/{events.js → events.ts} +5 -1
  218. package/src/common/events/{trigger-proxy.js → trigger-proxy.ts} +9 -5
  219. package/src/common/events/{util.js → util.ts} +2 -3
  220. package/src/common/logs/{logger-config.js → logger-config.ts} +1 -2
  221. package/src/common/logs/logger-proxy.ts +44 -0
  222. package/src/common/logs/{request.js → request.ts} +22 -9
  223. package/src/common/queue.ts +1 -2
  224. package/src/{config.js → config.ts} +17 -12
  225. package/src/constants.ts +40 -1
  226. package/src/index.js +1 -1
  227. package/src/locus-info/controlsUtils.ts +114 -0
  228. package/src/locus-info/{embeddedAppsUtils.js → embeddedAppsUtils.ts} +5 -6
  229. package/src/locus-info/{fullState.js → fullState.ts} +16 -12
  230. package/src/locus-info/{hostUtils.js → hostUtils.ts} +9 -8
  231. package/src/locus-info/{index.js → index.ts} +148 -64
  232. package/src/locus-info/{infoUtils.js → infoUtils.ts} +19 -8
  233. package/src/locus-info/{mediaSharesUtils.js → mediaSharesUtils.ts} +17 -17
  234. package/src/locus-info/{parser.js → parser.ts} +67 -79
  235. package/src/locus-info/{selfUtils.js → selfUtils.ts} +123 -68
  236. package/src/media/{index.js → index.ts} +181 -131
  237. package/src/media/{properties.js → properties.ts} +47 -28
  238. package/src/media/{util.js → util.ts} +2 -2
  239. package/src/mediaQualityMetrics/{config.js → config.ts} +46 -46
  240. package/src/meeting/{effectsState.js → effectsState.ts} +47 -41
  241. package/src/meeting/in-meeting-actions.ts +15 -3
  242. package/src/meeting/{index.js → index.ts} +2263 -1427
  243. package/src/meeting/{muteState.js → muteState.ts} +78 -42
  244. package/src/meeting/{request.js → request.ts} +292 -142
  245. package/src/meeting/request.type.ts +13 -0
  246. package/src/meeting/{state.js → state.ts} +50 -35
  247. package/src/meeting/{util.js → util.ts} +112 -115
  248. package/src/meeting-info/{collection.js → collection.ts} +6 -2
  249. package/src/meeting-info/{index.js → index.ts} +42 -36
  250. package/src/meeting-info/meeting-info-v2.ts +273 -0
  251. package/src/meeting-info/{request.js → request.ts} +14 -4
  252. package/src/meeting-info/{util.js → util.ts} +60 -51
  253. package/src/meeting-info/{utilv2.js → utilv2.ts} +65 -58
  254. package/src/meetings/{collection.js → collection.ts} +6 -3
  255. package/src/meetings/index.ts +1159 -0
  256. package/src/meetings/{request.js → request.ts} +32 -25
  257. package/src/meetings/{util.js → util.ts} +34 -32
  258. package/src/member/{index.js → index.ts} +102 -56
  259. package/src/member/{util.js → util.ts} +52 -25
  260. package/src/members/{collection.js → collection.ts} +2 -2
  261. package/src/members/{index.js → index.ts} +219 -142
  262. package/src/members/{request.js → request.ts} +60 -16
  263. package/src/members/{util.js → util.ts} +50 -48
  264. package/src/metrics/{config.js → config.ts} +254 -83
  265. package/src/metrics/{constants.js → constants.ts} +0 -2
  266. package/src/metrics/{index.js → index.ts} +106 -74
  267. package/src/multistream/mediaRequestManager.ts +81 -15
  268. package/src/multistream/multistreamMedia.ts +5 -0
  269. package/src/multistream/receiveSlot.ts +18 -12
  270. package/src/multistream/receiveSlotManager.ts +23 -21
  271. package/src/multistream/remoteMedia.ts +15 -5
  272. package/src/multistream/remoteMediaGroup.ts +4 -3
  273. package/src/multistream/remoteMediaManager.ts +153 -37
  274. package/src/networkQualityMonitor/{index.js → index.ts} +37 -25
  275. package/src/personal-meeting-room/{index.js → index.ts} +28 -19
  276. package/src/personal-meeting-room/{request.js → request.ts} +13 -4
  277. package/src/personal-meeting-room/{util.js → util.ts} +4 -4
  278. package/src/reachability/{index.js → index.ts} +99 -83
  279. package/src/reachability/request.ts +39 -33
  280. package/src/reactions/constants.ts +4 -0
  281. package/src/reactions/reactions.ts +104 -0
  282. package/src/reactions/reactions.type.ts +62 -0
  283. package/src/reconnection-manager/{index.js → index.ts} +195 -102
  284. package/src/recording-controller/enums.ts +8 -0
  285. package/src/recording-controller/index.ts +315 -0
  286. package/src/recording-controller/util.ts +58 -0
  287. package/src/roap/{index.js → index.ts} +73 -56
  288. package/src/roap/request.ts +157 -0
  289. package/src/roap/turnDiscovery.ts +77 -37
  290. package/src/statsAnalyzer/{global.js → global.ts} +30 -33
  291. package/src/statsAnalyzer/{index.js → index.ts} +468 -192
  292. package/src/statsAnalyzer/mqaUtil.ts +290 -0
  293. package/src/transcription/{index.js → index.ts} +46 -39
  294. package/test/integration/spec/journey.js +664 -463
  295. package/test/integration/spec/space-meeting.js +320 -206
  296. package/test/integration/spec/transcription.js +7 -8
  297. package/test/unit/spec/breakouts/breakout.ts +119 -0
  298. package/test/unit/spec/breakouts/collection.ts +15 -0
  299. package/test/unit/spec/breakouts/index.ts +293 -0
  300. package/test/unit/spec/common/browser-detection.js +9 -28
  301. package/test/unit/spec/fixture/locus.js +92 -90
  302. package/test/unit/spec/locus-info/controlsUtils.js +25 -5
  303. package/test/unit/spec/locus-info/embeddedAppsUtils.js +8 -6
  304. package/test/unit/spec/locus-info/index.js +104 -2
  305. package/test/unit/spec/locus-info/infoUtils.js +41 -32
  306. package/test/unit/spec/locus-info/lib/BasicSeqCmp.json +88 -430
  307. package/test/unit/spec/locus-info/lib/SeqCmp.json +513 -685
  308. package/test/unit/spec/locus-info/parser.js +3 -9
  309. package/test/unit/spec/locus-info/selfConstant.js +97 -103
  310. package/test/unit/spec/locus-info/selfUtils.js +105 -12
  311. package/test/unit/spec/media/index.ts +31 -47
  312. package/test/unit/spec/media/properties.ts +9 -9
  313. package/test/unit/spec/meeting/effectsState.js +39 -45
  314. package/test/unit/spec/meeting/in-meeting-actions.ts +5 -2
  315. package/test/unit/spec/meeting/index.js +2017 -742
  316. package/test/unit/spec/meeting/muteState.js +42 -33
  317. package/test/unit/spec/meeting/request.js +115 -44
  318. package/test/unit/spec/meeting/utils.js +104 -171
  319. package/test/unit/spec/meeting-info/meetinginfov2.js +100 -73
  320. package/test/unit/spec/meeting-info/request.js +7 -9
  321. package/test/unit/spec/meeting-info/util.js +11 -12
  322. package/test/unit/spec/meeting-info/utilv2.js +110 -74
  323. package/test/unit/spec/meetings/collection.js +1 -1
  324. package/test/unit/spec/meetings/index.js +439 -257
  325. package/test/unit/spec/meetings/utils.js +14 -12
  326. package/test/unit/spec/member/index.js +0 -1
  327. package/test/unit/spec/member/util.js +31 -7
  328. package/test/unit/spec/members/index.js +104 -54
  329. package/test/unit/spec/members/request.js +29 -20
  330. package/test/unit/spec/members/utils.js +8 -5
  331. package/test/unit/spec/metrics/index.js +16 -21
  332. package/test/unit/spec/multistream/mediaRequestManager.ts +316 -50
  333. package/test/unit/spec/multistream/receiveSlot.ts +6 -6
  334. package/test/unit/spec/multistream/receiveSlotManager.ts +13 -13
  335. package/test/unit/spec/multistream/remoteMedia.ts +10 -2
  336. package/test/unit/spec/multistream/remoteMediaGroup.ts +5 -5
  337. package/test/unit/spec/multistream/remoteMediaManager.ts +412 -65
  338. package/test/unit/spec/networkQualityMonitor/index.js +21 -15
  339. package/test/unit/spec/personal-meeting-room/personal-meeting-room.js +2 -7
  340. package/test/unit/spec/reachability/index.ts +58 -26
  341. package/test/unit/spec/reconnection-manager/index.js +102 -9
  342. package/test/unit/spec/recording-controller/index.js +231 -0
  343. package/test/unit/spec/recording-controller/util.js +102 -0
  344. package/test/unit/spec/roap/index.ts +2 -1
  345. package/test/unit/spec/roap/request.ts +114 -0
  346. package/test/unit/spec/roap/turnDiscovery.ts +64 -45
  347. package/test/unit/spec/stats-analyzer/index.js +27 -22
  348. package/test/utils/cmr.js +44 -42
  349. package/test/utils/testUtils.js +83 -74
  350. package/test/utils/webex-config.js +18 -18
  351. package/test/utils/webex-test-users.js +54 -50
  352. package/tsconfig.json +6 -0
  353. package/dist/media/internal-media-core-wrapper.js +0 -22
  354. package/dist/media/internal-media-core-wrapper.js.map +0 -1
  355. package/dist/peer-connection-manager/util.js +0 -124
  356. package/dist/peer-connection-manager/util.js.map +0 -1
  357. package/src/common/logs/logger-proxy.js +0 -33
  358. package/src/locus-info/controlsUtils.js +0 -102
  359. package/src/media/internal-media-core-wrapper.ts +0 -9
  360. package/src/meeting-info/meeting-info-v2.js +0 -255
  361. package/src/meetings/index.js +0 -1015
  362. package/src/peer-connection-manager/util.ts +0 -117
  363. package/src/roap/request.js +0 -127
  364. package/src/statsAnalyzer/mqaUtil.js +0 -173
  365. package/test/unit/spec/peerconnection-manager/utils.test-fixtures.ts +0 -389
@@ -2,15 +2,14 @@
2
2
  import {assert} from '@webex/test-helper-chai';
3
3
  import {skipInNode, jenkinsOnly} from '@webex/test-helper-mocha';
4
4
  import {patterns} from '@webex/common';
5
-
6
- import MeetingInfoUtil from '@webex/plugin-meetings/src/meeting-info/utilv2';
5
+ import MeetingInfoUtil from '@webex/plugin-meetings/dist/meeting-info/utilv2';
7
6
 
8
7
  import CMR from '../../utils/cmr';
9
8
  import testUtils from '../../utils/testUtils';
10
9
 
11
10
  require('dotenv').config();
12
11
 
13
- const webexTestUsers = require('../../utils/webex-test-users.js');
12
+ const webexTestUsers = require('../../utils/webex-test-users');
14
13
 
15
14
  let userSet, alice, bob, chris, guest;
16
15
 
@@ -18,29 +17,34 @@ skipInNode(describe)('plugin-meetings', () => {
18
17
  describe('space-meeting', () => {
19
18
  let space = null;
20
19
 
21
- before(() => webexTestUsers.generateTestUsers({
22
- count: 4,
23
- whistler: process.env.WHISTLER || process.env.JENKINS
24
- })
25
- .then((users) => {
26
- userSet = users;
27
- alice = userSet[0];
28
- bob = userSet[1];
29
- chris = userSet[2];
30
- guest = userSet[3];
31
- alice.name = 'alice';
32
- bob.name = 'bob';
33
- chris.name = 'chris';
34
- guest.name = 'guest';
35
- })
36
- .then(() => Promise.all([testUtils.syncAndEndMeeting(alice),
37
- testUtils.syncAndEndMeeting(bob)]))
38
- .catch((error) => {
39
- console.log(error);
40
- }));
20
+ before(() =>
21
+ webexTestUsers
22
+ .generateTestUsers({
23
+ count: 4,
24
+ whistler: process.env.WHISTLER || process.env.JENKINS,
25
+ })
26
+ .then((users) => {
27
+ userSet = users;
28
+ alice = userSet[0];
29
+ bob = userSet[1];
30
+ chris = userSet[2];
31
+ guest = userSet[3];
32
+ alice.name = 'alice';
33
+ bob.name = 'bob';
34
+ chris.name = 'chris';
35
+ guest.name = 'guest';
36
+ })
37
+ .then(() =>
38
+ Promise.all([testUtils.syncAndEndMeeting(alice), testUtils.syncAndEndMeeting(bob)])
39
+ )
40
+ .catch((error) => {
41
+ console.log(error);
42
+ })
43
+ );
41
44
 
42
45
  it('Alice starts a space meeting', () =>
43
- alice.webex.internal.conversation.create({participants: [bob, chris]})
46
+ alice.webex.internal.conversation
47
+ .create({participants: [bob, chris]})
44
48
  .then((conversation) => {
45
49
  assert.lengthOf(conversation.participants.items, 3);
46
50
  assert.lengthOf(conversation.activities.items, 1);
@@ -48,8 +52,13 @@ skipInNode(describe)('plugin-meetings', () => {
48
52
  space = conversation;
49
53
  })
50
54
  .then(async () => {
51
- const destinationWithType = await alice.webex.meetings.meetingInfo.fetchMeetingInfo(space.url, 'CONVERSATION_URL');
52
- const destinationNoType = await alice.webex.meetings.meetingInfo.fetchMeetingInfo(space.url);
55
+ const destinationWithType = await alice.webex.meetings.meetingInfo.fetchMeetingInfo(
56
+ space.url,
57
+ 'CONVERSATION_URL'
58
+ );
59
+ const destinationNoType = await alice.webex.meetings.meetingInfo.fetchMeetingInfo(
60
+ space.url
61
+ );
53
62
 
54
63
  assert.exists(destinationNoType);
55
64
  assert.exists(destinationWithType);
@@ -59,37 +68,47 @@ skipInNode(describe)('plugin-meetings', () => {
59
68
  .then(function aliceStartsMeeting() {
60
69
  return Promise.all([
61
70
  testUtils.delayedPromise(alice.webex.meetings.create(space.url)),
62
- testUtils.waitForEvents([{scope: alice.webex.meetings, event: 'meeting:added', user: alice}])
71
+ testUtils.waitForEvents([
72
+ {scope: alice.webex.meetings, event: 'meeting:added', user: alice},
73
+ ]),
63
74
  ]);
64
75
  })
65
- .then(() => Promise.all([
66
- testUtils.delayedPromise(alice.meeting.join()),
67
- testUtils.waitForEvents([
68
- {scope: bob.webex.meetings, event: 'meeting:added', user: bob},
69
- {scope: chris.webex.meetings, event: 'meeting:added', user: chris}
70
- ])
71
- ]).then(() => {
72
- // TODO Renenable after unified flag is enabled
73
- // const {meetingNumber} = bob.meeting.meetingInfo;
74
-
75
- // assert(meetingNumber === alice.meeting.meetingNumber, 'meetingNumber matches alice meeting number');
76
- })));
77
-
78
- xit('Should fetch user info using user hydra id with the new api', () => alice.webex.rooms.create({title: 'sample'})
79
- .then((room) => MeetingInfoUtil.getDestinationType({
80
- destination: room.creatorId,
81
- webex: alice.webex
82
- }))
83
- .then((destinationType) => MeetingInfoUtil.getRequestBody(destinationType))
84
- .then((res) => {
85
- assert.exists(res.sipUrl, 'sipURL didnt exist');
86
- assert.match(res.sipUrl, patterns.email); // assert sipURL is email
87
- }));
76
+ .then(() =>
77
+ Promise.all([
78
+ testUtils.delayedPromise(alice.meeting.join()),
79
+ testUtils.waitForEvents([
80
+ {scope: bob.webex.meetings, event: 'meeting:added', user: bob},
81
+ {scope: chris.webex.meetings, event: 'meeting:added', user: chris},
82
+ ]),
83
+ ]).then(() => {
84
+ // TODO Renenable after unified flag is enabled
85
+ // const {meetingNumber} = bob.meeting.meetingInfo;
86
+ // assert(meetingNumber === alice.meeting.meetingNumber, 'meetingNumber matches alice meeting number');
87
+ })
88
+ ));
89
+
90
+ xit('Should fetch user info using user hydra id with the new api', () =>
91
+ alice.webex.rooms
92
+ .create({title: 'sample'})
93
+ .then((room) =>
94
+ MeetingInfoUtil.getDestinationType({
95
+ destination: room.creatorId,
96
+ webex: alice.webex,
97
+ })
98
+ )
99
+ .then((destinationType) => MeetingInfoUtil.getRequestBody(destinationType))
100
+ .then((res) => {
101
+ assert.exists(res.sipUrl, 'sipURL didnt exist');
102
+ assert.match(res.sipUrl, patterns.email); // assert sipURL is email
103
+ }));
88
104
 
89
105
  // Enable this test when we are going to enable the unified space meeeting .
90
106
  // We cannot change the config on load as the meetingInfo function loads dynamically
91
107
  xit('Should fetch meeting info using space url with the new api', async () => {
92
- const res = await alice.webex.meetings.meetingInfo.fetchMeetingInfo(space.url, 'CONVERSATION_URL');
108
+ const res = await alice.webex.meetings.meetingInfo.fetchMeetingInfo(
109
+ space.url,
110
+ 'CONVERSATION_URL'
111
+ );
93
112
 
94
113
  assert.exists(res.body.meetingNumber);
95
114
  });
@@ -99,104 +118,150 @@ skipInNode(describe)('plugin-meetings', () => {
99
118
  const res = await bob.webex.meetings.meetingInfo.fetchMeetingInfo(sipUri, 'SIP_URI');
100
119
  const {meetingNumber} = res.body;
101
120
 
102
- assert(meetingNumber === alice.meeting.meetingNumber, 'meetingNumber matches alice meeting number');
121
+ assert(
122
+ meetingNumber === alice.meeting.meetingNumber,
123
+ 'meetingNumber matches alice meeting number'
124
+ );
103
125
  });
104
126
 
105
- it('Bob and chris joins space meeting', () => testUtils.waitForStateChange(alice.meeting, 'JOINED')
106
- .then(() => testUtils.waitForStateChange(bob.meeting, 'IDLE'))
107
- .then(() => testUtils.waitForStateChange(chris.meeting, 'IDLE'))
108
- .then(() => bob.meeting.join())
109
- .then(() => chris.meeting.join())
110
- // add .then checks for alice response, should see bob and chris member status to isInMeeting = true
111
- .then(() => testUtils.waitForStateChange(bob.meeting, 'JOINED'))
112
- .then(() => testUtils.waitForStateChange(chris.meeting, 'JOINED')));
127
+ it('Bob and chris joins space meeting', () =>
128
+ testUtils
129
+ .waitForStateChange(alice.meeting, 'JOINED')
130
+ .then(() => testUtils.waitForStateChange(bob.meeting, 'IDLE'))
131
+ .then(() => testUtils.waitForStateChange(chris.meeting, 'IDLE'))
132
+ .then(() => bob.meeting.join())
133
+ .then(() => chris.meeting.join())
134
+ // add .then checks for alice response, should see bob and chris member status to isInMeeting = true
135
+ .then(() => testUtils.waitForStateChange(bob.meeting, 'JOINED'))
136
+ .then(() => testUtils.waitForStateChange(chris.meeting, 'JOINED')));
113
137
 
114
- it('Bob and Alice addsMedia', () => testUtils.addMedia(bob)
115
- .then(() => testUtils.addMedia(alice)));
138
+ it('Bob and Alice addsMedia', () =>
139
+ testUtils.addMedia(bob).then(() => testUtils.addMedia(alice)));
116
140
 
117
141
  it('Bob has flowing streams on reconnect', () => {
118
142
  const retrieveStats = () => {
119
- assert.isAbove(bob.meeting.statsAnalyzer.statsResults.audio.recv.totalPacketsReceived, 0, 'total packets received greater than 0');
143
+ assert.isAbove(
144
+ bob.meeting.statsAnalyzer.statsResults.audio.recv.totalPacketsReceived,
145
+ 0,
146
+ 'total packets received greater than 0'
147
+ );
120
148
  };
121
149
 
122
150
  return Promise.all([
123
151
  testUtils.delayedPromise(bob.meeting.reconnect()),
124
152
  testUtils.waitForEvents([{scope: bob.meeting, event: 'media:ready'}]),
125
- testUtils.delayedTest(retrieveStats, 9000)
153
+ testUtils.delayedTest(retrieveStats, 9000),
126
154
  ]).catch((error) => {
127
155
  // eslint-disable-next-line no-console
128
156
  console.warn('errror', error);
129
157
  });
130
158
  });
131
159
 
132
-
133
- it('alice adds x user as guest to space meeting', () => Promise.all([
134
- testUtils.delayedPromise(guest.webex.meetings.create(alice.meeting.sipUri)),
135
- testUtils.waitForEvents([{scope: guest.webex.meetings, event: 'meeting:added', user: guest}])
136
- ]).then(() =>
160
+ it('alice adds x user as guest to space meeting', () =>
137
161
  Promise.all([
138
- testUtils.delayedPromise(guest.meeting.join()),
139
- testUtils.waitForEvents([{scope: guest.meeting, event: 'meeting:self:lobbyWaiting'}]),
140
- testUtils.waitForEvents([{scope: alice.meeting.members, event: 'members:update'}])
141
- .then((response) => {
142
- const guestParticipant = response[0].result.delta.added.find((member) => member.participant.identity === guest.id);
143
-
144
- assert.equal(guestParticipant.status, 'IN_LOBBY');
145
-
146
- return Promise.all([
147
- testUtils.delayedPromise(alice.meeting.admit(guestParticipant.id)),
148
- testUtils.waitForEvents([{scope: guest.meeting, event: 'meeting:self:guestAdmitted'}])
149
- ]);
150
- })
151
- ]))
152
- .then(() => testUtils.waitForStateChange(guest.meeting, 'JOINED'))
153
- .then(() => testUtils.addMedia(guest))
154
- .catch((e) => { console.error('Error chris joining the meeting ', e); throw e; }));
162
+ testUtils.delayedPromise(guest.webex.meetings.create(alice.meeting.sipUri)),
163
+ testUtils.waitForEvents([
164
+ {scope: guest.webex.meetings, event: 'meeting:added', user: guest},
165
+ ]),
166
+ ])
167
+ .then(() =>
168
+ Promise.all([
169
+ testUtils.delayedPromise(guest.meeting.join()),
170
+ testUtils.waitForEvents([{scope: guest.meeting, event: 'meeting:self:lobbyWaiting'}]),
171
+ testUtils
172
+ .waitForEvents([{scope: alice.meeting.members, event: 'members:update'}])
173
+ .then((response) => {
174
+ const guestParticipant = response[0].result.delta.added.find(
175
+ (member) => member.participant.identity === guest.id
176
+ );
177
+
178
+ assert.equal(guestParticipant.status, 'IN_LOBBY');
179
+
180
+ return Promise.all([
181
+ testUtils.delayedPromise(alice.meeting.admit(guestParticipant.id)),
182
+ testUtils.waitForEvents([
183
+ {scope: guest.meeting, event: 'meeting:self:guestAdmitted'},
184
+ ]),
185
+ ]);
186
+ }),
187
+ ])
188
+ )
189
+ .then(() => testUtils.waitForStateChange(guest.meeting, 'JOINED'))
190
+ .then(() => testUtils.addMedia(guest))
191
+ .catch((e) => {
192
+ console.error('Error chris joining the meeting ', e);
193
+ throw e;
194
+ }));
155
195
 
156
- it('alice Leaves the meeting', () => Promise.all([
157
- testUtils.delayedPromise(alice.meeting.leave()),
158
- testUtils.waitForEvents([{scope: chris.meeting.members, event: 'members:update', match: testUtils.checkParticipantUpdatedStatus(alice, 'NOT_IN_MEETING')}])
159
- ]).then(() => testUtils.waitForStateChange(alice.meeting, 'LEFT')));
196
+ it('alice Leaves the meeting', () =>
197
+ Promise.all([
198
+ testUtils.delayedPromise(alice.meeting.leave()),
199
+ testUtils.waitForEvents([
200
+ {
201
+ scope: chris.meeting.members,
202
+ event: 'members:update',
203
+ match: testUtils.checkParticipantUpdatedStatus(alice, 'NOT_IN_MEETING'),
204
+ },
205
+ ]),
206
+ ]).then(() => testUtils.waitForStateChange(alice.meeting, 'LEFT')));
160
207
 
161
208
  it('bob and chris leave meeting', () =>
162
209
  Promise.all([
163
210
  testUtils.delayedPromise(bob.meeting.leave()),
164
- testUtils.waitForEvents([{scope: chris.meeting.members, event: 'members:update', match: testUtils.checkParticipantUpdatedStatus(bob, 'NOT_IN_MEETING')}])
165
- ]).then(() => testUtils.waitForStateChange(bob.meeting, 'LEFT'))
211
+ testUtils.waitForEvents([
212
+ {
213
+ scope: chris.meeting.members,
214
+ event: 'members:update',
215
+ match: testUtils.checkParticipantUpdatedStatus(bob, 'NOT_IN_MEETING'),
216
+ },
217
+ ]),
218
+ ])
219
+ .then(() => testUtils.waitForStateChange(bob.meeting, 'LEFT'))
166
220
  .then(() => chris.meeting.leave())
167
221
  .then(() => testUtils.waitUntil(4000)));
168
222
 
169
-
170
223
  it('check for meeting cleanup', () => {
171
224
  console.log('Alice ', alice.webex.meetings.getAllMeetings());
172
225
  console.log('Bob ', bob.webex.meetings.getAllMeetings());
173
226
  console.log('Chris ', chris.webex.meetings.getAllMeetings());
174
- assert.notExists(alice.webex.meetings.getMeetingByType('correlationId', alice.meeting.correlationId), 'alice meeting exists');
175
- assert.notExists(bob.webex.meetings.getMeetingByType('correlationId', bob.meeting.correlationId), 'bob meeting exists');
176
- assert.notExists(chris.webex.meetings.getMeetingByType('correlationId', chris.meeting.correlationId), 'chris meeting exists');
227
+ assert.notExists(
228
+ alice.webex.meetings.getMeetingByType('correlationId', alice.meeting.correlationId),
229
+ 'alice meeting exists'
230
+ );
231
+ assert.notExists(
232
+ bob.webex.meetings.getMeetingByType('correlationId', bob.meeting.correlationId),
233
+ 'bob meeting exists'
234
+ );
235
+ assert.notExists(
236
+ chris.webex.meetings.getMeetingByType('correlationId', chris.meeting.correlationId),
237
+ 'chris meeting exists'
238
+ );
177
239
  });
178
240
  });
179
241
 
180
242
  jenkinsOnly(describe.skip)('Unclaimed PMR', () => {
181
- before(() => webexTestUsers.generateTestUsers({
182
- count: 3,
183
- whistler: true
184
- })
185
- .then((users) => {
186
- userSet = users;
187
- alice = userSet[0];
188
- bob = userSet[1];
189
- chris = userSet[2];
190
- })
191
- .then(() => testUtils.syncAndEndMeeting(alice))
192
- .then(() => CMR.reserve(alice.webex, false))
193
- .then((cmr) => {
194
- console.log('CMRR ', cmr);
195
- alice.cmr = cmr;
196
- })
197
- .catch((error) => {
198
- console.log('WEBEX MEETING error ', error);
199
- }));
243
+ before(() =>
244
+ webexTestUsers
245
+ .generateTestUsers({
246
+ count: 3,
247
+ whistler: true,
248
+ })
249
+ .then((users) => {
250
+ userSet = users;
251
+ alice = userSet[0];
252
+ bob = userSet[1];
253
+ chris = userSet[2];
254
+ })
255
+ .then(() => testUtils.syncAndEndMeeting(alice))
256
+ .then(() => CMR.reserve(alice.webex, false))
257
+ .then((cmr) => {
258
+ console.log('CMRR ', cmr);
259
+ alice.cmr = cmr;
260
+ })
261
+ .catch((error) => {
262
+ console.log('WEBEX MEETING error ', error);
263
+ })
264
+ );
200
265
 
201
266
  after(() => CMR.release(alice.webex, alice.cmr.reservationUrl));
202
267
 
@@ -204,12 +269,15 @@ skipInNode(describe)('plugin-meetings', () => {
204
269
  it('alice joins the unclaimed PMR as attende', () => {
205
270
  Promise.all([
206
271
  testUtils.delayedPromise(alice.webex.meetings.create(alice.cmr.sipAddress)),
207
- testUtils.waitForEvents([{scope: alice.webex.meetings, event: 'meeting:added', user: alice}])
272
+ testUtils.waitForEvents([
273
+ {scope: alice.webex.meetings, event: 'meeting:added', user: alice},
274
+ ]),
208
275
  ])
209
276
  .then(() => alice.meeting.join({moderator: false}))
210
277
  .then(() => testUtils.waitForStateChange(alice.meeting, 'IDLE'))
211
278
  .then(function bobChrisJoiningMeeting() {
212
- return bob.webex.meetings.create(alice.cmr.sipAddress)
279
+ return bob.webex.meetings
280
+ .create(alice.cmr.sipAddress)
213
281
  .then((m) => {
214
282
  bob.meeting = m;
215
283
 
@@ -230,10 +298,13 @@ skipInNode(describe)('plugin-meetings', () => {
230
298
  .then(() => testUtils.waitForStateChange(bob.meeting, 'LEFT'))
231
299
  .then(() => chris.meeting.leave())
232
300
  .then(() => testUtils.waitForStateChange(chris.meeting, 'LEFT'))
233
- .then(() => Promise.all([
234
- testUtils.waitForCallEnded(alice, alice.sipAddress),
235
- testUtils.waitForCallEnded(bob, alice.sipAddress),
236
- testUtils.waitForCallEnded(chris, alice.sipAddress)]));
301
+ .then(() =>
302
+ Promise.all([
303
+ testUtils.waitForCallEnded(alice, alice.sipAddress),
304
+ testUtils.waitForCallEnded(bob, alice.sipAddress),
305
+ testUtils.waitForCallEnded(chris, alice.sipAddress),
306
+ ])
307
+ );
237
308
  });
238
309
 
239
310
  // it('bob joins with out host pin or moderator', () => {
@@ -244,100 +315,143 @@ skipInNode(describe)('plugin-meetings', () => {
244
315
 
245
316
  // TODO: fix this . getting 408 conflict for leave
246
317
  jenkinsOnly(describe.skip)('Claimed PMR', () => {
247
- before(() => webexTestUsers.generateTestUsers({
248
- count: 3,
249
- whistler: true
250
- })
251
- .then((users) => {
252
- userSet = users;
253
- alice = userSet[0];
254
- bob = userSet[1];
255
- chris = userSet[2];
256
- alice.name = 'alice';
257
- bob.name = 'bob';
258
- })
259
- .then(() => testUtils.syncAndEndMeeting(alice))
260
- .then(() => CMR.reserve(alice.webex, true))
261
- .then((cmr) => {
262
- console.log('CMRR ', cmr);
263
- alice.cmr = cmr;
264
- })
265
- .catch((error) => {
266
- console.log('WEBEX MEETING error ', error);
267
- }));
318
+ before(() =>
319
+ webexTestUsers
320
+ .generateTestUsers({
321
+ count: 3,
322
+ whistler: true,
323
+ })
324
+ .then((users) => {
325
+ userSet = users;
326
+ alice = userSet[0];
327
+ bob = userSet[1];
328
+ chris = userSet[2];
329
+ alice.name = 'alice';
330
+ bob.name = 'bob';
331
+ })
332
+ .then(() => testUtils.syncAndEndMeeting(alice))
333
+ .then(() => CMR.reserve(alice.webex, true))
334
+ .then((cmr) => {
335
+ console.log('CMRR ', cmr);
336
+ alice.cmr = cmr;
337
+ })
338
+ .catch((error) => {
339
+ console.log('WEBEX MEETING error ', error);
340
+ })
341
+ );
268
342
 
269
343
  after(() => CMR.release(alice.webex, alice.cmr.reservationUrl));
270
344
 
271
345
  describe('Successful meeting', () => {
272
- it('alice starts a space meeting', () => Promise.all([
273
- testUtils.delayedPromise(alice.webex.meetings.create(alice.cmr.sipAddress)),
274
- testUtils.waitForEvents([{scope: alice.webex.meetings, event: 'meeting:added', user: alice}])
275
- ])
276
- .then(() => alice.meeting.join({moderator: false}))
277
- .then(() => testUtils.waitForStateChange(alice.meeting, 'JOINED'))
278
- .then(() => bob.webex.meetings.create(alice.cmr.sipAddress))
279
- .then((m) => {
280
- bob.meeting = m;
281
-
282
- return m.join();
283
- })
284
- .then(() => testUtils.waitForStateChange(bob.meeting, 'JOINED'))
285
- .then(function bobChrisJoinMeeting() {
286
- return chris.webex.meetings.create(alice.cmr.sipAddress)
287
- .then((m) => {
288
- chris.meeting = m;
289
-
290
- return m.join({moderator: false});
291
- })
292
- .then(() => testUtils.waitForStateChange(chris.meeting, 'JOINED'));
293
- }));
346
+ it('alice starts a space meeting', () =>
347
+ Promise.all([
348
+ testUtils.delayedPromise(alice.webex.meetings.create(alice.cmr.sipAddress)),
349
+ testUtils.waitForEvents([
350
+ {scope: alice.webex.meetings, event: 'meeting:added', user: alice},
351
+ ]),
352
+ ])
353
+ .then(() => alice.meeting.join({moderator: false}))
354
+ .then(() => testUtils.waitForStateChange(alice.meeting, 'JOINED'))
355
+ .then(() => bob.webex.meetings.create(alice.cmr.sipAddress))
356
+ .then((m) => {
357
+ bob.meeting = m;
294
358
 
359
+ return m.join();
360
+ })
361
+ .then(() => testUtils.waitForStateChange(bob.meeting, 'JOINED'))
362
+ .then(function bobChrisJoinMeeting() {
363
+ return chris.webex.meetings
364
+ .create(alice.cmr.sipAddress)
365
+ .then((m) => {
366
+ chris.meeting = m;
295
367
 
296
- it('alice adds chris as guest to space meeting', () => Promise.all([
297
- testUtils.delayedPromise(alice.meeting.invite({emailAddress: guest.emailAddress})),
298
- testUtils.waitForEvents([{scope: guest.webex.meetings, event: 'meeting:added', user: guest}]),
299
- testUtils.waitForEvents([{scope: alice.meeting.members, event: 'members:update'}])
300
- .then((response) => {
301
- const guestParticipant = response[0].result.delta.added.find((member) => guest.emailAddress === member.email);
368
+ return m.join({moderator: false});
369
+ })
370
+ .then(() => testUtils.waitForStateChange(chris.meeting, 'JOINED'));
371
+ }));
302
372
 
303
- assert.equal(guestParticipant.status, 'NOT_IN_MEETING');
373
+ it('alice adds chris as guest to space meeting', () =>
374
+ Promise.all([
375
+ testUtils.delayedPromise(alice.meeting.invite({emailAddress: guest.emailAddress})),
376
+ testUtils.waitForEvents([
377
+ {scope: guest.webex.meetings, event: 'meeting:added', user: guest},
378
+ ]),
379
+ testUtils
380
+ .waitForEvents([{scope: alice.meeting.members, event: 'members:update'}])
381
+ .then((response) => {
382
+ const guestParticipant = response[0].result.delta.added.find(
383
+ (member) => guest.emailAddress === member.email
384
+ );
385
+
386
+ assert.equal(guestParticipant.status, 'NOT_IN_MEETING');
387
+ }),
388
+ ])
389
+ .catch((e) => {
390
+ console.error('Error adding chris as guest ', e);
391
+ throw e;
304
392
  })
305
- ])
306
- .catch((e) => { console.error('Error adding chris as guest ', e); throw e; })
307
- .then(function memberUpdated() {
308
- assert.exists(guest.meeting);
393
+ .then(function memberUpdated() {
394
+ assert.exists(guest.meeting);
309
395
 
310
- return Promise.all([
311
- testUtils.delayedPromise(guest.meeting.join()),
312
- testUtils.waitForEvents([{scope: guest.meeting, event: 'meeting:self:lobbyWaiting'}]),
313
- testUtils.waitForEvents([{scope: alice.meeting.members, event: 'members:update', match: testUtils.checkParticipantUpdatedStatus(guest, 'IN_LOBBY')}])
314
- .then(() => {
315
- Promise.all([
316
- testUtils.delayedPromise(alice.meeting.admit(guest.meeting.members.selfId)),
317
- testUtils.waitForEvents([{scope: guest.meeting, event: 'meeting:self:guestAdmitted'}])
318
- ]);
319
- })
320
- ])
321
- .then(() => testUtils.waitForStateChange(guest.meeting, 'JOINED'))
322
- .then(() => testUtils.addMedia(guest));
323
- })
324
- .catch((e) => { console.error('Error guest joining the meeting ', e); throw e; })
325
- .then(() => Promise.all([
326
- testUtils.delayedPromise(chris.meeting.leave()),
327
- testUtils.waitForEvents([{scope: alice.meeting.members, event: 'members:update', match: testUtils.checkParticipantUpdatedStatus(chris, 'NOT_IN_MEETING')}])
328
- ]))
329
- .catch((e) => { console.error('Error chris leaving the meeting ', e); throw e; }));
330
-
331
- it('leave claimed PMR', () => alice.meeting.leave()
332
- .then(() => bob.meeting.leave())
333
- .then(() => testUtils.waitForStateChange(alice.meeting, 'LEFT'))
334
- .then(() => testUtils.waitForStateChange(bob.meeting, 'LEFT'))
335
- .then(() => chris.meeting.leave())
336
- .then(() => testUtils.waitForStateChange(chris.meeting, 'LEFT'))
337
- .then(() => Promise.all([
338
- testUtils.waitForCallEnded(alice, alice.sipAddress),
339
- testUtils.waitForCallEnded(bob, alice.sipAddress),
340
- testUtils.waitForCallEnded(chris, alice.sipAddress)])));
396
+ return Promise.all([
397
+ testUtils.delayedPromise(guest.meeting.join()),
398
+ testUtils.waitForEvents([{scope: guest.meeting, event: 'meeting:self:lobbyWaiting'}]),
399
+ testUtils
400
+ .waitForEvents([
401
+ {
402
+ scope: alice.meeting.members,
403
+ event: 'members:update',
404
+ match: testUtils.checkParticipantUpdatedStatus(guest, 'IN_LOBBY'),
405
+ },
406
+ ])
407
+ .then(() => {
408
+ Promise.all([
409
+ testUtils.delayedPromise(alice.meeting.admit(guest.meeting.members.selfId)),
410
+ testUtils.waitForEvents([
411
+ {scope: guest.meeting, event: 'meeting:self:guestAdmitted'},
412
+ ]),
413
+ ]);
414
+ }),
415
+ ])
416
+ .then(() => testUtils.waitForStateChange(guest.meeting, 'JOINED'))
417
+ .then(() => testUtils.addMedia(guest));
418
+ })
419
+ .catch((e) => {
420
+ console.error('Error guest joining the meeting ', e);
421
+ throw e;
422
+ })
423
+ .then(() =>
424
+ Promise.all([
425
+ testUtils.delayedPromise(chris.meeting.leave()),
426
+ testUtils.waitForEvents([
427
+ {
428
+ scope: alice.meeting.members,
429
+ event: 'members:update',
430
+ match: testUtils.checkParticipantUpdatedStatus(chris, 'NOT_IN_MEETING'),
431
+ },
432
+ ]),
433
+ ])
434
+ )
435
+ .catch((e) => {
436
+ console.error('Error chris leaving the meeting ', e);
437
+ throw e;
438
+ }));
439
+
440
+ it('leave claimed PMR', () =>
441
+ alice.meeting
442
+ .leave()
443
+ .then(() => bob.meeting.leave())
444
+ .then(() => testUtils.waitForStateChange(alice.meeting, 'LEFT'))
445
+ .then(() => testUtils.waitForStateChange(bob.meeting, 'LEFT'))
446
+ .then(() => chris.meeting.leave())
447
+ .then(() => testUtils.waitForStateChange(chris.meeting, 'LEFT'))
448
+ .then(() =>
449
+ Promise.all([
450
+ testUtils.waitForCallEnded(alice, alice.sipAddress),
451
+ testUtils.waitForCallEnded(bob, alice.sipAddress),
452
+ testUtils.waitForCallEnded(chris, alice.sipAddress),
453
+ ])
454
+ ));
341
455
  });
342
456
  });
343
457
  });