92 lines
3.2 KiB
JavaScript
92 lines
3.2 KiB
JavaScript
const we = require('./elements');
|
|
const { sleep } = require('../core/helper');
|
|
const {
|
|
LOOP_INTERVAL, ELEMENT_WAIT_TIME, VIDEO_LOADING_WAIT_TIME, ELEMENT_WAIT_LONGER_TIME,
|
|
} = require('../core/constants');
|
|
|
|
async function enableWebcam(test, videoPreviewTimeout) {
|
|
// Enabling webcam
|
|
await test.waitForSelector(we.joinVideo, ELEMENT_WAIT_TIME);
|
|
await test.page.evaluate(clickTestElement, we.joinVideo);
|
|
await test.waitForSelector(we.videoPreview, videoPreviewTimeout);
|
|
await test.waitForSelector(we.startSharingWebcam, ELEMENT_WAIT_TIME);
|
|
await test.page.evaluate(clickTestElement, we.startSharingWebcam);
|
|
await test.waitForSelector(we.webcamConnecting, ELEMENT_WAIT_TIME);
|
|
await test.waitForSelector(we.webcamVideo, VIDEO_LOADING_WAIT_TIME);
|
|
await test.waitForSelector(we.leaveVideo, VIDEO_LOADING_WAIT_TIME);
|
|
const resp = await test.page.evaluate(countTestElements, we.webcamVideo) !== 0;
|
|
return resp;
|
|
}
|
|
|
|
async function getFullScreenWebcamButton(element) {
|
|
return await document.querySelectorAll(element)[1] !== null;
|
|
}
|
|
|
|
async function evaluateCheck(test) {
|
|
await test.waitForSelector(we.videoContainer, ELEMENT_WAIT_TIME);
|
|
const videoContainer = await test.page.evaluate(getFullScreenWebcamButton, we.presentationFullscreenButton);
|
|
const response = videoContainer !== false;
|
|
return response;
|
|
}
|
|
|
|
async function startAndCheckForWebcams(test) {
|
|
await enableWebcam(test);
|
|
const response = await evaluateCheck(test);
|
|
return response;
|
|
}
|
|
|
|
async function webcamContentCheck(test) {
|
|
await test.waitForSelector(we.videoContainer, ELEMENT_WAIT_TIME);
|
|
await test.waitForElementHandleToBeRemoved(we.webcamConnecting, ELEMENT_WAIT_LONGER_TIME);
|
|
const repeats = 5;
|
|
let check;
|
|
for (let i = repeats; i >= 1; i--) {
|
|
console.log(`loop ${i}`);
|
|
const checkCameras = function (i) {
|
|
const videos = document.querySelectorAll('video');
|
|
const lastVideoColor = document.lastVideoColor || {};
|
|
document.lastVideoColor = lastVideoColor;
|
|
|
|
for (let v = 0; v < videos.length; v++) {
|
|
const video = videos[v];
|
|
const canvas = document.createElement('canvas');
|
|
const context = canvas.getContext('2d');
|
|
context.drawImage(video, 0, 0, video.videoWidth, video.videoHeight);
|
|
const pixel = context.getImageData(0, 0, 1, 1).data;
|
|
const pixelString = new Array(pixel).join(' ').toString();
|
|
|
|
if (lastVideoColor[v]) {
|
|
if (lastVideoColor[v] == pixelString) {
|
|
return false;
|
|
}
|
|
}
|
|
lastVideoColor[v] = pixelString;
|
|
return true;
|
|
}
|
|
};
|
|
|
|
check = await test.page.evaluate(checkCameras, i);
|
|
if (!check) return false;
|
|
await sleep(LOOP_INTERVAL);
|
|
}
|
|
return check === true;
|
|
}
|
|
|
|
|
|
async function clickTestElement(element) {
|
|
document.querySelectorAll(element)[0].click();
|
|
}
|
|
|
|
async function countTestElements(element) {
|
|
const respCount = await document.querySelectorAll(element).length;
|
|
console.log({ respCount });
|
|
return respCount;
|
|
}
|
|
|
|
exports.startAndCheckForWebcams = startAndCheckForWebcams;
|
|
exports.webcamContentCheck = webcamContentCheck;
|
|
exports.evaluateCheck = evaluateCheck;
|
|
exports.getFullScreenWebcamButton = getFullScreenWebcamButton;
|
|
exports.enableWebcam = enableWebcam;
|
|
exports.countTestElements = countTestElements;
|