bigbluebutton-Github/bigbluebutton-tests/playwright/whiteboard/shapeOptions.js
Gabriel Luiz Porfirio 7a67c54e25
test: Updates whiteboard tests (#20414)
* fixing whiteboard tests

* fix undo whiteboard test

* finished updating whiteboard tests

* updated two tests

* updated all whiteboard screenshots, pan test is flaky

* changing whiteboard checks

* whiteboard tests updated

* rm screenshots from failing tests

* changed repeat code to be in a function

* change data-shape-type

* changed selector

* skip check for screenshot on ci

* changes on function name

* adding @ci to all test specs

* removed tag on unecessary test
2024-09-12 13:51:26 -03:00

120 lines
5.1 KiB
JavaScript

const { expect } = require('@playwright/test');
const e = require('../core/elements');
const { ELEMENT_WAIT_LONGER_TIME } = require('../core/constants');
const { MultiUsers } = require('../user/multiusers');
const { sleep } = require('../core/helpers');
class ShapeOptions extends MultiUsers {
constructor(browser, context) {
super(browser, context);
}
async duplicate() {
await this.modPage.waitForSelector(e.whiteboard, ELEMENT_WAIT_LONGER_TIME);
const modWbLocator = this.modPage.getLocator(e.whiteboard);
const wbBox = await modWbLocator.boundingBox();
const screenshotOptions = {
maxDiffPixels: 1000,
};
await this.modPage.waitAndClick(e.wbShapesButton);
await this.modPage.waitAndClick(e.wbRectangleShape);
await this.modPage.page.mouse.move(wbBox.x + 0.3 * wbBox.width, wbBox.y + 0.3 * wbBox.height);
await this.modPage.page.mouse.down();
await this.modPage.page.mouse.move(wbBox.x + 0.7 * wbBox.width, wbBox.y + 0.7 * wbBox.height);
await this.modPage.page.mouse.up();
await this.modPage.page.mouse.click(wbBox.x + 0.7 * wbBox.width, wbBox.y + 0.7 * wbBox.height);
await this.modPage.waitAndClick(e.wbOptions);
await this.modPage.waitAndClick(e.wbDuplicate);
await this.modPage.waitAndClick(e.wbOptions);
await this.modPage.checkElementCount(e.wbDrawnShape, 2);
await this.userPage.checkElementCount(e.wbDrawnShape, 2);
}
async rotate() {
await this.modPage.waitForSelector(e.whiteboard, ELEMENT_WAIT_LONGER_TIME);
const modWbLocator = this.modPage.getLocator(e.whiteboard);
const wbBox = await modWbLocator.boundingBox();
const screenshotOptions = {
maxDiffPixels: 1000,
};
await this.modPage.waitAndClick(e.wbShapesButton);
await this.modPage.waitAndClick(e.wbRectangleShape);
await this.modPage.page.mouse.move(wbBox.x + 0.3 * wbBox.width, wbBox.y + 0.3 * wbBox.height);
await this.modPage.page.mouse.down();
await this.modPage.page.mouse.move(wbBox.x + 0.7 * wbBox.width, wbBox.y + 0.7 * wbBox.height);
await this.modPage.page.mouse.up();
await this.modPage.page.mouse.click(wbBox.x + 0.7 * wbBox.width, wbBox.y + 0.7 * wbBox.height);
await this.modPage.waitAndClick(e.wbOptions);
await this.modPage.waitAndClick(e.wbRotate);
await this.modPage.waitAndClick(e.wbOptions);
await expect(modWbLocator).toHaveScreenshot('moderator-rotate.png', screenshotOptions);
const userWbLocator = this.userPage.getLocator(e.whiteboard);
await expect(userWbLocator).toHaveScreenshot('viewer-rotate.png', screenshotOptions);
}
async movingShape() {
await this.modPage.waitForSelector(e.whiteboard, ELEMENT_WAIT_LONGER_TIME);
const modWbLocator = this.modPage.getLocator(e.whiteboard);
const wbBox = await modWbLocator.boundingBox();
const screenshotOptions = {
maxDiffPixels: 1000,
};
// First rectangle
await this.modPage.waitAndClick(e.wbShapesButton);
await this.modPage.waitAndClick(e.wbRectangleShape);
await this.modPage.page.mouse.move(wbBox.x + 0.3 * wbBox.width, wbBox.y + 0.3 * wbBox.height);
await this.modPage.page.mouse.down();
await this.modPage.page.mouse.move(wbBox.x + 0.7 * wbBox.width, wbBox.y + 0.7 * wbBox.height);
await this.modPage.page.mouse.up();
await this.modPage.page.mouse.click(wbBox.x + 0.7 * wbBox.width, wbBox.y + 0.7 * wbBox.height);
// Second rectangle
await this.modPage.waitAndClick(e.wbRectangleShape);
await this.modPage.page.mouse.move(wbBox.x + 0.4 * wbBox.width, wbBox.y + 0.4 * wbBox.height);
await this.modPage.page.mouse.down();
await this.modPage.page.mouse.move(wbBox.x + 0.9 * wbBox.width, wbBox.y + 0.9 * wbBox.height);
await this.modPage.page.mouse.up();
await this.modPage.page.mouse.click(wbBox.x + 0.9 * wbBox.width, wbBox.y + 0.9 * wbBox.height);
await this.modPage.waitAndClick(e.whiteboardStyles);
await this.modPage.waitAndClick(e.wbFillDrawing);
await this.modPage.waitAndClick(e.wbOptions);
await this.modPage.waitAndClick(e.wbMoveBackward);
await this.modPage.waitAndClick(e.wbOptions);
await expect(modWbLocator).toHaveScreenshot('moderator-move-backward.png', screenshotOptions);
const userWbLocator = this.userPage.getLocator(e.whiteboard);
await expect(userWbLocator).toHaveScreenshot('viewer-move-backward.png', screenshotOptions);
await this.modPage.waitAndClick(e.wbOptions);
await this.modPage.waitAndClick(e.wbMoveForward);
await this.modPage.waitAndClick(e.wbOptions);
await expect(modWbLocator).toHaveScreenshot('moderator-move-forward.png', screenshotOptions);
await expect(userWbLocator).toHaveScreenshot('viewer-move-forward.png', screenshotOptions);
await this.modPage.waitAndClick(e.wbOptions);
await this.modPage.waitAndClick(e.wbMoveBackward);
await this.modPage.waitAndClick(e.wbMoveToFront);
await this.modPage.waitAndClick(e.wbOptions);
await expect(modWbLocator).toHaveScreenshot('moderator-move-to-front.png', screenshotOptions);
await expect(userWbLocator).toHaveScreenshot('viewer-move-to-front.png', screenshotOptions);
}
}
exports.ShapeOptions = ShapeOptions;