mirror of
https://github.com/vector-im/element-call.git
synced 2026-03-16 06:17:10 +00:00
add playwright tests for new pip layout
This commit is contained in:
71
playwright/widget/pip-call-button-interaction.test.ts
Normal file
71
playwright/widget/pip-call-button-interaction.test.ts
Normal file
@@ -0,0 +1,71 @@
|
||||
/*
|
||||
Copyright 2026 Element Creations Ltd.
|
||||
|
||||
SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Element-Commercial
|
||||
Please see LICENSE in the repository root for full details.
|
||||
*/
|
||||
|
||||
import { expect, test } from "@playwright/test";
|
||||
|
||||
import { widgetTest } from "../fixtures/widget-user.ts";
|
||||
import { HOST1, TestHelpers } from "./test-helpers.ts";
|
||||
|
||||
widgetTest(
|
||||
"Footer interaction in PiP",
|
||||
async ({ addUser, browserName, page }) => {
|
||||
test.skip(
|
||||
browserName === "firefox",
|
||||
"The is test is not working on firefox CI environment. No mic/audio device inputs so cam/mic are disabled",
|
||||
);
|
||||
|
||||
test.slow();
|
||||
|
||||
const valere = await addUser("Valere", HOST1);
|
||||
|
||||
const callRoom = "CallRoom";
|
||||
await TestHelpers.createRoom("CallRoom", valere.page);
|
||||
|
||||
await TestHelpers.createRoom("OtherRoom", valere.page);
|
||||
|
||||
await TestHelpers.switchToRoomNamed(valere.page, callRoom);
|
||||
|
||||
// Start the call as Valere
|
||||
await TestHelpers.startCallInCurrentRoom(valere.page, false);
|
||||
await expect(
|
||||
valere.page.locator('iframe[title="Element Call"]'),
|
||||
).toBeVisible();
|
||||
|
||||
await TestHelpers.joinCallFromLobby(valere.page);
|
||||
// wait a bit so that the PIP has rendered
|
||||
await valere.page.waitForTimeout(600);
|
||||
|
||||
// Switch to the other room, the call should go to PIP
|
||||
await TestHelpers.switchToRoomNamed(valere.page, "OtherRoom");
|
||||
|
||||
// We should see the PIP overlay
|
||||
const iFrame = valere.page
|
||||
.locator('iframe[title="Element Call"]')
|
||||
.contentFrame();
|
||||
|
||||
{
|
||||
// Check for a bug where the video had the wrong fit in PIP
|
||||
const hangupButton = iFrame.getByRole("button", { name: "End call" });
|
||||
const videoMuteButton = iFrame.getByRole("button", {
|
||||
name: "Stop video",
|
||||
});
|
||||
const audioMuteButton = iFrame.getByRole("button", {
|
||||
name: "Mute microphone",
|
||||
});
|
||||
await expect(hangupButton).toBeVisible();
|
||||
await expect(videoMuteButton).toBeVisible();
|
||||
await expect(audioMuteButton).toBeVisible();
|
||||
|
||||
// TODO once we have the EW version that supports the interactive pip element we can activate those checks
|
||||
// await videoMuteButton.click();
|
||||
// await audioMuteButton.click();
|
||||
|
||||
// await expect(videoMuteButton).toHaveCSS("disabled", "true");
|
||||
// await expect(audioMuteButton).toHaveCSS("disabled", "true");
|
||||
}
|
||||
},
|
||||
);
|
||||
Reference in New Issue
Block a user