feat(load-test): Load test startmuted (#8629)

* feat(load-test): Senders unmute themselves if muted by policy.

* feat(load-test): Adds option to skip creating local audio track.

We currently create local audio track even when starting audio muted. Adding the option to control that can load test that for clients or signalling.
This commit is contained in:
Дамян Минков 2021-02-17 10:28:01 -06:00 committed by GitHub
parent e0aab11f98
commit 8fcaea9e3d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 30 additions and 2 deletions

View File

@ -13,7 +13,10 @@ const {
localVideo = config.startWithVideoMuted !== true, localVideo = config.startWithVideoMuted !== true,
remoteVideo = isHuman, remoteVideo = isHuman,
remoteAudio = isHuman, remoteAudio = isHuman,
autoPlayVideo = config.testing.noAutoPlayVideo !== true autoPlayVideo = config.testing.noAutoPlayVideo !== true,
// Whether to create local audio even if muted
autoCreateLocalAudio = config.testing.noAutoLocalAudio !== true
} = params; } = params;
const { room: roomName } = parseURIString(window.location.toString()); const { room: roomName } = parseURIString(window.location.toString());
@ -149,6 +152,27 @@ function onConferenceJoined() {
console.log('Conference joined'); console.log('Conference joined');
} }
/**
* Handles start muted events, when audio and/or video are muted due to
* startAudioMuted or startVideoMuted policy.
*/
function onStartMuted() {
// Give it some time, as it may be currently in the process of muting
setTimeout(() => {
const localAudioTrack = room.getLocalAudioTrack();
if (localAudio && localAudioTrack && localAudioTrack.isMuted()) {
localAudioTrack.unmute();
}
const localVideoTrack = room.getLocalVideoTrack();
if (localVideo && localVideoTrack && localVideoTrack.isMuted()) {
localVideoTrack.unmute();
}
}, 2000);
}
/** /**
* *
* @param id * @param id
@ -176,6 +200,7 @@ function onUserLeft(id) {
*/ */
function onConnectionSuccess() { function onConnectionSuccess() {
room = connection.initJitsiConference(roomName.toLowerCase(), config); room = connection.initJitsiConference(roomName.toLowerCase(), config);
room.on(JitsiMeetJS.events.conference.STARTED_MUTED, onStartMuted);
room.on(JitsiMeetJS.events.conference.TRACK_ADDED, onRemoteTrack); room.on(JitsiMeetJS.events.conference.TRACK_ADDED, onRemoteTrack);
room.on(JitsiMeetJS.events.conference.CONFERENCE_JOINED, onConferenceJoined); room.on(JitsiMeetJS.events.conference.CONFERENCE_JOINED, onConferenceJoined);
room.on(JitsiMeetJS.events.conference.USER_JOINED, id => { room.on(JitsiMeetJS.events.conference.USER_JOINED, id => {
@ -190,7 +215,10 @@ function onConnectionSuccess() {
if (localVideo) { if (localVideo) {
devices.push('video'); devices.push('video');
} }
if (autoCreateLocalAudio) {
devices.push('audio'); devices.push('audio');
}
if (devices.length > 0) { if (devices.length > 0) {
JitsiMeetJS.createLocalTracks({ devices }) JitsiMeetJS.createLocalTracks({ devices })