@webex/plugin-meetings 3.0.0-beta.16 → 3.0.0-beta.160
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.
- package/README.md +45 -1
- package/dist/annotation/annotation.types.js +7 -0
- package/dist/annotation/annotation.types.js.map +1 -0
- package/dist/annotation/constants.js +49 -0
- package/dist/annotation/constants.js.map +1 -0
- package/dist/annotation/index.js +359 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/breakouts/breakout.js +212 -0
- package/dist/breakouts/breakout.js.map +1 -0
- package/dist/breakouts/collection.js +23 -0
- package/dist/breakouts/collection.js.map +1 -0
- package/dist/breakouts/edit-lock-error.js +52 -0
- package/dist/breakouts/edit-lock-error.js.map +1 -0
- package/dist/breakouts/events.js +43 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +1046 -0
- package/dist/breakouts/index.js.map +1 -0
- package/dist/breakouts/request.js +78 -0
- package/dist/breakouts/request.js.map +1 -0
- package/dist/breakouts/utils.js +67 -0
- package/dist/breakouts/utils.js.map +1 -0
- package/dist/common/errors/webex-errors.js +3 -2
- package/dist/common/errors/webex-errors.js.map +1 -1
- package/dist/common/logs/logger-proxy.js +1 -1
- package/dist/common/logs/logger-proxy.js.map +1 -1
- package/dist/config.js +6 -8
- package/dist/config.js.map +1 -1
- package/dist/constants.js +165 -26
- package/dist/constants.js.map +1 -1
- package/dist/controls-options-manager/constants.js +14 -0
- package/dist/controls-options-manager/constants.js.map +1 -0
- package/dist/controls-options-manager/enums.js +27 -0
- package/dist/controls-options-manager/enums.js.map +1 -0
- package/dist/controls-options-manager/index.js +297 -0
- package/dist/controls-options-manager/index.js.map +1 -0
- package/dist/controls-options-manager/types.js +7 -0
- package/dist/controls-options-manager/types.js.map +1 -0
- package/dist/controls-options-manager/util.js +300 -0
- package/dist/controls-options-manager/util.js.map +1 -0
- package/dist/index.js +77 -0
- package/dist/index.js.map +1 -1
- package/dist/locus-info/controlsUtils.js +91 -2
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/index.js +298 -24
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +43 -1
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +2 -1
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +88 -14
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +39 -134
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +19 -97
- package/dist/media/properties.js.map +1 -1
- package/dist/mediaQualityMetrics/config.js +505 -493
- package/dist/mediaQualityMetrics/config.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +79 -1
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +2275 -2152
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/locusMediaRequest.js +291 -0
- package/dist/meeting/locusMediaRequest.js.map +1 -0
- package/dist/meeting/muteState.js +229 -124
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +191 -167
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/request.type.js.map +1 -1
- package/dist/meeting/util.js +443 -443
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +157 -49
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/utilv2.js +20 -5
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +22 -0
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +365 -73
- package/dist/meetings/index.js.map +1 -1
- package/dist/meetings/meetings.types.js +7 -0
- package/dist/meetings/meetings.types.js.map +1 -0
- package/dist/meetings/request.js +16 -12
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +88 -1
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +41 -0
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js +15 -0
- package/dist/member/types.js.map +1 -0
- package/dist/member/util.js +86 -3
- package/dist/member/util.js.map +1 -1
- package/dist/members/collection.js +10 -0
- package/dist/members/collection.js.map +1 -1
- package/dist/members/index.js +94 -11
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +109 -39
- package/dist/members/request.js.map +1 -1
- package/dist/members/types.js +15 -0
- package/dist/members/types.js.map +1 -0
- package/dist/members/util.js +316 -233
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/config.js +50 -14
- package/dist/metrics/config.js.map +1 -1
- package/dist/metrics/constants.js +3 -5
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +48 -29
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +265 -36
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +52 -19
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +53 -33
- package/dist/multistream/receiveSlotManager.js.map +1 -1
- package/dist/multistream/remoteMedia.js +44 -18
- package/dist/multistream/remoteMedia.js.map +1 -1
- package/dist/multistream/remoteMediaGroup.js +60 -3
- package/dist/multistream/remoteMediaGroup.js.map +1 -1
- package/dist/multistream/remoteMediaManager.js +322 -103
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/networkQualityMonitor/index.js +4 -2
- package/dist/networkQualityMonitor/index.js.map +1 -1
- package/dist/reachability/index.js +117 -60
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +12 -5
- package/dist/reachability/request.js.map +1 -1
- package/dist/reactions/constants.js +13 -0
- package/dist/reactions/constants.js.map +1 -0
- package/dist/reactions/reactions.js +2 -2
- package/dist/reactions/reactions.js.map +1 -1
- package/dist/reactions/reactions.type.js +18 -18
- package/dist/reactions/reactions.type.js.map +1 -1
- package/dist/reconnection-manager/index.js +190 -145
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/enums.js +17 -0
- package/dist/recording-controller/enums.js.map +1 -0
- package/dist/recording-controller/index.js +343 -0
- package/dist/recording-controller/index.js.map +1 -0
- package/dist/recording-controller/util.js +63 -0
- package/dist/recording-controller/util.js.map +1 -0
- package/dist/roap/index.js +21 -29
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +127 -92
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +135 -53
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/statsAnalyzer/global.js +1 -93
- package/dist/statsAnalyzer/global.js.map +1 -1
- package/dist/statsAnalyzer/index.js +329 -314
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +103 -54
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/types/annotation/annotation.types.d.ts +43 -0
- package/dist/types/annotation/constants.d.ts +31 -0
- package/dist/types/annotation/index.d.ts +124 -0
- package/dist/types/breakouts/breakout.d.ts +8 -0
- package/dist/types/breakouts/collection.d.ts +5 -0
- package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
- package/dist/types/breakouts/events.d.ts +2 -0
- package/dist/types/breakouts/index.d.ts +5 -0
- package/dist/types/breakouts/request.d.ts +22 -0
- package/dist/types/breakouts/utils.d.ts +15 -0
- package/dist/types/common/browser-detection.d.ts +9 -0
- package/dist/types/common/collection.d.ts +48 -0
- package/dist/types/common/config.d.ts +2 -0
- package/dist/types/common/errors/captcha-error.d.ts +15 -0
- package/dist/types/common/errors/intent-to-join.d.ts +16 -0
- package/dist/types/common/errors/join-meeting.d.ts +17 -0
- package/dist/types/common/errors/media.d.ts +15 -0
- package/dist/types/common/errors/parameter.d.ts +15 -0
- package/dist/types/common/errors/password-error.d.ts +15 -0
- package/dist/types/common/errors/permission.d.ts +14 -0
- package/dist/types/common/errors/reconnection-in-progress.d.ts +9 -0
- package/dist/types/common/errors/reconnection.d.ts +15 -0
- package/dist/types/common/errors/stats.d.ts +15 -0
- package/dist/types/common/errors/webex-errors.d.ts +69 -0
- package/dist/types/common/errors/webex-meetings-error.d.ts +20 -0
- package/dist/types/common/events/events-scope.d.ts +17 -0
- package/dist/types/common/events/events.d.ts +12 -0
- package/dist/types/common/events/trigger-proxy.d.ts +2 -0
- package/dist/types/common/events/util.d.ts +2 -0
- package/dist/types/common/logs/logger-config.d.ts +2 -0
- package/dist/types/common/logs/logger-proxy.d.ts +2 -0
- package/dist/types/common/logs/request.d.ts +34 -0
- package/dist/types/common/queue.d.ts +32 -0
- package/dist/types/config.d.ts +72 -0
- package/dist/types/constants.d.ts +978 -0
- package/dist/types/controls-options-manager/constants.d.ts +4 -0
- package/dist/types/controls-options-manager/enums.d.ts +15 -0
- package/dist/types/controls-options-manager/index.d.ts +136 -0
- package/dist/types/controls-options-manager/types.d.ts +43 -0
- package/dist/types/controls-options-manager/util.d.ts +1 -0
- package/dist/types/index.d.ts +7 -0
- package/dist/types/locus-info/controlsUtils.d.ts +2 -0
- package/dist/types/locus-info/embeddedAppsUtils.d.ts +2 -0
- package/dist/types/locus-info/fullState.d.ts +2 -0
- package/dist/types/locus-info/hostUtils.d.ts +2 -0
- package/dist/types/locus-info/index.d.ts +315 -0
- package/dist/types/locus-info/infoUtils.d.ts +2 -0
- package/dist/types/locus-info/mediaSharesUtils.d.ts +2 -0
- package/dist/types/locus-info/parser.d.ts +212 -0
- package/dist/types/locus-info/selfUtils.d.ts +2 -0
- package/dist/types/media/index.d.ts +34 -0
- package/dist/types/media/properties.d.ts +86 -0
- package/dist/types/media/util.d.ts +2 -0
- package/dist/types/mediaQualityMetrics/config.d.ts +365 -0
- package/dist/types/meeting/in-meeting-actions.d.ts +149 -0
- package/dist/types/meeting/index.d.ts +1516 -0
- package/dist/types/meeting/locusMediaRequest.d.ts +70 -0
- package/dist/types/meeting/muteState.d.ts +184 -0
- package/dist/types/meeting/request.d.ts +270 -0
- package/dist/types/meeting/request.type.d.ts +11 -0
- package/dist/types/meeting/state.d.ts +9 -0
- package/dist/types/meeting/util.d.ts +75 -0
- package/dist/types/meeting-info/collection.d.ts +20 -0
- package/dist/types/meeting-info/index.d.ts +57 -0
- package/dist/types/meeting-info/meeting-info-v2.d.ts +122 -0
- package/dist/types/meeting-info/request.d.ts +22 -0
- package/dist/types/meeting-info/util.d.ts +2 -0
- package/dist/types/meeting-info/utilv2.d.ts +2 -0
- package/dist/types/meetings/collection.d.ts +31 -0
- package/dist/types/meetings/index.d.ts +364 -0
- package/dist/types/meetings/meetings.types.d.ts +4 -0
- package/dist/types/meetings/request.d.ts +27 -0
- package/dist/types/meetings/util.d.ts +18 -0
- package/dist/types/member/index.d.ts +157 -0
- package/dist/types/member/types.d.ts +21 -0
- package/dist/types/member/util.d.ts +2 -0
- package/dist/types/members/collection.d.ts +29 -0
- package/dist/types/members/index.d.ts +353 -0
- package/dist/types/members/request.d.ts +114 -0
- package/dist/types/members/types.d.ts +24 -0
- package/dist/types/members/util.d.ts +210 -0
- package/dist/types/metrics/config.d.ts +195 -0
- package/dist/types/metrics/constants.d.ts +55 -0
- package/dist/types/metrics/index.d.ts +169 -0
- package/dist/types/multistream/mediaRequestManager.d.ts +118 -0
- package/dist/types/multistream/receiveSlot.d.ts +68 -0
- package/dist/types/multistream/receiveSlotManager.d.ts +56 -0
- package/dist/types/multistream/remoteMedia.d.ts +72 -0
- package/dist/types/multistream/remoteMediaGroup.d.ts +47 -0
- package/dist/types/multistream/remoteMediaManager.d.ts +277 -0
- package/dist/types/networkQualityMonitor/index.d.ts +70 -0
- package/dist/types/personal-meeting-room/index.d.ts +47 -0
- package/dist/types/personal-meeting-room/request.d.ts +14 -0
- package/dist/types/personal-meeting-room/util.d.ts +2 -0
- package/dist/types/reachability/index.d.ts +152 -0
- package/dist/types/reachability/request.d.ts +37 -0
- package/dist/types/reactions/constants.d.ts +3 -0
- package/dist/types/reactions/reactions.d.ts +4 -0
- package/dist/types/reactions/reactions.type.d.ts +52 -0
- package/dist/types/reconnection-manager/index.d.ts +126 -0
- package/dist/types/recording-controller/enums.d.ts +7 -0
- package/dist/types/recording-controller/index.d.ts +193 -0
- package/dist/types/recording-controller/util.d.ts +13 -0
- package/dist/types/roap/index.d.ts +77 -0
- package/dist/types/roap/request.d.ts +36 -0
- package/dist/types/roap/turnDiscovery.d.ts +91 -0
- package/dist/types/statsAnalyzer/global.d.ts +36 -0
- package/dist/types/statsAnalyzer/index.d.ts +200 -0
- package/dist/types/statsAnalyzer/mqaUtil.d.ts +24 -0
- package/dist/types/transcription/index.d.ts +64 -0
- package/package.json +28 -21
- package/src/annotation/annotation.types.ts +52 -0
- package/src/annotation/constants.ts +36 -0
- package/src/annotation/index.ts +343 -0
- package/src/breakouts/README.md +220 -0
- package/src/breakouts/breakout.ts +180 -0
- package/src/breakouts/collection.ts +19 -0
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +37 -0
- package/src/breakouts/index.ts +921 -0
- package/src/breakouts/request.ts +55 -0
- package/src/breakouts/utils.ts +57 -0
- package/src/common/errors/webex-errors.ts +6 -2
- package/src/common/logs/logger-proxy.ts +1 -1
- package/src/config.ts +5 -7
- package/src/constants.ts +155 -20
- package/src/controls-options-manager/constants.ts +5 -0
- package/src/controls-options-manager/enums.ts +18 -0
- package/src/controls-options-manager/index.ts +278 -0
- package/src/controls-options-manager/types.ts +59 -0
- package/src/controls-options-manager/util.ts +286 -0
- package/src/index.ts +34 -0
- package/src/locus-info/controlsUtils.ts +108 -0
- package/src/locus-info/index.ts +310 -21
- package/src/locus-info/mediaSharesUtils.ts +48 -0
- package/src/locus-info/parser.ts +2 -1
- package/src/locus-info/selfUtils.ts +80 -2
- package/src/media/index.ts +70 -142
- package/src/media/properties.ts +41 -104
- package/src/mediaQualityMetrics/config.ts +379 -377
- package/src/meeting/in-meeting-actions.ts +156 -0
- package/src/meeting/index.ts +1744 -1767
- package/src/meeting/locusMediaRequest.ts +309 -0
- package/src/meeting/muteState.ts +228 -132
- package/src/meeting/request.ts +100 -91
- package/src/meeting/request.type.ts +2 -0
- package/src/meeting/util.ts +421 -421
- package/src/meeting-info/meeting-info-v2.ts +134 -13
- package/src/meeting-info/utilv2.ts +13 -3
- package/src/meetings/collection.ts +20 -0
- package/src/meetings/index.ts +385 -83
- package/src/meetings/meetings.types.ts +12 -0
- package/src/meetings/request.ts +3 -1
- package/src/meetings/util.ts +103 -4
- package/src/member/index.ts +40 -0
- package/src/member/types.ts +24 -0
- package/src/member/util.ts +81 -1
- package/src/members/collection.ts +8 -0
- package/src/members/index.ts +108 -6
- package/src/members/request.ts +98 -17
- package/src/members/types.ts +28 -0
- package/src/members/util.ts +319 -240
- package/src/metrics/config.ts +49 -10
- package/src/metrics/constants.ts +2 -4
- package/src/metrics/index.ts +43 -27
- package/src/multistream/mediaRequestManager.ts +337 -63
- package/src/multistream/receiveSlot.ts +68 -26
- package/src/multistream/receiveSlotManager.ts +61 -38
- package/src/multistream/remoteMedia.ts +29 -3
- package/src/multistream/remoteMediaGroup.ts +61 -2
- package/src/multistream/remoteMediaManager.ts +260 -66
- package/src/networkQualityMonitor/index.ts +6 -6
- package/src/reachability/index.ts +75 -25
- package/src/reachability/request.ts +10 -5
- package/src/reactions/constants.ts +4 -0
- package/src/reactions/reactions.ts +4 -4
- package/src/reactions/reactions.type.ts +28 -3
- package/src/reconnection-manager/index.ts +53 -32
- package/src/recording-controller/enums.ts +8 -0
- package/src/recording-controller/index.ts +315 -0
- package/src/recording-controller/util.ts +58 -0
- package/src/roap/index.ts +21 -30
- package/src/roap/request.ts +51 -52
- package/src/roap/turnDiscovery.ts +51 -27
- package/src/statsAnalyzer/global.ts +1 -94
- package/src/statsAnalyzer/index.ts +380 -390
- package/src/statsAnalyzer/mqaUtil.ts +106 -99
- package/test/integration/spec/converged-space-meetings.js +233 -0
- package/test/integration/spec/journey.js +331 -254
- package/test/integration/spec/space-meeting.js +77 -4
- package/test/unit/spec/annotation/index.ts +436 -0
- package/test/unit/spec/breakouts/breakout.ts +233 -0
- package/test/unit/spec/breakouts/collection.ts +15 -0
- package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
- package/test/unit/spec/breakouts/events.ts +77 -0
- package/test/unit/spec/breakouts/index.ts +1790 -0
- package/test/unit/spec/breakouts/request.ts +104 -0
- package/test/unit/spec/breakouts/utils.js +72 -0
- package/test/unit/spec/controls-options-manager/index.js +287 -0
- package/test/unit/spec/controls-options-manager/util.js +518 -0
- package/test/unit/spec/fixture/locus.js +1 -0
- package/test/unit/spec/locus-info/controlsUtils.js +303 -30
- package/test/unit/spec/locus-info/index.js +616 -4
- package/test/unit/spec/locus-info/mediaSharesUtils.ts +22 -0
- package/test/unit/spec/locus-info/selfConstant.js +38 -0
- package/test/unit/spec/locus-info/selfUtils.js +249 -0
- package/test/unit/spec/media/index.ts +118 -22
- package/test/unit/spec/media/properties.ts +9 -9
- package/test/unit/spec/meeting/in-meeting-actions.ts +76 -0
- package/test/unit/spec/meeting/index.js +2496 -1375
- package/test/unit/spec/meeting/locusMediaRequest.ts +436 -0
- package/test/unit/spec/meeting/muteState.js +370 -208
- package/test/unit/spec/meeting/request.js +354 -42
- package/test/unit/spec/meeting/utils.js +268 -156
- package/test/unit/spec/meeting-info/meetinginfov2.js +383 -5
- package/test/unit/spec/meeting-info/utilv2.js +21 -0
- package/test/unit/spec/meetings/collection.js +14 -0
- package/test/unit/spec/meetings/index.js +866 -120
- package/test/unit/spec/meetings/utils.js +206 -2
- package/test/unit/spec/member/index.js +24 -0
- package/test/unit/spec/member/util.js +384 -32
- package/test/unit/spec/members/index.js +320 -1
- package/test/unit/spec/members/request.js +206 -27
- package/test/unit/spec/members/utils.js +184 -0
- package/test/unit/spec/metrics/index.js +98 -0
- package/test/unit/spec/multistream/mediaRequestManager.ts +1012 -109
- package/test/unit/spec/multistream/receiveSlot.ts +77 -18
- package/test/unit/spec/multistream/receiveSlotManager.ts +69 -39
- package/test/unit/spec/multistream/remoteMedia.ts +32 -2
- package/test/unit/spec/multistream/remoteMediaGroup.ts +271 -5
- package/test/unit/spec/multistream/remoteMediaManager.ts +672 -65
- package/test/unit/spec/networkQualityMonitor/index.js +4 -4
- package/test/unit/spec/reachability/index.ts +176 -25
- package/test/unit/spec/reachability/request.js +66 -0
- package/test/unit/spec/reconnection-manager/index.js +46 -13
- package/test/unit/spec/recording-controller/index.js +231 -0
- package/test/unit/spec/recording-controller/util.js +102 -0
- package/test/unit/spec/roap/index.ts +21 -51
- package/test/unit/spec/roap/request.ts +187 -0
- package/test/unit/spec/roap/turnDiscovery.ts +73 -34
- package/test/unit/spec/stats-analyzer/index.js +94 -43
- package/test/utils/constants.js +9 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +0 -45
- package/test/utils/webex-config.js +4 -0
- package/test/utils/webex-test-users.js +7 -3
- package/tsconfig.json +6 -0
- package/dist/media/internal-media-core-wrapper.js +0 -18
- package/dist/media/internal-media-core-wrapper.js.map +0 -1
- package/dist/meeting/effectsState.js +0 -262
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/multistream/multistreamMedia.js +0 -106
- package/dist/multistream/multistreamMedia.js.map +0 -1
- package/src/index.js +0 -15
- package/src/media/internal-media-core-wrapper.ts +0 -9
- package/src/meeting/effectsState.ts +0 -211
- package/src/multistream/multistreamMedia.ts +0 -93
- package/test/unit/spec/meeting/effectsState.js +0 -281
|
@@ -2,7 +2,7 @@ import 'jsdom-global/register';
|
|
|
2
2
|
import chai from 'chai';
|
|
3
3
|
import chaiAsPromised from 'chai-as-promised';
|
|
4
4
|
import sinon from 'sinon';
|
|
5
|
-
import {
|
|
5
|
+
import {ConnectionState} from '@webex/internal-media-core';
|
|
6
6
|
|
|
7
7
|
import {StatsAnalyzer, EVENTS} from '../../../../src/statsAnalyzer';
|
|
8
8
|
import NetworkQualityMonitor from '../../../../src/networkQualityMonitor';
|
|
@@ -24,14 +24,15 @@ describe('plugin-meetings', () => {
|
|
|
24
24
|
};
|
|
25
25
|
|
|
26
26
|
const defaultStats = {
|
|
27
|
+
resolutions: {},
|
|
27
28
|
internal: {
|
|
28
|
-
video: {
|
|
29
|
+
'video-send-1': {
|
|
29
30
|
send: {
|
|
30
31
|
totalPacketsLostOnReceiver: 10,
|
|
31
32
|
},
|
|
32
33
|
},
|
|
33
34
|
},
|
|
34
|
-
video: {
|
|
35
|
+
'video-send-1': {
|
|
35
36
|
send: {
|
|
36
37
|
packetsSent: 2,
|
|
37
38
|
meanRemoteJitter: [],
|
|
@@ -52,7 +53,12 @@ describe('plugin-meetings', () => {
|
|
|
52
53
|
beforeEach(() => {
|
|
53
54
|
const networkQualityMonitor = new NetworkQualityMonitor(initialConfig);
|
|
54
55
|
|
|
55
|
-
statsAnalyzer = new StatsAnalyzer(
|
|
56
|
+
statsAnalyzer = new StatsAnalyzer(
|
|
57
|
+
initialConfig,
|
|
58
|
+
() => ({}),
|
|
59
|
+
networkQualityMonitor,
|
|
60
|
+
defaultStats
|
|
61
|
+
);
|
|
56
62
|
|
|
57
63
|
sandBoxSpy = sandbox.spy(
|
|
58
64
|
statsAnalyzer.networkQualityMonitor,
|
|
@@ -65,12 +71,12 @@ describe('plugin-meetings', () => {
|
|
|
65
71
|
});
|
|
66
72
|
|
|
67
73
|
it('should trigger determineUplinkNetworkQuality with specific arguments', async () => {
|
|
68
|
-
await statsAnalyzer.parseGetStatsResult(statusResult, 'video');
|
|
74
|
+
await statsAnalyzer.parseGetStatsResult(statusResult, 'video-send-1', true);
|
|
69
75
|
|
|
70
76
|
assert.calledOnce(statsAnalyzer.networkQualityMonitor.determineUplinkNetworkQuality);
|
|
71
77
|
assert(
|
|
72
78
|
sandBoxSpy.calledWith({
|
|
73
|
-
mediaType: 'video',
|
|
79
|
+
mediaType: 'video-send-1',
|
|
74
80
|
remoteRtpResults: statusResult,
|
|
75
81
|
statsAnalyzerCurrentStats: statsAnalyzer.statsResults,
|
|
76
82
|
})
|
|
@@ -83,6 +89,7 @@ describe('plugin-meetings', () => {
|
|
|
83
89
|
let pc;
|
|
84
90
|
let networkQualityMonitor;
|
|
85
91
|
let statsAnalyzer;
|
|
92
|
+
let mqeData;
|
|
86
93
|
|
|
87
94
|
let receivedEventsData = {
|
|
88
95
|
local: {},
|
|
@@ -110,57 +117,83 @@ describe('plugin-meetings', () => {
|
|
|
110
117
|
// bytesReceived and bytesSent need to be non-zero in order for StatsAnalyzer to parse any other values
|
|
111
118
|
fakeStats = {
|
|
112
119
|
audio: {
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
120
|
+
senders: [
|
|
121
|
+
{
|
|
122
|
+
report: [
|
|
123
|
+
{
|
|
124
|
+
type: 'outbound-rtp',
|
|
125
|
+
packetsSent: 0,
|
|
126
|
+
bytesSent: 1,
|
|
127
|
+
},
|
|
128
|
+
],
|
|
129
|
+
},
|
|
130
|
+
],
|
|
131
|
+
receivers: [
|
|
132
|
+
{
|
|
133
|
+
report: [
|
|
134
|
+
{
|
|
135
|
+
type: 'inbound-rtp',
|
|
136
|
+
packetsReceived: 0,
|
|
137
|
+
bytesReceived: 1,
|
|
138
|
+
},
|
|
139
|
+
],
|
|
140
|
+
},
|
|
141
|
+
],
|
|
123
142
|
},
|
|
124
143
|
video: {
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
144
|
+
senders: [
|
|
145
|
+
{
|
|
146
|
+
report: [
|
|
147
|
+
{
|
|
148
|
+
type: 'outbound-rtp',
|
|
149
|
+
framesSent: 0,
|
|
150
|
+
bytesSent: 1,
|
|
151
|
+
},
|
|
152
|
+
],
|
|
153
|
+
},
|
|
154
|
+
],
|
|
155
|
+
receivers: [
|
|
156
|
+
{
|
|
157
|
+
report: [
|
|
158
|
+
{
|
|
159
|
+
type: 'inbound-rtp',
|
|
160
|
+
framesDecoded: 0,
|
|
161
|
+
bytesReceived: 1,
|
|
162
|
+
frameHeight: 720,
|
|
163
|
+
frameWidth: 1280,
|
|
164
|
+
framesReceived: 1,
|
|
165
|
+
},
|
|
166
|
+
],
|
|
167
|
+
},
|
|
168
|
+
],
|
|
135
169
|
},
|
|
136
170
|
};
|
|
137
171
|
|
|
138
172
|
pc = {
|
|
139
|
-
getConnectionState: sinon.stub().returns(
|
|
173
|
+
getConnectionState: sinon.stub().returns(ConnectionState.Connected),
|
|
140
174
|
getTransceiverStats: sinon.stub().resolves({
|
|
141
175
|
audio: {
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
currentDirection: 'sendrecv',
|
|
145
|
-
localTrackLabel: 'fake mic',
|
|
176
|
+
senders: [fakeStats.audio.senders[0]],
|
|
177
|
+
receivers: [fakeStats.audio.receivers[0]],
|
|
146
178
|
},
|
|
147
179
|
video: {
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
180
|
+
senders: [fakeStats.video.senders[0]],
|
|
181
|
+
receivers: [fakeStats.video.receivers[0]],
|
|
182
|
+
},
|
|
183
|
+
screenShareAudio: {
|
|
184
|
+
senders: [],
|
|
185
|
+
receivers: [],
|
|
152
186
|
},
|
|
153
187
|
screenShareVideo: {
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
currentDirection: 'sendrecv',
|
|
188
|
+
senders: [],
|
|
189
|
+
receivers: [],
|
|
157
190
|
},
|
|
158
191
|
}),
|
|
159
192
|
};
|
|
160
193
|
|
|
161
194
|
networkQualityMonitor = new NetworkQualityMonitor(initialConfig);
|
|
162
195
|
|
|
163
|
-
statsAnalyzer = new StatsAnalyzer(initialConfig, networkQualityMonitor);
|
|
196
|
+
statsAnalyzer = new StatsAnalyzer(initialConfig, () => ({}), networkQualityMonitor);
|
|
164
197
|
|
|
165
198
|
statsAnalyzer.on(EVENTS.LOCAL_MEDIA_STARTED, (data) => {
|
|
166
199
|
receivedEventsData.local.started = data;
|
|
@@ -174,6 +207,9 @@ describe('plugin-meetings', () => {
|
|
|
174
207
|
statsAnalyzer.on(EVENTS.REMOTE_MEDIA_STOPPED, (data) => {
|
|
175
208
|
receivedEventsData.remote.stopped = data;
|
|
176
209
|
});
|
|
210
|
+
statsAnalyzer.on(EVENTS.MEDIA_QUALITY, ({data}) => {
|
|
211
|
+
mqeData = data;
|
|
212
|
+
});
|
|
177
213
|
});
|
|
178
214
|
|
|
179
215
|
afterEach(() => {
|
|
@@ -200,6 +236,12 @@ describe('plugin-meetings', () => {
|
|
|
200
236
|
assert.deepEqual(receivedEventsData.remote.stopped, expected.remote?.stopped);
|
|
201
237
|
};
|
|
202
238
|
|
|
239
|
+
const checkMqeData = () => {
|
|
240
|
+
assert.strictEqual(mqeData.videoReceive[0].streams[0].receivedFrameSize, 3600);
|
|
241
|
+
assert.strictEqual(mqeData.videoReceive[0].streams[0].receivedHeight, 720);
|
|
242
|
+
assert.strictEqual(mqeData.videoReceive[0].streams[0].receivedWidth, 1280);
|
|
243
|
+
};
|
|
244
|
+
|
|
203
245
|
it('emits LOCAL_MEDIA_STARTED and LOCAL_MEDIA_STOPPED events for audio', async () => {
|
|
204
246
|
await startStatsAnalyzer({expected: {sendAudio: true}});
|
|
205
247
|
|
|
@@ -207,7 +249,7 @@ describe('plugin-meetings', () => {
|
|
|
207
249
|
checkReceivedEvent({expected: {}});
|
|
208
250
|
|
|
209
251
|
// setup a mock to return some values higher the previous ones
|
|
210
|
-
fakeStats.audio.
|
|
252
|
+
fakeStats.audio.senders[0].report[0].packetsSent += 10;
|
|
211
253
|
|
|
212
254
|
await progressTime();
|
|
213
255
|
|
|
@@ -227,7 +269,7 @@ describe('plugin-meetings', () => {
|
|
|
227
269
|
checkReceivedEvent({expected: {}});
|
|
228
270
|
|
|
229
271
|
// setup a mock to return some values higher the previous ones
|
|
230
|
-
fakeStats.video.
|
|
272
|
+
fakeStats.video.senders[0].report[0].framesSent += 1;
|
|
231
273
|
|
|
232
274
|
await progressTime();
|
|
233
275
|
|
|
@@ -247,7 +289,7 @@ describe('plugin-meetings', () => {
|
|
|
247
289
|
checkReceivedEvent({expected: {}});
|
|
248
290
|
|
|
249
291
|
// setup a mock to return some values higher the previous ones
|
|
250
|
-
fakeStats.audio.
|
|
292
|
+
fakeStats.audio.receivers[0].report[0].packetsReceived += 5;
|
|
251
293
|
|
|
252
294
|
await progressTime();
|
|
253
295
|
// check that we got the REMOTE_MEDIA_STARTED event for audio
|
|
@@ -267,7 +309,7 @@ describe('plugin-meetings', () => {
|
|
|
267
309
|
checkReceivedEvent({expected: {}});
|
|
268
310
|
|
|
269
311
|
// setup a mock to return some values higher the previous ones
|
|
270
|
-
fakeStats.video.
|
|
312
|
+
fakeStats.video.receivers[0].report[0].framesDecoded += 1;
|
|
271
313
|
|
|
272
314
|
await progressTime();
|
|
273
315
|
// check that we got the REMOTE_MEDIA_STARTED event for video
|
|
@@ -279,6 +321,15 @@ describe('plugin-meetings', () => {
|
|
|
279
321
|
|
|
280
322
|
checkReceivedEvent({expected: {remote: {stopped: {type: 'video'}}}});
|
|
281
323
|
});
|
|
324
|
+
|
|
325
|
+
it('emits the correct MEDIA_QUALITY events', async () => {
|
|
326
|
+
await startStatsAnalyzer({expected: {receiveVideo: true}});
|
|
327
|
+
|
|
328
|
+
await progressTime();
|
|
329
|
+
|
|
330
|
+
// Check that the mqe data has been emitted and is correctly computed.
|
|
331
|
+
checkMqeData();
|
|
332
|
+
});
|
|
282
333
|
});
|
|
283
334
|
});
|
|
284
335
|
});
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
// MOVE TO TEST CONSTANTS
|
|
2
|
+
export const MEDIA_SERVERS = {
|
|
3
|
+
// The homer media server for converged multistream meetings.
|
|
4
|
+
HOMER: 'homer',
|
|
5
|
+
// The linus media server
|
|
6
|
+
LINUS: 'linus',
|
|
7
|
+
// The calliope media server for transcoded meetings
|
|
8
|
+
CALLIOPE: 'calliope',
|
|
9
|
+
};
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import {assert} from '@webex/test-helper-chai';
|
|
2
|
+
import {Defer} from '@webex/common';
|
|
3
|
+
|
|
4
|
+
const addMedia = async (user, options = {}) => {
|
|
5
|
+
|
|
6
|
+
const {microphone, camera} = options;
|
|
7
|
+
|
|
8
|
+
if (options.multistream) {
|
|
9
|
+
await user.meeting.addMedia({localTracks: {microphone, camera}});
|
|
10
|
+
} else {
|
|
11
|
+
const mediaReadyPromises = Array.isArray(options.expectedMediaReadyTypes)
|
|
12
|
+
? options.expectedMediaReadyTypes.reduce((output, expectedMediaReadyType) => {
|
|
13
|
+
if (typeof expectedMediaReadyType !== 'string') {
|
|
14
|
+
return output;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
output[expectedMediaReadyType] = new Defer();
|
|
18
|
+
|
|
19
|
+
return output;
|
|
20
|
+
}, {})
|
|
21
|
+
: {remoteAudio: new Defer(), remoteVideo: new Defer()};
|
|
22
|
+
|
|
23
|
+
const mediaReady = (media) => {
|
|
24
|
+
if (!media) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (mediaReadyPromises[media.type]) {
|
|
28
|
+
mediaReadyPromises[media.type].resolve();
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
user.meeting.on('media:ready', mediaReady);
|
|
33
|
+
|
|
34
|
+
await user.meeting.addMedia({localTracks: {microphone, camera}});
|
|
35
|
+
await Promise.all(Object.values(mediaReadyPromises).map((defer) => defer.promise));
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
assert.exists(user.meeting.mediaProperties.audioTrack, 'audioTrack not present');
|
|
40
|
+
assert.exists(user.meeting.mediaProperties.videoTrack, 'videoTrack not present');
|
|
41
|
+
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
export default {
|
|
45
|
+
addMedia
|
|
46
|
+
};
|
package/test/utils/testUtils.js
CHANGED
|
@@ -1,5 +1,3 @@
|
|
|
1
|
-
import {assert} from '@webex/test-helper-chai';
|
|
2
|
-
import {Defer} from '@webex/common';
|
|
3
1
|
|
|
4
2
|
const max = 30000;
|
|
5
3
|
const waitForSpy = (spy, event) => {
|
|
@@ -195,49 +193,7 @@ const delayedTest = (callback, timeout) =>
|
|
|
195
193
|
}, timeout);
|
|
196
194
|
});
|
|
197
195
|
|
|
198
|
-
const addMedia = (user) => {
|
|
199
|
-
const mediaReadyPromises = {
|
|
200
|
-
local: new Defer(),
|
|
201
|
-
remoteAudio: new Defer(),
|
|
202
|
-
remoteVideo: new Defer(),
|
|
203
|
-
};
|
|
204
|
-
const mediaReady = (media) => {
|
|
205
|
-
if (!media) {
|
|
206
|
-
return;
|
|
207
|
-
}
|
|
208
|
-
if (mediaReadyPromises[media.type]) {
|
|
209
|
-
mediaReadyPromises[media.type].resolve();
|
|
210
|
-
}
|
|
211
|
-
};
|
|
212
|
-
|
|
213
|
-
user.meeting.on('media:ready', mediaReady);
|
|
214
196
|
|
|
215
|
-
return user.meeting
|
|
216
|
-
.getMediaStreams({
|
|
217
|
-
sendAudio: true,
|
|
218
|
-
sendVideo: true,
|
|
219
|
-
sendShare: false,
|
|
220
|
-
})
|
|
221
|
-
.then(([localStream, localShare]) =>
|
|
222
|
-
user.meeting.addMedia({
|
|
223
|
-
mediaSettings: {
|
|
224
|
-
sendAudio: true,
|
|
225
|
-
sendVideo: true,
|
|
226
|
-
sendShare: false,
|
|
227
|
-
receiveShare: true,
|
|
228
|
-
receiveAudio: true,
|
|
229
|
-
receiveVideo: true,
|
|
230
|
-
},
|
|
231
|
-
localShare,
|
|
232
|
-
localStream,
|
|
233
|
-
})
|
|
234
|
-
)
|
|
235
|
-
.then(() => Promise.all(Object.values(mediaReadyPromises).map((defer) => defer.promise)))
|
|
236
|
-
.then(() => {
|
|
237
|
-
assert.exists(user.meeting.mediaProperties.audioTrack, 'audioTrack not present');
|
|
238
|
-
assert.exists(user.meeting.mediaProperties.videoTrack, 'videoTrack not present');
|
|
239
|
-
});
|
|
240
|
-
};
|
|
241
197
|
|
|
242
198
|
const waitUntil = (waitTime) =>
|
|
243
199
|
new Promise((resolve) => {
|
|
@@ -279,7 +235,6 @@ export default {
|
|
|
279
235
|
waitForEvents,
|
|
280
236
|
checkParticipantUpdatedStatus,
|
|
281
237
|
delayedPromise,
|
|
282
|
-
addMedia,
|
|
283
238
|
waitUntil,
|
|
284
239
|
delayedTest,
|
|
285
240
|
flushPromises,
|
|
@@ -8,6 +8,7 @@ const config = require('./webex-config');
|
|
|
8
8
|
|
|
9
9
|
// Include the plugins which you feel will be used by the webex instance
|
|
10
10
|
require('@webex/internal-plugin-mercury');
|
|
11
|
+
require('@webex/internal-plugin-llm');
|
|
11
12
|
require('@webex/internal-plugin-user');
|
|
12
13
|
require('@webex/internal-plugin-device');
|
|
13
14
|
require('@webex/internal-plugin-conversation');
|
|
@@ -16,9 +17,11 @@ require('@webex/plugin-people');
|
|
|
16
17
|
require('@webex/plugin-rooms');
|
|
17
18
|
require('@webex/plugin-meetings');
|
|
18
19
|
|
|
19
|
-
const generateTestUsers = (options) =>
|
|
20
|
-
|
|
21
|
-
|
|
20
|
+
const generateTestUsers = (options = {}) => {
|
|
21
|
+
options.config = options.config || {};
|
|
22
|
+
options.config.orgId = options.config.orgId || process.env.WEBEX_CONVERGED_ORG_ID;
|
|
23
|
+
|
|
24
|
+
return testUser.create(options)
|
|
22
25
|
.then(async (userSet) => {
|
|
23
26
|
if (userSet.length !== options.count) {
|
|
24
27
|
return Promise.reject(new Error('Test users not created'));
|
|
@@ -51,6 +54,7 @@ const generateTestUsers = (options) =>
|
|
|
51
54
|
.catch((error) => {
|
|
52
55
|
console.error('#generateTestUsers=>ERROR', error);
|
|
53
56
|
});
|
|
57
|
+
};
|
|
54
58
|
|
|
55
59
|
const reserveCMR = (user) =>
|
|
56
60
|
user.webex
|
package/tsconfig.json
ADDED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _Object$defineProperty = require("@babel/runtime-corejs2/core-js/object/define-property");
|
|
4
|
-
_Object$defineProperty(exports, "__esModule", {
|
|
5
|
-
value: true
|
|
6
|
-
});
|
|
7
|
-
exports.RoapMediaConnection = exports.MultistreamRoapMediaConnection = void 0;
|
|
8
|
-
var _internalMediaCore = require("@webex/internal-media-core");
|
|
9
|
-
/* We have this wrapper just because otherwise it's impossible to mock
|
|
10
|
-
* RoapMediaConnection and MultistreamRoapMediaConnection constructors in unit tests,
|
|
11
|
-
* because they are exported by @webex/internal-media-core as non-writable, non-configurable
|
|
12
|
-
* properties of MediaConnection and sinon doesn't allow spying on them or stubbing them.
|
|
13
|
-
*/
|
|
14
|
-
var RoapMediaConnection = _internalMediaCore.MediaConnection.RoapMediaConnection;
|
|
15
|
-
exports.RoapMediaConnection = RoapMediaConnection;
|
|
16
|
-
var MultistreamRoapMediaConnection = _internalMediaCore.MediaConnection.MultistreamRoapMediaConnection;
|
|
17
|
-
exports.MultistreamRoapMediaConnection = MultistreamRoapMediaConnection;
|
|
18
|
-
//# sourceMappingURL=internal-media-core-wrapper.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"names":["RoapMediaConnection","MC","MultistreamRoapMediaConnection"],"sources":["internal-media-core-wrapper.ts"],"sourcesContent":["import {MediaConnection as MC} from '@webex/internal-media-core';\n\n/* We have this wrapper just because otherwise it's impossible to mock\n * RoapMediaConnection and MultistreamRoapMediaConnection constructors in unit tests,\n * because they are exported by @webex/internal-media-core as non-writable, non-configurable\n * properties of MediaConnection and sinon doesn't allow spying on them or stubbing them.\n */\nexport const {RoapMediaConnection} = MC;\nexport const {MultistreamRoapMediaConnection} = MC;\n"],"mappings":";;;;;;;AAAA;AAEA;AACA;AACA;AACA;AACA;AACO,IAAOA,mBAAmB,GAAIC,kCAAE,CAAzBD,mBAAmB;AAAO;AACjC,IAAOE,8BAA8B,GAAID,kCAAE,CAApCC,8BAA8B;AAAO"}
|