@webex/plugin-meetings 3.0.0-beta.31 → 3.0.0-beta.310
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 +46 -8
- 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 +342 -0
- package/dist/annotation/index.js.map +1 -0
- package/dist/breakouts/breakout.js +94 -15
- package/dist/breakouts/breakout.js.map +1 -1
- package/dist/breakouts/edit-lock-error.js +52 -0
- package/dist/breakouts/edit-lock-error.js.map +1 -0
- package/dist/breakouts/events.js +45 -0
- package/dist/breakouts/events.js.map +1 -0
- package/dist/breakouts/index.js +709 -35
- package/dist/breakouts/index.js.map +1 -1
- package/dist/breakouts/utils.js +45 -1
- package/dist/breakouts/utils.js.map +1 -1
- package/dist/common/errors/no-meeting-info.js +51 -0
- package/dist/common/errors/no-meeting-info.js.map +1 -0
- package/dist/common/errors/reclaim-host-role-errors.js +158 -0
- package/dist/common/errors/reclaim-host-role-errors.js.map +1 -0
- package/dist/common/errors/webex-errors.js +48 -7
- 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/common/logs/request.js +5 -1
- package/dist/common/logs/request.js.map +1 -1
- package/dist/common/queue.js +24 -9
- package/dist/common/queue.js.map +1 -1
- package/dist/config.js +5 -11
- package/dist/config.js.map +1 -1
- package/dist/constants.js +233 -29
- package/dist/constants.js.map +1 -1
- package/dist/controls-options-manager/enums.js +14 -2
- package/dist/controls-options-manager/enums.js.map +1 -1
- package/dist/controls-options-manager/index.js +109 -15
- package/dist/controls-options-manager/index.js.map +1 -1
- 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 +309 -18
- package/dist/controls-options-manager/util.js.map +1 -1
- package/dist/index.js +112 -1
- package/dist/index.js.map +1 -1
- package/dist/interpretation/collection.js +23 -0
- package/dist/interpretation/collection.js.map +1 -0
- package/dist/interpretation/index.js +366 -0
- package/dist/interpretation/index.js.map +1 -0
- package/dist/interpretation/siLanguage.js +25 -0
- package/dist/interpretation/siLanguage.js.map +1 -0
- package/dist/locus-info/controlsUtils.js +91 -2
- package/dist/locus-info/controlsUtils.js.map +1 -1
- package/dist/locus-info/index.js +383 -62
- package/dist/locus-info/index.js.map +1 -1
- package/dist/locus-info/infoUtils.js +7 -1
- package/dist/locus-info/infoUtils.js.map +1 -1
- package/dist/locus-info/mediaSharesUtils.js +57 -1
- package/dist/locus-info/mediaSharesUtils.js.map +1 -1
- package/dist/locus-info/parser.js +249 -72
- package/dist/locus-info/parser.js.map +1 -1
- package/dist/locus-info/selfUtils.js +89 -14
- package/dist/locus-info/selfUtils.js.map +1 -1
- package/dist/media/index.js +61 -116
- package/dist/media/index.js.map +1 -1
- package/dist/media/properties.js +73 -124
- package/dist/media/properties.js.map +1 -1
- package/dist/meeting/in-meeting-actions.js +82 -2
- package/dist/meeting/in-meeting-actions.js.map +1 -1
- package/dist/meeting/index.js +3777 -2929
- package/dist/meeting/index.js.map +1 -1
- package/dist/meeting/locusMediaRequest.js +292 -0
- package/dist/meeting/locusMediaRequest.js.map +1 -0
- package/dist/meeting/muteState.js +230 -124
- package/dist/meeting/muteState.js.map +1 -1
- package/dist/meeting/request.js +260 -196
- package/dist/meeting/request.js.map +1 -1
- package/dist/meeting/util.js +601 -417
- package/dist/meeting/util.js.map +1 -1
- package/dist/meeting-info/index.js +73 -7
- package/dist/meeting-info/index.js.map +1 -1
- package/dist/meeting-info/meeting-info-v2.js +192 -51
- package/dist/meeting-info/meeting-info-v2.js.map +1 -1
- package/dist/meeting-info/util.js +1 -1
- package/dist/meeting-info/util.js.map +1 -1
- package/dist/meeting-info/utilv2.js +36 -36
- package/dist/meeting-info/utilv2.js.map +1 -1
- package/dist/meetings/collection.js +39 -0
- package/dist/meetings/collection.js.map +1 -1
- package/dist/meetings/index.js +415 -115
- 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 +2 -0
- package/dist/meetings/request.js.map +1 -1
- package/dist/meetings/util.js +72 -6
- package/dist/meetings/util.js.map +1 -1
- package/dist/member/index.js +58 -0
- package/dist/member/index.js.map +1 -1
- package/dist/member/types.js +25 -0
- package/dist/member/types.js.map +1 -0
- package/dist/member/util.js +132 -25
- 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 +102 -6
- package/dist/members/index.js.map +1 -1
- package/dist/members/request.js +106 -38
- 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 +326 -232
- package/dist/members/util.js.map +1 -1
- package/dist/metrics/constants.js +13 -5
- package/dist/metrics/constants.js.map +1 -1
- package/dist/metrics/index.js +1 -468
- package/dist/metrics/index.js.map +1 -1
- package/dist/multistream/mediaRequestManager.js +238 -49
- package/dist/multistream/mediaRequestManager.js.map +1 -1
- package/dist/multistream/receiveSlot.js +29 -16
- package/dist/multistream/receiveSlot.js.map +1 -1
- package/dist/multistream/receiveSlotManager.js +39 -36
- 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 +209 -59
- package/dist/multistream/remoteMediaManager.js.map +1 -1
- package/dist/multistream/sendSlotManager.js +233 -0
- package/dist/multistream/sendSlotManager.js.map +1 -0
- package/dist/reachability/index.js +225 -59
- package/dist/reachability/index.js.map +1 -1
- package/dist/reachability/request.js +17 -8
- package/dist/reachability/request.js.map +1 -1
- package/dist/reconnection-manager/index.js +201 -156
- package/dist/reconnection-manager/index.js.map +1 -1
- package/dist/recording-controller/index.js +21 -2
- package/dist/recording-controller/index.js.map +1 -1
- package/dist/recording-controller/util.js +9 -8
- package/dist/recording-controller/util.js.map +1 -1
- package/dist/roap/index.js +62 -32
- package/dist/roap/index.js.map +1 -1
- package/dist/roap/request.js +112 -97
- package/dist/roap/request.js.map +1 -1
- package/dist/roap/turnDiscovery.js +95 -36
- package/dist/roap/turnDiscovery.js.map +1 -1
- package/dist/rtcMetrics/constants.js +12 -0
- package/dist/rtcMetrics/constants.js.map +1 -0
- package/dist/rtcMetrics/index.js +117 -0
- package/dist/rtcMetrics/index.js.map +1 -0
- package/dist/statsAnalyzer/index.js +86 -78
- package/dist/statsAnalyzer/index.js.map +1 -1
- package/dist/statsAnalyzer/mqaUtil.js +11 -10
- package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
- package/dist/types/annotation/annotation.types.d.ts +42 -0
- package/dist/types/annotation/constants.d.ts +31 -0
- package/dist/types/annotation/index.d.ts +117 -0
- package/dist/types/breakouts/edit-lock-error.d.ts +15 -0
- package/dist/types/breakouts/events.d.ts +8 -0
- package/dist/types/breakouts/utils.d.ts +14 -0
- package/dist/types/common/errors/no-meeting-info.d.ts +14 -0
- package/dist/types/common/errors/reclaim-host-role-errors.d.ts +60 -0
- package/dist/types/common/errors/webex-errors.d.ts +25 -1
- package/dist/types/common/logs/request.d.ts +2 -0
- package/dist/types/common/queue.d.ts +9 -7
- package/dist/types/config.d.ts +1 -7
- package/dist/types/constants.d.ts +194 -24
- package/dist/types/controls-options-manager/enums.d.ts +11 -1
- package/dist/types/controls-options-manager/index.d.ts +17 -1
- package/dist/types/controls-options-manager/types.d.ts +43 -0
- package/dist/types/controls-options-manager/util.d.ts +1 -7
- package/dist/types/index.d.ts +6 -4
- package/dist/types/interpretation/collection.d.ts +5 -0
- package/dist/types/interpretation/index.d.ts +5 -0
- package/dist/types/interpretation/siLanguage.d.ts +5 -0
- package/dist/types/locus-info/index.d.ts +57 -4
- package/dist/types/locus-info/parser.d.ts +67 -6
- package/dist/types/media/index.d.ts +2 -0
- package/dist/types/media/properties.d.ts +34 -48
- package/dist/types/meeting/in-meeting-actions.d.ts +82 -2
- package/dist/types/meeting/index.d.ts +463 -510
- package/dist/types/meeting/locusMediaRequest.d.ts +74 -0
- package/dist/types/meeting/muteState.d.ts +99 -23
- package/dist/types/meeting/request.d.ts +72 -43
- package/dist/types/meeting/util.d.ts +101 -1
- package/dist/types/meeting-info/index.d.ts +13 -1
- package/dist/types/meeting-info/meeting-info-v2.d.ts +31 -1
- package/dist/types/meetings/collection.d.ts +17 -0
- package/dist/types/meetings/index.d.ts +98 -20
- package/dist/types/meetings/meetings.types.d.ts +4 -0
- package/dist/types/member/index.d.ts +14 -0
- package/dist/types/member/types.d.ts +32 -0
- package/dist/types/members/collection.d.ts +5 -0
- package/dist/types/members/index.d.ts +35 -2
- package/dist/types/members/request.d.ts +73 -9
- package/dist/types/members/types.d.ts +25 -0
- package/dist/types/members/util.d.ts +214 -1
- package/dist/types/metrics/constants.d.ts +12 -4
- package/dist/types/metrics/index.d.ts +4 -119
- package/dist/types/multistream/mediaRequestManager.d.ts +73 -5
- package/dist/types/multistream/receiveSlot.d.ts +13 -11
- package/dist/types/multistream/receiveSlotManager.d.ts +14 -4
- package/dist/types/multistream/remoteMedia.d.ts +8 -29
- package/dist/types/multistream/remoteMediaGroup.d.ts +0 -9
- package/dist/types/multistream/remoteMediaManager.d.ts +46 -2
- package/dist/types/multistream/sendSlotManager.d.ts +61 -0
- package/dist/types/reachability/index.d.ts +61 -7
- package/dist/types/reachability/request.d.ts +7 -3
- package/dist/types/reconnection-manager/index.d.ts +9 -0
- package/dist/types/recording-controller/index.d.ts +15 -1
- package/dist/types/recording-controller/util.d.ts +5 -4
- package/dist/types/roap/index.d.ts +2 -1
- package/dist/types/roap/request.d.ts +15 -11
- package/dist/types/roap/turnDiscovery.d.ts +21 -3
- package/dist/types/rtcMetrics/constants.d.ts +4 -0
- package/dist/types/rtcMetrics/index.d.ts +47 -0
- package/dist/types/statsAnalyzer/index.d.ts +7 -1
- package/dist/types/webinar/collection.d.ts +16 -0
- package/dist/types/webinar/index.d.ts +5 -0
- package/dist/webinar/collection.js +44 -0
- package/dist/webinar/collection.js.map +1 -0
- package/dist/webinar/index.js +69 -0
- package/dist/webinar/index.js.map +1 -0
- package/package.json +23 -20
- package/src/annotation/annotation.types.ts +50 -0
- package/src/annotation/constants.ts +36 -0
- package/src/annotation/index.ts +328 -0
- package/src/breakouts/README.md +42 -12
- package/src/breakouts/breakout.ts +67 -9
- package/src/breakouts/edit-lock-error.ts +25 -0
- package/src/breakouts/events.ts +56 -0
- package/src/breakouts/index.ts +592 -20
- package/src/breakouts/utils.ts +42 -0
- package/src/common/errors/no-meeting-info.ts +24 -0
- package/src/common/errors/reclaim-host-role-errors.ts +134 -0
- package/src/common/errors/webex-errors.ts +44 -2
- package/src/common/logs/logger-proxy.ts +1 -1
- package/src/common/logs/request.ts +5 -1
- package/src/common/queue.ts +22 -8
- package/src/config.ts +4 -10
- package/src/constants.ts +221 -19
- package/src/controls-options-manager/enums.ts +12 -0
- package/src/controls-options-manager/index.ts +116 -21
- package/src/controls-options-manager/types.ts +59 -0
- package/src/controls-options-manager/util.ts +294 -14
- package/src/index.ts +40 -0
- package/src/interpretation/README.md +60 -0
- package/src/interpretation/collection.ts +19 -0
- package/src/interpretation/index.ts +332 -0
- package/src/interpretation/siLanguage.ts +18 -0
- package/src/locus-info/controlsUtils.ts +108 -0
- package/src/locus-info/index.ts +413 -59
- package/src/locus-info/infoUtils.ts +10 -2
- package/src/locus-info/mediaSharesUtils.ts +64 -0
- package/src/locus-info/parser.ts +258 -47
- package/src/locus-info/selfUtils.ts +81 -5
- package/src/media/index.ts +102 -122
- package/src/media/properties.ts +87 -110
- package/src/meeting/in-meeting-actions.ts +163 -3
- package/src/meeting/index.ts +3132 -2541
- package/src/meeting/locusMediaRequest.ts +313 -0
- package/src/meeting/muteState.ts +229 -131
- package/src/meeting/request.ts +177 -121
- package/src/meeting/util.ts +588 -394
- package/src/meeting-info/index.ts +81 -8
- package/src/meeting-info/meeting-info-v2.ts +170 -14
- package/src/meeting-info/util.ts +1 -1
- package/src/meeting-info/utilv2.ts +23 -23
- package/src/meetings/collection.ts +33 -0
- package/src/meetings/index.ts +445 -123
- package/src/meetings/meetings.types.ts +12 -0
- package/src/meetings/request.ts +2 -0
- package/src/meetings/util.ts +80 -11
- package/src/member/index.ts +58 -0
- package/src/member/types.ts +38 -0
- package/src/member/util.ts +141 -25
- package/src/members/collection.ts +8 -0
- package/src/members/index.ts +134 -8
- package/src/members/request.ts +97 -17
- package/src/members/types.ts +29 -0
- package/src/members/util.ts +333 -240
- package/src/metrics/constants.ts +12 -4
- package/src/metrics/index.ts +1 -490
- package/src/multistream/mediaRequestManager.ts +289 -79
- package/src/multistream/receiveSlot.ts +31 -17
- package/src/multistream/receiveSlotManager.ts +34 -24
- package/src/multistream/remoteMedia.ts +27 -2
- package/src/multistream/remoteMediaGroup.ts +59 -0
- package/src/multistream/remoteMediaManager.ts +148 -30
- package/src/multistream/sendSlotManager.ts +170 -0
- package/src/reachability/index.ts +228 -37
- package/src/reachability/request.ts +17 -8
- package/src/reconnection-manager/index.ts +83 -56
- package/src/recording-controller/index.ts +20 -3
- package/src/recording-controller/util.ts +26 -9
- package/src/roap/index.ts +63 -32
- package/src/roap/request.ts +100 -104
- package/src/roap/turnDiscovery.ts +48 -26
- package/src/rtcMetrics/constants.ts +3 -0
- package/src/rtcMetrics/index.ts +100 -0
- package/src/statsAnalyzer/index.ts +105 -91
- package/src/statsAnalyzer/mqaUtil.ts +13 -14
- package/src/webinar/collection.ts +31 -0
- package/src/webinar/index.ts +62 -0
- package/test/integration/spec/converged-space-meetings.js +60 -3
- package/test/integration/spec/journey.js +320 -261
- package/test/integration/spec/space-meeting.js +76 -3
- package/test/unit/spec/annotation/index.ts +418 -0
- package/test/unit/spec/breakouts/breakout.ts +118 -28
- package/test/unit/spec/breakouts/edit-lock-error.ts +30 -0
- package/test/unit/spec/breakouts/events.ts +89 -0
- package/test/unit/spec/breakouts/index.ts +1395 -69
- package/test/unit/spec/breakouts/utils.js +52 -1
- package/test/unit/spec/common/queue.js +31 -2
- package/test/unit/spec/controls-options-manager/index.js +163 -0
- package/test/unit/spec/controls-options-manager/util.js +576 -60
- package/test/unit/spec/fixture/locus.js +1 -0
- package/test/unit/spec/interpretation/collection.ts +15 -0
- package/test/unit/spec/interpretation/index.ts +589 -0
- package/test/unit/spec/interpretation/siLanguage.ts +28 -0
- package/test/unit/spec/locus-info/controlsUtils.js +316 -43
- package/test/unit/spec/locus-info/index.js +1304 -33
- package/test/unit/spec/locus-info/infoUtils.js +37 -15
- package/test/unit/spec/locus-info/lib/SeqCmp.json +16 -0
- package/test/unit/spec/locus-info/mediaSharesUtils.ts +32 -0
- package/test/unit/spec/locus-info/parser.js +116 -35
- package/test/unit/spec/locus-info/selfConstant.js +27 -4
- package/test/unit/spec/locus-info/selfUtils.js +208 -17
- package/test/unit/spec/media/index.ts +104 -37
- package/test/unit/spec/media/properties.ts +2 -2
- package/test/unit/spec/meeting/in-meeting-actions.ts +81 -3
- package/test/unit/spec/meeting/index.js +5216 -1956
- package/test/unit/spec/meeting/locusMediaRequest.ts +442 -0
- package/test/unit/spec/meeting/muteState.js +408 -208
- package/test/unit/spec/meeting/request.js +483 -49
- package/test/unit/spec/meeting/utils.js +679 -64
- package/test/unit/spec/meeting-info/index.js +300 -0
- package/test/unit/spec/meeting-info/meetinginfov2.js +526 -5
- package/test/unit/spec/meeting-info/utilv2.js +21 -0
- package/test/unit/spec/meetings/collection.js +26 -0
- package/test/unit/spec/meetings/index.js +1011 -205
- package/test/unit/spec/meetings/utils.js +202 -2
- package/test/unit/spec/member/index.js +61 -6
- package/test/unit/spec/member/util.js +510 -34
- package/test/unit/spec/members/index.js +432 -1
- package/test/unit/spec/members/request.js +206 -27
- package/test/unit/spec/members/utils.js +210 -0
- package/test/unit/spec/metrics/index.js +1 -50
- package/test/unit/spec/multistream/mediaRequestManager.ts +803 -162
- package/test/unit/spec/multistream/receiveSlot.ts +28 -20
- package/test/unit/spec/multistream/receiveSlotManager.ts +32 -30
- package/test/unit/spec/multistream/remoteMedia.ts +30 -0
- package/test/unit/spec/multistream/remoteMediaGroup.ts +266 -0
- package/test/unit/spec/multistream/remoteMediaManager.ts +326 -0
- package/test/unit/spec/multistream/sendSlotManager.ts +242 -0
- package/test/unit/spec/reachability/index.ts +549 -9
- package/test/unit/spec/reachability/request.js +68 -0
- package/test/unit/spec/reconnection-manager/index.js +85 -9
- package/test/unit/spec/recording-controller/index.js +294 -218
- package/test/unit/spec/recording-controller/util.js +223 -96
- package/test/unit/spec/roap/index.ts +178 -64
- package/test/unit/spec/roap/request.ts +203 -85
- package/test/unit/spec/roap/turnDiscovery.ts +82 -36
- package/test/unit/spec/rtcMetrics/index.ts +73 -0
- package/test/unit/spec/stats-analyzer/index.js +136 -2
- package/test/unit/spec/webinar/collection.ts +13 -0
- package/test/unit/spec/webinar/index.ts +60 -0
- package/test/utils/integrationTestUtils.js +46 -0
- package/test/utils/testUtils.js +0 -52
- package/dist/meeting/effectsState.js +0 -262
- package/dist/meeting/effectsState.js.map +0 -1
- package/dist/metrics/config.js +0 -299
- package/dist/metrics/config.js.map +0 -1
- package/dist/types/meeting/effectsState.d.ts +0 -42
- package/dist/types/metrics/config.d.ts +0 -178
- package/src/index.js +0 -16
- package/src/meeting/effectsState.ts +0 -211
- package/src/metrics/config.ts +0 -495
- package/test/unit/spec/meeting/effectsState.js +0 -285
|
@@ -0,0 +1,442 @@
|
|
|
1
|
+
import sinon from 'sinon';
|
|
2
|
+
import {assert} from '@webex/test-helper-chai';
|
|
3
|
+
import { cloneDeep, defer } from 'lodash';
|
|
4
|
+
|
|
5
|
+
import MockWebex from '@webex/test-helper-mock-webex';
|
|
6
|
+
import Meetings from '@webex/plugin-meetings';
|
|
7
|
+
import { LocalMuteRequest, LocusMediaRequest, RoapRequest } from "@webex/plugin-meetings/src/meeting/locusMediaRequest";
|
|
8
|
+
import testUtils from '../../../utils/testUtils';
|
|
9
|
+
import { Defer } from '@webex/common';
|
|
10
|
+
import { IP_VERSION } from '../../../../src/constants';
|
|
11
|
+
|
|
12
|
+
describe('LocusMediaRequest.send()', () => {
|
|
13
|
+
let locusMediaRequest: LocusMediaRequest;
|
|
14
|
+
let webexRequestStub;
|
|
15
|
+
let mockWebex;
|
|
16
|
+
|
|
17
|
+
const fakeLocusResponse = {
|
|
18
|
+
locus: { something: 'whatever'}
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
const exampleRoapRequestBody:RoapRequest = {
|
|
22
|
+
type: 'RoapMessage',
|
|
23
|
+
mediaId: 'mediaId',
|
|
24
|
+
selfUrl: 'fakeMeetingSelfUrl',
|
|
25
|
+
roapMessage: {
|
|
26
|
+
messageType: 'OFFER',
|
|
27
|
+
sdps: ['sdp'],
|
|
28
|
+
version: '2',
|
|
29
|
+
seq: 1,
|
|
30
|
+
tieBreaker: 0xfffffffe,
|
|
31
|
+
},
|
|
32
|
+
reachability: {
|
|
33
|
+
'wjfkm.wjfkm.*': {udp:{reachable: true}, tcp:{reachable:false}},
|
|
34
|
+
'1eb65fdf-9643-417f-9974-ad72cae0e10f.59268c12-7a04-4b23-a1a1-4c74be03019a.*': {udp:{reachable: false}, tcp:{reachable:true}},
|
|
35
|
+
},
|
|
36
|
+
joinCookie: {
|
|
37
|
+
anycastEntryPoint: 'aws-eu-west-1',
|
|
38
|
+
clientIpAddress: 'some ip',
|
|
39
|
+
timeShot: '2023-05-23T08:03:49Z',
|
|
40
|
+
},
|
|
41
|
+
ipVersion: IP_VERSION.only_ipv4,
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
const createExpectedRoapBody = (expectedMessageType, expectedMute:{audioMuted: boolean, videoMuted: boolean}) => {
|
|
45
|
+
return {
|
|
46
|
+
device: { url: 'deviceUrl', deviceType: 'deviceType', regionCode: 'regionCode' },
|
|
47
|
+
correlationId: 'correlationId',
|
|
48
|
+
localMedias: [
|
|
49
|
+
{
|
|
50
|
+
localSdp: `{"audioMuted":${expectedMute.audioMuted},"videoMuted":${expectedMute.videoMuted},"roapMessage":{"messageType":"${expectedMessageType}","sdps":["sdp"],"version":"2","seq":1,"tieBreaker":4294967294},"reachability":{"wjfkm.wjfkm.*":{"udp":{"reachable":true},"tcp":{"reachable":false}},"1eb65fdf-9643-417f-9974-ad72cae0e10f.59268c12-7a04-4b23-a1a1-4c74be03019a.*":{"udp":{"reachable":false},"tcp":{"reachable":true}}}}`,
|
|
51
|
+
mediaId: 'mediaId'
|
|
52
|
+
}
|
|
53
|
+
],
|
|
54
|
+
clientMediaPreferences: {
|
|
55
|
+
preferTranscoding: true,
|
|
56
|
+
ipver: 4,
|
|
57
|
+
joinCookie: {
|
|
58
|
+
anycastEntryPoint: 'aws-eu-west-1',
|
|
59
|
+
clientIpAddress: 'some ip',
|
|
60
|
+
timeShot: '2023-05-23T08:03:49Z'
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
const exampleLocalMuteRequestBody:LocalMuteRequest = {
|
|
67
|
+
type: 'LocalMute',
|
|
68
|
+
mediaId: 'mediaId',
|
|
69
|
+
selfUrl: 'fakeMeetingSelfUrl',
|
|
70
|
+
muteOptions: {},
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
const createExpectedLocalMuteBody = (expectedMute:{audioMuted: boolean, videoMuted: boolean}, sequence = undefined) => {
|
|
74
|
+
const body: any = {
|
|
75
|
+
device: {
|
|
76
|
+
url: 'deviceUrl',
|
|
77
|
+
deviceType: 'deviceType',
|
|
78
|
+
regionCode: 'regionCode',
|
|
79
|
+
},
|
|
80
|
+
correlationId: 'correlationId',
|
|
81
|
+
usingResource: null,
|
|
82
|
+
respOnlySdp: true,
|
|
83
|
+
localMedias: [
|
|
84
|
+
{
|
|
85
|
+
mediaId: 'mediaId',
|
|
86
|
+
localSdp: `{"audioMuted":${expectedMute.audioMuted},"videoMuted":${expectedMute.videoMuted}}`,
|
|
87
|
+
},
|
|
88
|
+
],
|
|
89
|
+
clientMediaPreferences: {
|
|
90
|
+
preferTranscoding: true,
|
|
91
|
+
ipver: undefined,
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
if (sequence) {
|
|
96
|
+
body.sequence = sequence;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return body;
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
beforeEach(() => {
|
|
103
|
+
mockWebex = new MockWebex({
|
|
104
|
+
children: {
|
|
105
|
+
meetings: Meetings,
|
|
106
|
+
},
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
locusMediaRequest = new LocusMediaRequest({
|
|
110
|
+
device: {
|
|
111
|
+
url: 'deviceUrl',
|
|
112
|
+
deviceType: 'deviceType',
|
|
113
|
+
regionCode: 'regionCode',
|
|
114
|
+
},
|
|
115
|
+
correlationId: 'correlationId',
|
|
116
|
+
preferTranscoding: true,
|
|
117
|
+
}, {
|
|
118
|
+
parent: mockWebex,
|
|
119
|
+
});
|
|
120
|
+
webexRequestStub = sinon.stub(locusMediaRequest, 'request').resolves(fakeLocusResponse);
|
|
121
|
+
})
|
|
122
|
+
|
|
123
|
+
const sendLocalMute = (muteOptions, overrides={}) => locusMediaRequest.send({...exampleLocalMuteRequestBody, ...overrides, muteOptions});
|
|
124
|
+
|
|
125
|
+
const sendRoapMessage = (messageType) => {
|
|
126
|
+
const request = cloneDeep(exampleRoapRequestBody);
|
|
127
|
+
|
|
128
|
+
request.roapMessage.messageType = messageType;
|
|
129
|
+
return locusMediaRequest.send(request);
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/** Helper function that makes sure the LocusMediaRequest.confluenceState is 'created' */
|
|
133
|
+
const ensureConfluenceCreated = async () => {
|
|
134
|
+
await sendRoapMessage('OFFER');
|
|
135
|
+
|
|
136
|
+
webexRequestStub.resetHistory();
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
it('sends a roap message', async () => {
|
|
140
|
+
const result = await sendRoapMessage('OFFER');
|
|
141
|
+
|
|
142
|
+
assert.equal(result, fakeLocusResponse);
|
|
143
|
+
|
|
144
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
145
|
+
method: 'PUT',
|
|
146
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
147
|
+
body: createExpectedRoapBody('OFFER', {audioMuted: true, videoMuted: true}),
|
|
148
|
+
});
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
it('sends a local mute request', async () => {
|
|
152
|
+
await ensureConfluenceCreated();
|
|
153
|
+
|
|
154
|
+
const result = await sendLocalMute({audioMuted: false, videoMuted: false});
|
|
155
|
+
|
|
156
|
+
assert.equal(result, fakeLocusResponse);
|
|
157
|
+
|
|
158
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
159
|
+
method: 'PUT',
|
|
160
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
161
|
+
body: createExpectedLocalMuteBody({audioMuted: false, videoMuted: false}),
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
it('sends a local mute request with sequence', async () => {
|
|
166
|
+
await ensureConfluenceCreated();
|
|
167
|
+
|
|
168
|
+
const sequence = {some: 'sequence data'};
|
|
169
|
+
|
|
170
|
+
const result = await sendLocalMute({audioMuted: false, videoMuted: false}, {sequence});
|
|
171
|
+
|
|
172
|
+
assert.equal(result, fakeLocusResponse);
|
|
173
|
+
|
|
174
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
175
|
+
method: 'PUT',
|
|
176
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
177
|
+
body: createExpectedLocalMuteBody({audioMuted: false, videoMuted: false}, sequence),
|
|
178
|
+
});
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
it('sends a local mute request with the last audio/video mute values when called multiple times in same processing cycle', async () => {
|
|
182
|
+
await ensureConfluenceCreated();
|
|
183
|
+
|
|
184
|
+
let result1;
|
|
185
|
+
let result2;
|
|
186
|
+
|
|
187
|
+
const promise1 = sendLocalMute({audioMuted: true, videoMuted: false})
|
|
188
|
+
.then((result) => {
|
|
189
|
+
result1 = result;
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
const promise2 = sendLocalMute({audioMuted: false, videoMuted: true})
|
|
193
|
+
.then((result) => {
|
|
194
|
+
result2 = result;
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
await testUtils.flushPromises();
|
|
198
|
+
|
|
199
|
+
await promise1;
|
|
200
|
+
await promise2;
|
|
201
|
+
assert.equal(result1, fakeLocusResponse);
|
|
202
|
+
assert.equal(result2, fakeLocusResponse);
|
|
203
|
+
|
|
204
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
205
|
+
method: 'PUT',
|
|
206
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
207
|
+
body: createExpectedLocalMuteBody({audioMuted: false, videoMuted: true}),
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
});
|
|
211
|
+
|
|
212
|
+
it('sends a local mute request with the last audio/video mute values', async () => {
|
|
213
|
+
await ensureConfluenceCreated();
|
|
214
|
+
|
|
215
|
+
await Promise.all([
|
|
216
|
+
sendLocalMute({audioMuted: undefined, videoMuted: false}),
|
|
217
|
+
sendLocalMute({audioMuted: true, videoMuted: undefined}),
|
|
218
|
+
sendLocalMute({audioMuted: false, videoMuted: true}),
|
|
219
|
+
sendLocalMute({audioMuted: true, videoMuted: false}),
|
|
220
|
+
]);
|
|
221
|
+
|
|
222
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
223
|
+
method: 'PUT',
|
|
224
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
225
|
+
body: createExpectedLocalMuteBody({audioMuted: true, videoMuted: false}),
|
|
226
|
+
});
|
|
227
|
+
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
it('sends only roap when roap and local mute are requested', async () => {
|
|
231
|
+
await Promise.all([
|
|
232
|
+
sendLocalMute({audioMuted: false, videoMuted: undefined}),
|
|
233
|
+
sendRoapMessage('OFFER'),
|
|
234
|
+
sendLocalMute({audioMuted: true, videoMuted: false}),
|
|
235
|
+
]);
|
|
236
|
+
|
|
237
|
+
/* check that only the roap message was sent and it had the last
|
|
238
|
+
values for audio and video mute
|
|
239
|
+
*/
|
|
240
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
241
|
+
method: 'PUT',
|
|
242
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
243
|
+
body: createExpectedRoapBody('OFFER', {audioMuted: true, videoMuted: false}),
|
|
244
|
+
});
|
|
245
|
+
});
|
|
246
|
+
|
|
247
|
+
describe('queueing', () => {
|
|
248
|
+
let clock;
|
|
249
|
+
let requestsToLocus;
|
|
250
|
+
let results;
|
|
251
|
+
|
|
252
|
+
beforeEach(() => {
|
|
253
|
+
clock = sinon.useFakeTimers();
|
|
254
|
+
requestsToLocus = [];
|
|
255
|
+
results = [];
|
|
256
|
+
|
|
257
|
+
// setup the mock so that each new request that we send to Locus,
|
|
258
|
+
// returns a promise that we control from this test
|
|
259
|
+
webexRequestStub.callsFake(() => {
|
|
260
|
+
const defer = new Defer();
|
|
261
|
+
requestsToLocus.push(defer);
|
|
262
|
+
return defer.promise;
|
|
263
|
+
});
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
afterEach(() => {
|
|
267
|
+
clock.restore();
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
/** LocusMediaRequest.send() uses Lodash.defer(), so it only starts sending any requests
|
|
271
|
+
* after the processing cycle from which it was called is finished.
|
|
272
|
+
* This helper function waits for this to happen - it's needed, because we're using
|
|
273
|
+
* fake timers in these tests
|
|
274
|
+
*/
|
|
275
|
+
const ensureQueueProcessingIsStarted = () => {
|
|
276
|
+
clock.tick(1);
|
|
277
|
+
}
|
|
278
|
+
it('queues requests if there is one already in progress', async () => {
|
|
279
|
+
results.push(sendRoapMessage('OFFER'));
|
|
280
|
+
|
|
281
|
+
ensureQueueProcessingIsStarted();
|
|
282
|
+
|
|
283
|
+
// check that OFFER has been sent out
|
|
284
|
+
assert.calledWith(webexRequestStub, {
|
|
285
|
+
method: 'PUT',
|
|
286
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
287
|
+
body: createExpectedRoapBody('OFFER', {audioMuted: true, videoMuted: true}),
|
|
288
|
+
});
|
|
289
|
+
|
|
290
|
+
webexRequestStub.resetHistory();
|
|
291
|
+
|
|
292
|
+
// at this point the request should be sent out and "in progress",
|
|
293
|
+
// so any further calls should be queued
|
|
294
|
+
results.push(sendRoapMessage('OK'));
|
|
295
|
+
|
|
296
|
+
// OK should not be sent out yet, only queued
|
|
297
|
+
assert.notCalled(webexRequestStub);
|
|
298
|
+
|
|
299
|
+
// now simulate the first locus request (offer) to resolve,
|
|
300
|
+
// so that the next request from the queue (ok) can be sent out
|
|
301
|
+
requestsToLocus[0].resolve();
|
|
302
|
+
await testUtils.flushPromises();
|
|
303
|
+
ensureQueueProcessingIsStarted();
|
|
304
|
+
|
|
305
|
+
// verify OK was sent out
|
|
306
|
+
assert.calledWith(webexRequestStub, {
|
|
307
|
+
method: 'PUT',
|
|
308
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
309
|
+
body: createExpectedRoapBody('OK', {audioMuted: true, videoMuted: true}),
|
|
310
|
+
});
|
|
311
|
+
|
|
312
|
+
// promise returned by the first call to send OFFER should be resolved by now
|
|
313
|
+
await results[0];
|
|
314
|
+
|
|
315
|
+
// simulate Locus sending http response to OK
|
|
316
|
+
requestsToLocus[1].resolve();
|
|
317
|
+
await results[1];
|
|
318
|
+
});
|
|
319
|
+
|
|
320
|
+
it('combines local mute requests into a single /media request to Locus when queueing', async () => {
|
|
321
|
+
results.push(sendRoapMessage('OFFER'));
|
|
322
|
+
results.push(sendLocalMute({audioMuted: false, videoMuted: false}));
|
|
323
|
+
|
|
324
|
+
ensureQueueProcessingIsStarted();
|
|
325
|
+
|
|
326
|
+
// check that OFFER and local mute have been combined into
|
|
327
|
+
// a single OFFER request with the right mute values
|
|
328
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
329
|
+
method: 'PUT',
|
|
330
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
331
|
+
body: createExpectedRoapBody('OFFER', {audioMuted: false, videoMuted: false}),
|
|
332
|
+
});
|
|
333
|
+
|
|
334
|
+
webexRequestStub.resetHistory();
|
|
335
|
+
|
|
336
|
+
// at this point the request should be sent out and "in progress",
|
|
337
|
+
// so any further calls should be queued
|
|
338
|
+
results.push(sendLocalMute({audioMuted: true, videoMuted: false}));
|
|
339
|
+
results.push(sendRoapMessage('OK'));
|
|
340
|
+
results.push(sendLocalMute({audioMuted: false, videoMuted: true}));
|
|
341
|
+
|
|
342
|
+
// nothing should be sent out yet, only queued
|
|
343
|
+
assert.notCalled(webexRequestStub);
|
|
344
|
+
|
|
345
|
+
// now simulate the first locus request (offer) to resolve,
|
|
346
|
+
// so that the next request from the queue (ok) can be sent out
|
|
347
|
+
requestsToLocus[0].resolve();
|
|
348
|
+
await testUtils.flushPromises();
|
|
349
|
+
ensureQueueProcessingIsStarted();
|
|
350
|
+
|
|
351
|
+
// verify OK was sent out
|
|
352
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
353
|
+
method: 'PUT',
|
|
354
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
355
|
+
body: createExpectedRoapBody('OK', {audioMuted: false, videoMuted: true}),
|
|
356
|
+
});
|
|
357
|
+
|
|
358
|
+
// promise returned by the first call to send OFFER should be resolved by now
|
|
359
|
+
await results[0];
|
|
360
|
+
|
|
361
|
+
// simulate Locus sending http response to OK
|
|
362
|
+
requestsToLocus[1].resolve();
|
|
363
|
+
await results[1];
|
|
364
|
+
});
|
|
365
|
+
|
|
366
|
+
describe('confluence creation', () => {
|
|
367
|
+
it('resolves without sending the request if LocalMute is requested before Roap Offer is sent (confluence state is "not created")', async () => {
|
|
368
|
+
const result = await sendLocalMute({audioMuted: false, videoMuted: true});
|
|
369
|
+
|
|
370
|
+
assert.notCalled(webexRequestStub);
|
|
371
|
+
assert.deepEqual(result, {});
|
|
372
|
+
});
|
|
373
|
+
|
|
374
|
+
it('queues LocalMute if requested after first Roap Offer was sent but before it got http response (confluence state is "creation in progress")', async () => {
|
|
375
|
+
let result;
|
|
376
|
+
|
|
377
|
+
// send roap offer so that confluence state is "creation in progress"
|
|
378
|
+
sendRoapMessage('OFFER');
|
|
379
|
+
|
|
380
|
+
ensureQueueProcessingIsStarted();
|
|
381
|
+
|
|
382
|
+
sendLocalMute({audioMuted: false, videoMuted: true})
|
|
383
|
+
.then((response) => {
|
|
384
|
+
result = response;
|
|
385
|
+
});
|
|
386
|
+
|
|
387
|
+
// only roap offer should have been sent so far
|
|
388
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
389
|
+
method: 'PUT',
|
|
390
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
391
|
+
body: createExpectedRoapBody('OFFER', {audioMuted: true, videoMuted: true}),
|
|
392
|
+
});
|
|
393
|
+
assert.equal(result, undefined); // sendLocalMute shouldn't resolve yet, as the request should be queued
|
|
394
|
+
|
|
395
|
+
// now let the Offer be completed - so confluence state will be "complete"
|
|
396
|
+
webexRequestStub.resetHistory();
|
|
397
|
+
requestsToLocus[0].resolve({});
|
|
398
|
+
await testUtils.flushPromises();
|
|
399
|
+
|
|
400
|
+
// now the queued up local mute request should have been sent out
|
|
401
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
402
|
+
method: 'PUT',
|
|
403
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
404
|
+
body: createExpectedLocalMuteBody({audioMuted: false, videoMuted: true}),
|
|
405
|
+
});
|
|
406
|
+
|
|
407
|
+
// check also the result once Locus replies to local mute
|
|
408
|
+
const fakeLocusResponse = { response: 'ok'};
|
|
409
|
+
requestsToLocus[1].resolve(fakeLocusResponse);
|
|
410
|
+
await testUtils.flushPromises();
|
|
411
|
+
assert.deepEqual(result, fakeLocusResponse);
|
|
412
|
+
});
|
|
413
|
+
});
|
|
414
|
+
|
|
415
|
+
it('sends LocalMute request if Offer was already sent and Locus replied (confluence state is "completed")', async () => {
|
|
416
|
+
let result;
|
|
417
|
+
|
|
418
|
+
// send roap offer and ensure it's completed
|
|
419
|
+
sendRoapMessage('OFFER');
|
|
420
|
+
ensureQueueProcessingIsStarted();
|
|
421
|
+
requestsToLocus[0].resolve({});
|
|
422
|
+
await testUtils.flushPromises();
|
|
423
|
+
webexRequestStub.resetHistory();
|
|
424
|
+
|
|
425
|
+
// now send local mute
|
|
426
|
+
sendLocalMute({audioMuted: false, videoMuted: true})
|
|
427
|
+
.then((response) => {
|
|
428
|
+
result = response;
|
|
429
|
+
});
|
|
430
|
+
|
|
431
|
+
ensureQueueProcessingIsStarted();
|
|
432
|
+
|
|
433
|
+
// it should be sent out
|
|
434
|
+
assert.calledOnceWithExactly(webexRequestStub, {
|
|
435
|
+
method: 'PUT',
|
|
436
|
+
uri: 'fakeMeetingSelfUrl/media',
|
|
437
|
+
body: createExpectedLocalMuteBody({audioMuted: false, videoMuted: true}),
|
|
438
|
+
});
|
|
439
|
+
});
|
|
440
|
+
|
|
441
|
+
});
|
|
442
|
+
})
|