我正在为视频聊天应用程序编写功能测试。
我想确保当用户离开会议时相机会关闭。所以,我正在尝试检查相机是否正在使用。
有没有办法以编程方式做到这一点?我找不到任何关于navigator.MediaDevices
“嘿,你的相机正在被使用”的方法。
我正在为视频聊天应用程序编写功能测试。
我想确保当用户离开会议时相机会关闭。所以,我正在尝试检查相机是否正在使用。
有没有办法以编程方式做到这一点?我找不到任何关于navigator.MediaDevices
“嘿,你的相机正在被使用”的方法。
以下是我在 TestCafe 中通过“间谍”解决它的方法getUserMedia
:
const overWriteGetUserMedia = ClientFunction(() => {
const realGetUserMedia = navigator.mediaDevices.getUserMedia;
const allRequestedTracks = [];
navigator.mediaDevices.getUserMedia = constraints =>
realGetUserMedia(constraints).then(stream => {
stream.getTracks().forEach(track => {
allRequestedTracks.push(track);
});
return stream;
});
return allRequestedTracks;
});
test('leaving a meeting should end streams', async t => {
const allRequestedTracks = await overWriteGetUserMedia();
await t.wait(5000); // wait for streams to start;
await t.click(screen.getByLabelText(/leave/i));
await t.click(screen.getByLabelText(/yes, leave the meeting/i));
await t.wait(1000); // wait for navigation;
const actual = !allRequestedTracks.some(track => !track.ended);
const expected = true;
await t.expect(actual).eql(expected);
});