@webex/plugin-meetings 3.7.0 → 3.8.0-next.1

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 (198) hide show
  1. package/dist/annotation/index.js +17 -0
  2. package/dist/annotation/index.js.map +1 -1
  3. package/dist/breakouts/breakout.js +1 -1
  4. package/dist/breakouts/index.js +1 -1
  5. package/dist/common/errors/join-forbidden-error.js +52 -0
  6. package/dist/common/errors/join-forbidden-error.js.map +1 -0
  7. package/dist/common/errors/{webinar-registration-error.js → join-webinar-error.js} +12 -12
  8. package/dist/common/errors/join-webinar-error.js.map +1 -0
  9. package/dist/common/errors/multistream-not-supported-error.js +53 -0
  10. package/dist/common/errors/multistream-not-supported-error.js.map +1 -0
  11. package/dist/config.js +2 -1
  12. package/dist/config.js.map +1 -1
  13. package/dist/constants.js +68 -6
  14. package/dist/constants.js.map +1 -1
  15. package/dist/index.js +16 -11
  16. package/dist/index.js.map +1 -1
  17. package/dist/interpretation/index.js +1 -1
  18. package/dist/interpretation/siLanguage.js +1 -1
  19. package/dist/locus-info/index.js +14 -3
  20. package/dist/locus-info/index.js.map +1 -1
  21. package/dist/locus-info/selfUtils.js +35 -17
  22. package/dist/locus-info/selfUtils.js.map +1 -1
  23. package/dist/media/MediaConnectionAwaiter.js +1 -0
  24. package/dist/media/MediaConnectionAwaiter.js.map +1 -1
  25. package/dist/media/properties.js +30 -16
  26. package/dist/media/properties.js.map +1 -1
  27. package/dist/meeting/brbState.js +167 -0
  28. package/dist/meeting/brbState.js.map +1 -0
  29. package/dist/meeting/in-meeting-actions.js +13 -1
  30. package/dist/meeting/in-meeting-actions.js.map +1 -1
  31. package/dist/meeting/index.js +1335 -1052
  32. package/dist/meeting/index.js.map +1 -1
  33. package/dist/meeting/locusMediaRequest.js +11 -6
  34. package/dist/meeting/locusMediaRequest.js.map +1 -1
  35. package/dist/meeting/muteState.js +1 -6
  36. package/dist/meeting/muteState.js.map +1 -1
  37. package/dist/meeting/request.js +51 -29
  38. package/dist/meeting/request.js.map +1 -1
  39. package/dist/meeting/request.type.js.map +1 -1
  40. package/dist/meeting/util.js +103 -67
  41. package/dist/meeting/util.js.map +1 -1
  42. package/dist/meeting-info/meeting-info-v2.js +115 -45
  43. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  44. package/dist/meeting-info/utilv2.js +6 -2
  45. package/dist/meeting-info/utilv2.js.map +1 -1
  46. package/dist/meetings/index.js +107 -55
  47. package/dist/meetings/index.js.map +1 -1
  48. package/dist/meetings/meetings.types.js +2 -0
  49. package/dist/meetings/meetings.types.js.map +1 -1
  50. package/dist/meetings/util.js +1 -1
  51. package/dist/meetings/util.js.map +1 -1
  52. package/dist/member/index.js +9 -0
  53. package/dist/member/index.js.map +1 -1
  54. package/dist/member/types.js.map +1 -1
  55. package/dist/member/util.js +39 -28
  56. package/dist/member/util.js.map +1 -1
  57. package/dist/members/util.js +4 -2
  58. package/dist/members/util.js.map +1 -1
  59. package/dist/metrics/constants.js +6 -1
  60. package/dist/metrics/constants.js.map +1 -1
  61. package/dist/multistream/remoteMedia.js +30 -15
  62. package/dist/multistream/remoteMedia.js.map +1 -1
  63. package/dist/multistream/sendSlotManager.js +24 -0
  64. package/dist/multistream/sendSlotManager.js.map +1 -1
  65. package/dist/reachability/clusterReachability.js +12 -15
  66. package/dist/reachability/clusterReachability.js.map +1 -1
  67. package/dist/reachability/index.js +461 -136
  68. package/dist/reachability/index.js.map +1 -1
  69. package/dist/{rtcMetrics/constants.js → reachability/reachability.types.js} +1 -5
  70. package/dist/reachability/reachability.types.js.map +1 -0
  71. package/dist/reachability/request.js +21 -8
  72. package/dist/reachability/request.js.map +1 -1
  73. package/dist/recording-controller/enums.js +8 -4
  74. package/dist/recording-controller/enums.js.map +1 -1
  75. package/dist/recording-controller/index.js +18 -9
  76. package/dist/recording-controller/index.js.map +1 -1
  77. package/dist/recording-controller/util.js +13 -9
  78. package/dist/recording-controller/util.js.map +1 -1
  79. package/dist/roap/index.js +15 -15
  80. package/dist/roap/index.js.map +1 -1
  81. package/dist/roap/request.js +45 -79
  82. package/dist/roap/request.js.map +1 -1
  83. package/dist/roap/turnDiscovery.js +3 -6
  84. package/dist/roap/turnDiscovery.js.map +1 -1
  85. package/dist/types/annotation/index.d.ts +5 -0
  86. package/dist/types/common/errors/join-forbidden-error.d.ts +15 -0
  87. package/dist/types/common/errors/{webinar-registration-error.d.ts → join-webinar-error.d.ts} +2 -2
  88. package/dist/types/common/errors/multistream-not-supported-error.d.ts +17 -0
  89. package/dist/types/config.d.ts +1 -0
  90. package/dist/types/constants.d.ts +53 -1
  91. package/dist/types/index.d.ts +3 -3
  92. package/dist/types/locus-info/index.d.ts +2 -1
  93. package/dist/types/meeting/brbState.d.ts +54 -0
  94. package/dist/types/meeting/in-meeting-actions.d.ts +12 -0
  95. package/dist/types/meeting/index.d.ts +64 -14
  96. package/dist/types/meeting/locusMediaRequest.d.ts +6 -3
  97. package/dist/types/meeting/request.d.ts +14 -3
  98. package/dist/types/meeting/request.type.d.ts +6 -0
  99. package/dist/types/meeting/util.d.ts +3 -3
  100. package/dist/types/meeting-info/meeting-info-v2.d.ts +30 -5
  101. package/dist/types/meetings/index.d.ts +20 -2
  102. package/dist/types/meetings/meetings.types.d.ts +8 -0
  103. package/dist/types/member/index.d.ts +1 -0
  104. package/dist/types/member/types.d.ts +7 -0
  105. package/dist/types/members/util.d.ts +2 -0
  106. package/dist/types/metrics/constants.d.ts +6 -1
  107. package/dist/types/multistream/sendSlotManager.d.ts +8 -1
  108. package/dist/types/reachability/clusterReachability.d.ts +1 -10
  109. package/dist/types/reachability/index.d.ts +83 -36
  110. package/dist/types/reachability/reachability.types.d.ts +64 -0
  111. package/dist/types/reachability/request.d.ts +5 -1
  112. package/dist/types/recording-controller/enums.d.ts +5 -2
  113. package/dist/types/recording-controller/index.d.ts +1 -0
  114. package/dist/types/recording-controller/util.d.ts +2 -1
  115. package/dist/types/roap/request.d.ts +1 -13
  116. package/dist/webinar/index.js +390 -7
  117. package/dist/webinar/index.js.map +1 -1
  118. package/package.json +23 -22
  119. package/src/annotation/index.ts +16 -0
  120. package/src/common/errors/join-forbidden-error.ts +26 -0
  121. package/src/common/errors/join-webinar-error.ts +24 -0
  122. package/src/common/errors/multistream-not-supported-error.ts +30 -0
  123. package/src/config.ts +1 -0
  124. package/src/constants.ts +61 -3
  125. package/src/index.ts +5 -3
  126. package/src/locus-info/index.ts +20 -3
  127. package/src/locus-info/selfUtils.ts +24 -6
  128. package/src/media/MediaConnectionAwaiter.ts +2 -0
  129. package/src/media/properties.ts +34 -13
  130. package/src/meeting/brbState.ts +169 -0
  131. package/src/meeting/in-meeting-actions.ts +25 -0
  132. package/src/meeting/index.ts +451 -88
  133. package/src/meeting/locusMediaRequest.ts +11 -8
  134. package/src/meeting/muteState.ts +1 -6
  135. package/src/meeting/request.ts +30 -12
  136. package/src/meeting/request.type.ts +7 -0
  137. package/src/meeting/util.ts +32 -13
  138. package/src/meeting-info/meeting-info-v2.ts +83 -12
  139. package/src/meeting-info/utilv2.ts +17 -3
  140. package/src/meetings/index.ts +79 -20
  141. package/src/meetings/meetings.types.ts +10 -0
  142. package/src/meetings/util.ts +2 -1
  143. package/src/member/index.ts +9 -0
  144. package/src/member/types.ts +8 -0
  145. package/src/member/util.ts +34 -24
  146. package/src/members/util.ts +1 -0
  147. package/src/metrics/constants.ts +6 -1
  148. package/src/multistream/remoteMedia.ts +28 -15
  149. package/src/multistream/sendSlotManager.ts +31 -0
  150. package/src/reachability/clusterReachability.ts +5 -15
  151. package/src/reachability/index.ts +311 -75
  152. package/src/reachability/reachability.types.ts +85 -0
  153. package/src/reachability/request.ts +55 -31
  154. package/src/recording-controller/enums.ts +5 -2
  155. package/src/recording-controller/index.ts +17 -4
  156. package/src/recording-controller/util.ts +20 -5
  157. package/src/roap/index.ts +14 -13
  158. package/src/roap/request.ts +30 -44
  159. package/src/roap/turnDiscovery.ts +2 -4
  160. package/src/webinar/index.ts +235 -9
  161. package/test/unit/spec/annotation/index.ts +46 -1
  162. package/test/unit/spec/locus-info/index.js +292 -60
  163. package/test/unit/spec/locus-info/selfConstant.js +7 -0
  164. package/test/unit/spec/locus-info/selfUtils.js +101 -1
  165. package/test/unit/spec/media/properties.ts +15 -0
  166. package/test/unit/spec/meeting/brbState.ts +114 -0
  167. package/test/unit/spec/meeting/in-meeting-actions.ts +15 -1
  168. package/test/unit/spec/meeting/index.js +860 -110
  169. package/test/unit/spec/meeting/locusMediaRequest.ts +18 -11
  170. package/test/unit/spec/meeting/muteState.js +0 -24
  171. package/test/unit/spec/meeting/request.js +3 -26
  172. package/test/unit/spec/meeting/utils.js +73 -28
  173. package/test/unit/spec/meeting-info/meetinginfov2.js +46 -4
  174. package/test/unit/spec/meeting-info/utilv2.js +26 -0
  175. package/test/unit/spec/meetings/index.js +159 -18
  176. package/test/unit/spec/meetings/utils.js +10 -0
  177. package/test/unit/spec/member/util.js +52 -11
  178. package/test/unit/spec/members/utils.js +95 -0
  179. package/test/unit/spec/multistream/remoteMedia.ts +11 -7
  180. package/test/unit/spec/reachability/clusterReachability.ts +7 -0
  181. package/test/unit/spec/reachability/index.ts +383 -9
  182. package/test/unit/spec/reachability/request.js +48 -12
  183. package/test/unit/spec/recording-controller/index.js +61 -5
  184. package/test/unit/spec/recording-controller/util.js +39 -3
  185. package/test/unit/spec/roap/index.ts +48 -1
  186. package/test/unit/spec/roap/request.ts +51 -109
  187. package/test/unit/spec/roap/turnDiscovery.ts +202 -147
  188. package/test/unit/spec/webinar/index.ts +504 -0
  189. package/dist/common/errors/webinar-registration-error.js.map +0 -1
  190. package/dist/networkQualityMonitor/index.js +0 -227
  191. package/dist/networkQualityMonitor/index.js.map +0 -1
  192. package/dist/rtcMetrics/constants.js.map +0 -1
  193. package/dist/rtcMetrics/index.js +0 -197
  194. package/dist/rtcMetrics/index.js.map +0 -1
  195. package/dist/types/networkQualityMonitor/index.d.ts +0 -70
  196. package/dist/types/rtcMetrics/constants.d.ts +0 -4
  197. package/dist/types/rtcMetrics/index.d.ts +0 -71
  198. package/src/common/errors/webinar-registration-error.ts +0 -27
@@ -1,5 +1,5 @@
1
1
  import RecordingUtil from '@webex/plugin-meetings/src/recording-controller/util';
2
- import RecordingAction from '@webex/plugin-meetings/src/recording-controller/enums';
2
+ import { RecordingAction } from '@webex/plugin-meetings/src/recording-controller/enums';
3
3
  import {SELF_POLICY} from '@webex/plugin-meetings/src/constants';
4
4
 
5
5
  import {assert} from 'chai';
@@ -29,6 +29,15 @@ describe('plugin-meetings', () => {
29
29
  );
30
30
  });
31
31
 
32
+ it('can start premise recording when the correct display hint is present', () => {
33
+ locusInfo.parsedLocus.info.userDisplayHints.push('PREMISE_RECORDING_CONTROL_START');
34
+
35
+ assert.equal(
36
+ RecordingUtil.canUserStart(locusInfo.parsedLocus.info.userDisplayHints),
37
+ true
38
+ );
39
+ });
40
+
32
41
  it('can start recording when the correct display hint is present and the policy is true', () => {
33
42
  locusInfo.parsedLocus.info.userDisplayHints.push('RECORDING_CONTROL_START');
34
43
 
@@ -69,6 +78,15 @@ describe('plugin-meetings', () => {
69
78
  );
70
79
  });
71
80
 
81
+ it('can pause premise recording when the correct display hint is present', () => {
82
+ locusInfo.parsedLocus.info.userDisplayHints.push('PREMISE_RECORDING_CONTROL_PAUSE');
83
+
84
+ assert.equal(
85
+ RecordingUtil.canUserPause(locusInfo.parsedLocus.info.userDisplayHints),
86
+ true
87
+ );
88
+ });
89
+
72
90
  it('can pause recording when the correct display hint is present and the policy is true', () => {
73
91
  locusInfo.parsedLocus.info.userDisplayHints.push('RECORDING_CONTROL_PAUSE');
74
92
 
@@ -109,6 +127,15 @@ describe('plugin-meetings', () => {
109
127
  );
110
128
  });
111
129
 
130
+ it('can stop premise recording when the correct display hint is present', () => {
131
+ locusInfo.parsedLocus.info.userDisplayHints.push('PREMISE_RECORDING_CONTROL_STOP');
132
+
133
+ assert.equal(
134
+ RecordingUtil.canUserStop(locusInfo.parsedLocus.info.userDisplayHints),
135
+ true
136
+ );
137
+ });
138
+
112
139
  it('can stop recording when the correct display hint is present and the policy is true', () => {
113
140
  locusInfo.parsedLocus.info.userDisplayHints.push('RECORDING_CONTROL_STOP', {
114
141
  [SELF_POLICY.SUPPORT_NETWORK_BASED_RECORD]: true,
@@ -142,7 +169,7 @@ describe('plugin-meetings', () => {
142
169
  });
143
170
 
144
171
  describe('canUserResume', () => {
145
- it('can start recording when the correct display hint is present', () => {
172
+ it('can resume recording when the correct display hint is present', () => {
146
173
  locusInfo.parsedLocus.info.userDisplayHints.push('RECORDING_CONTROL_RESUME');
147
174
 
148
175
  assert.equal(
@@ -151,7 +178,16 @@ describe('plugin-meetings', () => {
151
178
  );
152
179
  });
153
180
 
154
- it('can start recording when the correct display hint is present and the policy is true', () => {
181
+ it('can resume premise recording when the correct display hint is present', () => {
182
+ locusInfo.parsedLocus.info.userDisplayHints.push('PREMISE_RECORDING_CONTROL_RESUME');
183
+
184
+ assert.equal(
185
+ RecordingUtil.canUserResume(locusInfo.parsedLocus.info.userDisplayHints),
186
+ true
187
+ );
188
+ });
189
+
190
+ it('can resume recording when the correct display hint is present and the policy is true', () => {
155
191
  locusInfo.parsedLocus.info.userDisplayHints.push('RECORDING_CONTROL_RESUME');
156
192
 
157
193
  assert.equal(
@@ -161,7 +161,7 @@ describe('Roap', () => {
161
161
  roapMessage: expectedRoapMessage,
162
162
  locusSelfUrl: meeting.selfUrl,
163
163
  mediaId: meeting.mediaId,
164
- meetingId: meeting.id,
164
+ isMultistream: meeting.isMultistream,
165
165
  locusMediaRequest: meeting.locusMediaRequest,
166
166
  })
167
167
  );
@@ -251,6 +251,53 @@ describe('Roap', () => {
251
251
  );
252
252
  });
253
253
 
254
+ it('handles the case when there is some other (not an answer) roap message type in the http response', async () => {
255
+ const roapError = {
256
+ seq: 1,
257
+ messageType: 'ERROR',
258
+ sdps: [],
259
+ errorType: 'error type',
260
+ errorCause: 'error cause',
261
+ headers: ['header1', 'header2'],
262
+ };
263
+ const fakeMediaConnections = [
264
+ {
265
+ remoteSdp: JSON.stringify({
266
+ roapMessage: roapError,
267
+ }),
268
+ },
269
+ ];
270
+
271
+ sendRoapStub.resolves({
272
+ mediaConnections: fakeMediaConnections,
273
+ locus: fakeLocus,
274
+ });
275
+
276
+ const result = await roap.sendRoapMediaRequest({
277
+ meeting,
278
+ sdp: 'sdp',
279
+ reconnect: false,
280
+ seq: 1,
281
+ tieBreaker: 4294967294,
282
+ });
283
+
284
+ assert.calledOnce(sendRoapStub);
285
+ assert.calledOnceWithExactly(meeting.updateMediaConnections, fakeMediaConnections);
286
+ assert.deepEqual(result, {
287
+ locus: fakeLocus,
288
+ roapAnswer: undefined,
289
+ });
290
+ assert.calledOnceWithExactly(
291
+ Metrics.sendBehavioralMetric,
292
+ BEHAVIORAL_METRICS.ROAP_HTTP_RESPONSE_MISSING,
293
+ {
294
+ correlationId: meeting.correlationId,
295
+ messageType: 'ANSWER',
296
+ isMultistream: meeting.isMultistream,
297
+ }
298
+ );
299
+ });
300
+
254
301
  describe('does not crash when http response is missing things', () => {
255
302
  [
256
303
  {mediaConnections: undefined, title: 'mediaConnections are undefined'},
@@ -4,6 +4,7 @@ import {assert} from '@webex/test-helper-chai';
4
4
  import MockWebex from '@webex/test-helper-mock-webex';
5
5
  import Meetings from '@webex/plugin-meetings';
6
6
  import RoapRequest from '@webex/plugin-meetings/src/roap/request';
7
+ import MeetingUtil from '@webex/plugin-meetings/src/meeting/util';
7
8
  import {IP_VERSION, REACHABILITY} from '@webex/plugin-meetings/src/constants';
8
9
 
9
10
  describe('plugin-meetings/roap', () => {
@@ -23,6 +24,11 @@ describe('plugin-meetings/roap', () => {
23
24
  regionCode: 'WEST-COAST',
24
25
  };
25
26
 
27
+ webex.meetings.reachability = {
28
+ getReachabilityReportToAttachToRoap: sinon.stub().resolves({}),
29
+ getClientMediaPreferences: sinon.stub().resolves({}),
30
+ };
31
+
26
32
  webex.internal = {
27
33
  services: {
28
34
  get: sinon.mock().returns(locusUrl),
@@ -36,6 +42,8 @@ describe('plugin-meetings/roap', () => {
36
42
  },
37
43
  };
38
44
 
45
+ sinon.stub(MeetingUtil, 'getIpVersion').returns(IP_VERSION.ipv4_and_ipv6);
46
+
39
47
  // @ts-ignore
40
48
  roapRequest = new RoapRequest({webex});
41
49
 
@@ -74,146 +82,80 @@ describe('plugin-meetings/roap', () => {
74
82
  );
75
83
  });
76
84
 
77
- describe('#attachReachabilityData', () => {
78
- it('returns the correct reachability data', async () => {
79
- const res = await roapRequest.attachReachabilityData({});
80
-
81
- assert.deepEqual(res.localSdp, {
82
- reachability: {
83
- clusterId: {
84
- udp: {
85
- reachable: 'true',
86
- latencyInMilliseconds: '10',
87
- },
88
- tcp: {
89
- reachable: 'false',
90
- },
91
- xtls: {
92
- untested: 'true',
93
- }
94
- },
95
- },
96
- });
97
- assert.deepEqual(res.joinCookie, {
98
- anycastEntryPoint: 'aws-eu-west-1',
99
- });
100
- });
85
+ afterEach(() => {
86
+ sinon.restore();
87
+ })
101
88
 
102
- it('handles the case when reachability data does not exist', async () => {
103
- await webex.boundedStorage.del(REACHABILITY.namespace, REACHABILITY.localStorageJoinCookie);
89
+ describe('sendRoap', () => {
90
+ it('includes clientMediaPreferences and reachability in the request correctly', async () => {
91
+ const locusMediaRequest = {send: sinon.stub().resolves({body: {locus: {}}})};
104
92
 
105
- await webex.boundedStorage.del(REACHABILITY.namespace, REACHABILITY.localStorageResult);
106
- const sdp = {
107
- some: 'attribute',
93
+ const FAKE_REACHABILITY_REPORT = {
94
+ id: 'fake reachability report',
95
+ };
96
+ const FAKE_CLIENT_MEDIA_PREFERENCES = {
97
+ id: 'fake client media preferences',
108
98
  };
109
99
 
110
- const result = await roapRequest.attachReachabilityData(sdp);
111
-
112
- assert.deepEqual(result, {
113
- joinCookie: undefined,
114
- localSdp: {
115
- some: 'attribute',
116
- },
117
- });
118
- });
119
- });
120
-
121
- describe('sendRoap', () => {
122
- it('includes joinCookie in the request correctly', async () => {
123
- const locusMediaRequest = {send: sinon.stub().resolves({body: {locus: {}}})};
124
- const ipVersion = IP_VERSION.unknown;
100
+ webex.meetings.reachability.getReachabilityReportToAttachToRoap.resolves(FAKE_REACHABILITY_REPORT);
101
+ webex.meetings.reachability.getClientMediaPreferences.resolves(FAKE_CLIENT_MEDIA_PREFERENCES);
125
102
 
126
103
  await roapRequest.sendRoap({
127
104
  locusSelfUrl: locusUrl,
128
- ipVersion,
129
105
  mediaId: 'mediaId',
130
106
  roapMessage: {
131
107
  seq: 'seq',
132
108
  },
133
109
  meetingId: 'meeting-id',
110
+ isMultistream: true,
134
111
  locusMediaRequest,
135
112
  });
136
113
 
114
+ assert.calledOnceWithExactly(webex.meetings.reachability.getReachabilityReportToAttachToRoap);
115
+ assert.calledOnceWithExactly(webex.meetings.reachability.getClientMediaPreferences, true, IP_VERSION.ipv4_and_ipv6);
116
+
137
117
  const requestParams = locusMediaRequest.send.getCall(0).args[0];
138
118
  assert.deepEqual(requestParams, {
139
119
  type: 'RoapMessage',
140
120
  selfUrl: locusUrl,
141
- ipVersion,
142
- joinCookie: {
143
- anycastEntryPoint: 'aws-eu-west-1',
144
- },
121
+ clientMediaPreferences: FAKE_CLIENT_MEDIA_PREFERENCES,
145
122
  mediaId: 'mediaId',
146
123
  roapMessage: {
147
124
  seq: 'seq',
148
125
  },
149
- reachability: {
150
- clusterId: {
151
- tcp: {
152
- reachable: 'false',
153
- },
154
- udp: {
155
- latencyInMilliseconds: '10',
156
- reachable: 'true',
157
- },
158
- xtls: {
159
- untested: 'true',
160
- },
161
- },
162
- },
126
+ reachability: FAKE_REACHABILITY_REPORT,
163
127
  });
164
128
  });
165
- });
166
129
 
167
- it('calls attachReachabilityData when sendRoap', async () => {
168
- const locusMediaRequest = { send: sinon.stub().resolves({body: {locus: {}}})};
130
+ it('includes default clientMediaPreferences if calls to reachability fail', async () => {
131
+ const locusMediaRequest = {send: sinon.stub().resolves({body: {locus: {}}})};
169
132
 
170
- const newSdp = {
171
- new: 'sdp',
172
- reachability: { someResult: 'whatever' }
173
- };
174
- const ipVersion = IP_VERSION.only_ipv6;
133
+ webex.meetings.reachability.getClientMediaPreferences.rejects(new Error('fake error'));
175
134
 
176
- roapRequest.attachReachabilityData = sinon.stub().returns(
177
- Promise.resolve({
178
- localSdp: newSdp,
179
- joinCookie: {
180
- anycastEntryPoint: 'aws-eu-west-1',
135
+ await roapRequest.sendRoap({
136
+ locusSelfUrl: locusUrl,
137
+ mediaId: 'mediaId',
138
+ roapMessage: {
139
+ seq: 'seq',
181
140
  },
182
- })
183
- );
184
-
185
- await roapRequest.sendRoap({
186
- roapMessage: {
187
- seq: 1,
188
- },
189
- locusSelfUrl: 'locusSelfUrl',
190
- ipVersion,
191
- mediaId: 'mediaId',
192
- meetingId: 'meetingId',
193
- preferTranscoding: true,
194
- locusMediaRequest
195
- });
196
-
197
- const requestParams = locusMediaRequest.send.getCall(0).args[0];
141
+ meetingId: 'meeting-id',
142
+ isMultistream: true,
143
+ locusMediaRequest,
144
+ });
198
145
 
199
- assert.deepEqual(requestParams, {
200
- type: 'RoapMessage',
201
- selfUrl: 'locusSelfUrl',
202
- ipVersion,
203
- joinCookie: {
204
- anycastEntryPoint: 'aws-eu-west-1',
205
- },
206
- mediaId: 'mediaId',
207
- roapMessage: {
208
- seq: 1,
209
- },
210
- reachability: { someResult: 'whatever' },
211
- });
146
+ assert.calledOnce(webex.meetings.reachability.getClientMediaPreferences);
212
147
 
213
- assert.calledOnceWithExactly(roapRequest.attachReachabilityData, {
214
- roapMessage: {
215
- seq: 1,
216
- },
148
+ const requestParams = locusMediaRequest.send.getCall(0).args[0];
149
+ assert.deepEqual(requestParams, {
150
+ type: 'RoapMessage',
151
+ selfUrl: locusUrl,
152
+ clientMediaPreferences: {ipver: 0, joinCookie: undefined, preferTranscoding: false},
153
+ mediaId: 'mediaId',
154
+ roapMessage: {
155
+ seq: 'seq',
156
+ },
157
+ reachability: undefined,
158
+ });
217
159
  });
218
160
  });
219
161
  });