45 lines
1.3 KiB
JavaScript
45 lines
1.3 KiB
JavaScript
|
const { expect } = require('@playwright/test');
|
||
|
const Page = require('../core/page');
|
||
|
const e = require('../core/elements');
|
||
|
const { ELEMENT_WAIT_LONGER_TIME } = require('../core/constants');
|
||
|
const { MultiUsers } = require('../user/multiusers');
|
||
|
|
||
|
class DrawText extends MultiUsers {
|
||
|
constructor(browser, context) {
|
||
|
super(browser, context);
|
||
|
}
|
||
|
|
||
|
async test() {
|
||
|
await this.modPage.waitForSelector(e.whiteboard, ELEMENT_WAIT_LONGER_TIME);
|
||
|
await this.modPage.waitAndClick(e.wbTextShape);
|
||
|
|
||
|
const wb = await this.modPage.page.$(e.whiteboard);
|
||
|
const wbBox = await wb.boundingBox();
|
||
|
await this.modPage.page.mouse.click(wbBox.x + 0.3 * wbBox.width, wbBox.y + 0.3 * wbBox.height);
|
||
|
|
||
|
await this.modPage.press('A');
|
||
|
await this.modPage.press('A');
|
||
|
await this.modPage.press('Backspace');
|
||
|
await this.modPage.press('B');
|
||
|
await this.modPage.page.mouse.click(wbBox.x + 0.6 * wbBox.width, wbBox.y + 0.6 * wbBox.height);
|
||
|
|
||
|
const clipObj = {
|
||
|
x: wbBox.x,
|
||
|
y: wbBox.y,
|
||
|
width: wbBox.width,
|
||
|
height: wbBox.height,
|
||
|
};
|
||
|
|
||
|
await expect(this.modPage.page).toHaveScreenshot('moderator1-text.png', {
|
||
|
maxDiffPixels: 1000,
|
||
|
clip: clipObj,
|
||
|
});
|
||
|
await expect(this.modPage2.page).toHaveScreenshot('moderator2-text.png', {
|
||
|
maxDiffPixels: 1000,
|
||
|
clip: clipObj,
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
exports.DrawText = DrawText;
|