2022-03-29 21:53:07 +08:00
|
|
|
const { default: test } = require('@playwright/test');
|
2021-12-01 01:14:03 +08:00
|
|
|
const Page = require('../core/page');
|
2023-03-08 10:33:22 +08:00
|
|
|
const { MultiUsers } = require('../user/multiusers');
|
2024-04-19 22:31:59 +08:00
|
|
|
const { startScreenshare } = require('./util');
|
2021-12-01 01:14:03 +08:00
|
|
|
const e = require('../core/elements');
|
2022-03-29 21:53:07 +08:00
|
|
|
const { getSettings } = require('../core/settings');
|
2021-12-01 01:14:03 +08:00
|
|
|
|
2021-12-02 12:12:14 +08:00
|
|
|
class ScreenShare extends Page {
|
2021-12-01 01:14:03 +08:00
|
|
|
constructor(browser, page) {
|
|
|
|
super(browser, page);
|
|
|
|
}
|
|
|
|
|
|
|
|
async startSharing() {
|
2022-03-29 21:53:07 +08:00
|
|
|
const { screensharingEnabled } = getSettings();
|
2023-11-08 19:50:16 +08:00
|
|
|
|
|
|
|
if(!screensharingEnabled) {
|
2023-11-16 20:00:22 +08:00
|
|
|
await this.hasElement(e.joinVideo);
|
2023-11-15 04:15:26 +08:00
|
|
|
return this.wasRemoved(e.startScreenSharing);
|
2023-11-08 19:50:16 +08:00
|
|
|
}
|
2021-12-02 12:12:14 +08:00
|
|
|
await startScreenshare(this);
|
2021-12-01 01:14:03 +08:00
|
|
|
await this.hasElement(e.isSharingScreen);
|
|
|
|
}
|
|
|
|
|
|
|
|
async testMobileDevice() {
|
|
|
|
await this.wasRemoved(e.startScreenSharing);
|
|
|
|
}
|
2024-04-16 03:28:53 +08:00
|
|
|
|
|
|
|
async screenshareStopsExternalVideo() {
|
|
|
|
const { screensharingEnabled } = getSettings();
|
|
|
|
|
2024-04-16 19:23:53 +08:00
|
|
|
await this.waitForSelector(e.whiteboard);
|
|
|
|
|
2024-04-16 03:28:53 +08:00
|
|
|
if(!screensharingEnabled) {
|
|
|
|
await this.hasElement(e.joinVideo);
|
|
|
|
return this.wasRemoved(e.startScreenSharing);
|
|
|
|
}
|
|
|
|
|
|
|
|
await this.waitAndClick(e.actions);
|
|
|
|
await this.waitAndClick(e.shareExternalVideoBtn);
|
|
|
|
await this.waitForSelector(e.closeModal);
|
|
|
|
await this.type(e.videoModalInput, e.youtubeLink);
|
|
|
|
await this.waitAndClick(e.startShareVideoBtn);
|
|
|
|
|
2024-04-19 22:31:59 +08:00
|
|
|
const modFrame = await this.getYoutubeFrame(this, e.youtubeFrame);
|
2024-04-16 03:28:53 +08:00
|
|
|
await modFrame.hasElement('video');
|
|
|
|
|
|
|
|
await startScreenshare(this);
|
|
|
|
await this.hasElement(e.isSharingScreen);
|
|
|
|
|
|
|
|
await this.hasElement(e.stopScreenSharing);
|
|
|
|
await this.waitAndClick(e.stopScreenSharing);
|
|
|
|
await this.hasElement(e.whiteboard);
|
|
|
|
}
|
2021-12-01 01:14:03 +08:00
|
|
|
}
|
|
|
|
|
2023-03-08 10:33:22 +08:00
|
|
|
class MultiUserScreenShare extends MultiUsers {
|
|
|
|
constructor(browser, context) {
|
|
|
|
super(browser, context);
|
|
|
|
}
|
|
|
|
|
|
|
|
async startSharing(page) {
|
|
|
|
const { screensharingEnabled } = getSettings();
|
2023-11-08 19:50:16 +08:00
|
|
|
|
|
|
|
if(!screensharingEnabled) {
|
2023-11-16 20:00:22 +08:00
|
|
|
await this.hasElement(e.joinVideo);
|
2023-11-15 04:15:26 +08:00
|
|
|
return this.wasRemoved(e.startScreenSharing);
|
2023-11-08 19:50:16 +08:00
|
|
|
}
|
2023-03-08 10:33:22 +08:00
|
|
|
await startScreenshare(page);
|
|
|
|
await page.hasElement(e.isSharingScreen);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-12-04 01:01:36 +08:00
|
|
|
exports.ScreenShare = ScreenShare;
|
2023-03-08 10:33:22 +08:00
|
|
|
exports.MultiUserScreenShare = MultiUserScreenShare;
|