Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Run Playwright tests against Dendrite & Pinecone periodically #28888

Merged
merged 128 commits into from
Jan 14, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
128 commits
Select commit Hold shift + click to select a range
00b25f5
Switch to TestContainers for manging services in Playwright
t3chguy Jan 3, 2025
87a0acb
Iterate
t3chguy Jan 3, 2025
7ba1d3e
Flip fixture dependency order
t3chguy Jan 3, 2025
c0337f1
Remove mas dep
t3chguy Jan 6, 2025
a4ba79a
Iterate
t3chguy Jan 6, 2025
94697fe
Iterate
t3chguy Jan 6, 2025
9c52986
Iterate
t3chguy Jan 6, 2025
f176473
Iterate
t3chguy Jan 6, 2025
75ba4f2
Iterate
t3chguy Jan 6, 2025
99af4a4
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 6, 2025
4fce001
Iterate
t3chguy Jan 6, 2025
4eefa27
Update matrix-authentication-service in Playwright tests
t3chguy Jan 6, 2025
1cd1dcd
delint
t3chguy Jan 6, 2025
f1c392d
Fix SMTP port
t3chguy Jan 6, 2025
84126e8
Iterate
t3chguy Jan 6, 2025
eaca3f8
Comments
t3chguy Jan 6, 2025
edefe02
Strip ansi from playwright logs to make them more readable
t3chguy Jan 6, 2025
d506dec
Actually do the update
t3chguy Jan 6, 2025
63e855e
Iterate
t3chguy Jan 6, 2025
8e1372b
Remove access to homeserver.config.baseUrl field in favour of homeser…
t3chguy Jan 6, 2025
d80ad9d
Use sane default_server_config and specify server.invalid in the spec…
t3chguy Jan 6, 2025
4cacb83
Fix mas run
t3chguy Jan 6, 2025
08bb07e
break cycle
t3chguy Jan 6, 2025
7104429
Merge branch 't3chguy/playwright-update-mas' of https://github.com/ve…
t3chguy Jan 6, 2025
e7b62c3
Merge branch 't3chguy/prepare-playwright-testcontainers' of https://g…
t3chguy Jan 6, 2025
f6ea850
Iterate
t3chguy Jan 6, 2025
b2fb036
typo
t3chguy Jan 6, 2025
1368dc0
Iterate
t3chguy Jan 6, 2025
27652d0
Iterate
t3chguy Jan 6, 2025
ac53bab
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 6, 2025
69723c5
Merge branch 't3chguy/prepare-playwright-testcontainers' of https://g…
t3chguy Jan 6, 2025
9ba9f1c
Iterate
t3chguy Jan 6, 2025
ea61320
prettier
t3chguy Jan 6, 2025
7ceced6
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 6, 2025
fd44732
Merge branch 't3chguy/prepare-playwright-testcontainers' of https://g…
t3chguy Jan 6, 2025
0410574
Wire up basics of dendriteHomeserver
t3chguy Jan 6, 2025
40d755a
Run Playwright tests against Dendrite & Pinecone periodically
t3chguy Jan 7, 2025
df510dc
Iterate
t3chguy Jan 7, 2025
7d8f00f
Iterate
t3chguy Jan 7, 2025
e4cff3f
Iterate
t3chguy Jan 7, 2025
4142c80
Iterate
t3chguy Jan 7, 2025
5e304be
Iterate
t3chguy Jan 7, 2025
18a3e72
Iterate
t3chguy Jan 7, 2025
757a22a
Iterate
t3chguy Jan 7, 2025
048563a
Iterate
t3chguy Jan 7, 2025
af8935e
Iterate
t3chguy Jan 7, 2025
cc871a6
Fix playwright-image-updates.yaml workflow
t3chguy Jan 8, 2025
30c82d8
Add `X-Run-All-Tests` label for running all tests
t3chguy Jan 8, 2025
0f5e135
Ignore failing tests in stale-screenshot-reporter.ts to avoid confusi…
t3chguy Jan 8, 2025
6cdfdc0
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 8, 2025
13527e7
Iterate
t3chguy Jan 8, 2025
9a89876
Merge branch 't3chguy/playwright-fixes' of https://github.com/vector-…
t3chguy Jan 8, 2025
4a2a93e
Iterate
t3chguy Jan 8, 2025
b10fa4e
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 8, 2025
91370c6
Specify Synapse ui_auth.session_timeout only on tests which require it
t3chguy Jan 8, 2025
ca38b0f
Iterate
t3chguy Jan 8, 2025
dc08e02
Merge branch 't3chguy/playwright-uia-timeout' of https://github.com/v…
t3chguy Jan 8, 2025
f7170ea
Iterate
t3chguy Jan 8, 2025
c890dfc
Iterate
t3chguy Jan 8, 2025
65936e6
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 8, 2025
9f5c32a
Iterate
t3chguy Jan 8, 2025
bde3142
React to MatrixEvent sender/target sentinels being updated for render…
t3chguy Jan 8, 2025
5ca8d74
Iterate
t3chguy Jan 8, 2025
4b79bb6
Merge branch 't3chguy/sentinels' of https://github.com/vector-im/elem…
t3chguy Jan 8, 2025
668da48
Iterate
t3chguy Jan 9, 2025
3d93ab8
Remove test code
t3chguy Jan 9, 2025
658527c
Iterate
t3chguy Jan 9, 2025
f3bbfae
React to sentinel changes in EventListSummary
t3chguy Jan 9, 2025
3051a95
Iterate
t3chguy Jan 9, 2025
e8910d9
Iterate
t3chguy Jan 9, 2025
40d9b3e
Merge branch 't3chguy/sentinels' of https://github.com/vector-im/elem…
t3chguy Jan 9, 2025
45607bb
Docs
t3chguy Jan 10, 2025
1b8f62a
Avoid reusing user1234
t3chguy Jan 10, 2025
b203e4b
Fix stale-screenshot-reporter.ts
t3chguy Jan 10, 2025
3eeb221
Clean up public rooms between tests on reused homeserver
t3chguy Jan 10, 2025
b7b650e
Deflake spotlight when homeserver is reused
t3chguy Jan 10, 2025
c25c8a3
Deflake more tests using existing username
t3chguy Jan 10, 2025
db47e68
Clean mailhog between tests
t3chguy Jan 10, 2025
c75da32
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 10, 2025
8f68dbb
Fix more flakes
t3chguy Jan 10, 2025
548d45a
Fix missing _request
t3chguy Jan 10, 2025
8b3ffb4
Iterate
t3chguy Jan 10, 2025
71f06cd
Iterate
t3chguy Jan 10, 2025
1a98f8c
Iterate
t3chguy Jan 10, 2025
0f6f047
Iterate
t3chguy Jan 10, 2025
ad0b86c
Fix playwright flaky tests
t3chguy Jan 10, 2025
6a62ae5
Wipe mailhog between test runs
t3chguy Jan 10, 2025
f03ad7b
Delint
t3chguy Jan 10, 2025
6e36a1f
Iterate
t3chguy Jan 10, 2025
344a7a0
Merge branch 't3chguy/flaky-tests-10jan2' of https://github.com/vecto…
t3chguy Jan 13, 2025
c1c98d3
delint
t3chguy Jan 13, 2025
5e9066e
Deflake more tests
t3chguy Jan 13, 2025
c8e4625
Iterate
t3chguy Jan 13, 2025
84dfc5d
Fix flaky tests
t3chguy Jan 13, 2025
c25a2f4
Merge branch 'develop' into t3chguy/flaky-tests-10jan
t3chguy Jan 13, 2025
d7a1c30
Fix flaky tests
t3chguy Jan 13, 2025
7fbf9ef
Fix mas config
t3chguy Jan 13, 2025
d27b558
Fix another flaky test
t3chguy Jan 13, 2025
7de0ddd
Merge branch 't3chguy/flaky-playwright-13jan' of https://github.com/v…
t3chguy Jan 13, 2025
0aea827
Merge remote-tracking branch 'origin/t3chguy/flaky-tests-10jan' into …
t3chguy Jan 13, 2025
d8d3ebc
Fix playwright flakes due to floating promises
t3chguy Jan 13, 2025
0124584
Iterate
t3chguy Jan 13, 2025
2cd4088
Iterate
t3chguy Jan 13, 2025
a1fc44d
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 13, 2025
d87dff6
Merge branch 't3chguy/flaky-playwright-13jan' of https://github.com/v…
t3chguy Jan 13, 2025
26e1a9b
Fix flaky playwright tests
t3chguy Jan 13, 2025
6509a61
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 13, 2025
91d818a
Merge branch 't3chguy/flaky-tests-10jan' of https://github.com/vector…
t3chguy Jan 13, 2025
6544144
Merge branch 't3chguy/playwright-flakes-floating-promises' of https:/…
t3chguy Jan 13, 2025
1f43b88
Merge branch 't3chguy/flaky-playwright-13jan2' of https://github.com/…
t3chguy Jan 13, 2025
c7c9c9a
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 13, 2025
0e7c40c
Iterate
t3chguy Jan 13, 2025
cae93fa
Iterate
t3chguy Jan 13, 2025
70c14af
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 13, 2025
f02967e
Iterate
t3chguy Jan 13, 2025
3b4ca5e
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 13, 2025
07fc948
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 13, 2025
a565e53
Merge branch 't3chguy/flaky-tests-10jan' of https://github.com/vector…
t3chguy Jan 13, 2025
504f352
Iterate
t3chguy Jan 13, 2025
2356459
Iterate
t3chguy Jan 13, 2025
53b2e30
Iterate
t3chguy Jan 13, 2025
4ad16af
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 14, 2025
7b69861
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 14, 2025
2c093b8
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 14, 2025
e182f41
Merge branch 't3chguy/flaky-tests-10jan' of https://github.com/vector…
t3chguy Jan 14, 2025
84bc096
Iterate
t3chguy Jan 14, 2025
58af471
Merge branch 'develop' of https://github.com/vector-im/element-web in…
t3chguy Jan 14, 2025
a7ec37f
Update services.ts
t3chguy Jan 14, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .github/workflows/end-to-end-tests.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,8 @@ jobs:
- Chrome
- Firefox
- WebKit
- Dendrite
- Pinecone
runAllTests:
- ${{ github.event_name == 'schedule' || contains(github.event.pull_request.labels.*.name, 'X-Run-All-Tests') }}
# Skip the Firefox & Safari runs unless this was a cron trigger or PR has X-Run-All-Tests label
Expand All @@ -122,6 +124,10 @@ jobs:
project: Firefox
- runAllTests: false
project: WebKit
- runAllTests: false
project: Dendrite
- runAllTests: false
project: Pinecone
steps:
- uses: actions/checkout@v4
with:
Expand Down
4 changes: 2 additions & 2 deletions docs/playwright.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,11 +66,11 @@ as is typical for Playwright tests. Likewise, tests live in `playwright/e2e`.
of Synapse/Dendrite. These servers are what Element-web runs against in the tests.

Synapse can be launched with different configurations in order to test element
in different configurations. You can specify `synapseConfigOptions` as such:
in different configurations. You can specify `synapseConfig` as such:

```typescript
test.use({
synapseConfigOptions: {
synapseConfig: {
// The config options to pass to the Synapse instance
},
});
Expand Down
36 changes: 29 additions & 7 deletions playwright.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,19 +8,25 @@ Please see LICENSE files in the repository root for full details.

import { defineConfig, devices } from "@playwright/test";

import { Options } from "./playwright/services";

const baseURL = process.env["BASE_URL"] ?? "http://localhost:8080";

export default defineConfig({
const chromeProject = {
...devices["Desktop Chrome"],
channel: "chromium",
permissions: ["clipboard-write", "clipboard-read", "microphone"],
launchOptions: {
args: ["--use-fake-ui-for-media-stream", "--use-fake-device-for-media-stream", "--mute-audio"],
},
};

export default defineConfig<Options>({
projects: [
{
name: "Chrome",
use: {
...devices["Desktop Chrome"],
channel: "chromium",
permissions: ["clipboard-write", "clipboard-read", "microphone"],
launchOptions: {
args: ["--use-fake-ui-for-media-stream", "--use-fake-device-for-media-stream", "--mute-audio"],
},
...chromeProject,
},
},
{
Expand Down Expand Up @@ -48,6 +54,22 @@ export default defineConfig({
},
ignoreSnapshots: true,
},
{
name: "Dendrite",
use: {
...chromeProject,
homeserverType: "dendrite",
},
ignoreSnapshots: true,
},
{
name: "Pinecone",
use: {
...chromeProject,
homeserverType: "pinecone",
},
ignoreSnapshots: true,
},
],
use: {
viewport: { width: 1280, height: 720 },
Expand Down
2 changes: 1 addition & 1 deletion playwright/e2e/create-room/create-room.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ test.describe("Create Room", () => {
// Submit
await dialog.getByRole("button", { name: "Create room" }).click();

await expect(page).toHaveURL(/\/#\/room\/#test-room-1:localhost/);
await expect(page).toHaveURL(new RegExp(`/#/room/#test-room-1:${user.homeServer}`));
const header = page.locator(".mx_RoomHeader");
await expect(header).toContainText(name);
});
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/crypto/backups.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ Please see LICENSE files in the repository root for full details.
import { type Page } from "@playwright/test";

import { test, expect } from "../../element-web-test";
import { isDendrite } from "../../plugins/homeserver/dendrite";

async function expectBackupVersionToBe(page: Page, version: string) {
await expect(page.locator(".mx_SecureBackupPanel_statusList tr:nth-child(5) td")).toHaveText(
Expand All @@ -19,6 +20,7 @@ async function expectBackupVersionToBe(page: Page, version: string) {
}

test.describe("Backups", () => {
test.skip(isDendrite, "Dendrite lacks support for MSC3967 so requires additional auth here");
test.use({
displayName: "Hanako",
});
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/crypto/complete-security.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,10 @@ Please see LICENSE files in the repository root for full details.

import { test, expect } from "../../element-web-test";
import { logIntoElement } from "./utils";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Complete security", () => {
test.skip(isDendrite, "Dendrite lacks support for MSC3967 so requires additional auth here");
test.use({
displayName: "Jeff",
});
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/crypto/crypto.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import { expect, test } from "../../element-web-test";
import { autoJoin, copyAndContinue, createSharedRoomWithUser, enableKeyBackup, verify } from "./utils";
import { Bot } from "../../pages/bot";
import { ElementAppPage } from "../../pages/ElementAppPage";
import { isDendrite } from "../../plugins/homeserver/dendrite";

const checkDMRoom = async (page: Page) => {
const body = page.locator(".mx_RoomView_body");
Expand Down Expand Up @@ -67,6 +68,7 @@ const bobJoin = async (page: Page, bob: Bot) => {
};

test.describe("Cryptography", function () {
test.skip(isDendrite, "Dendrite lacks support for MSC3967 so requires additional auth here");
test.use({
displayName: "Alice",
botCreateOpts: {
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/crypto/decryption-failure-messages.spec.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/*

Check failure on line 1 in playwright/e2e/crypto/decryption-failure-messages.spec.ts

View workflow job for this annotation

GitHub Actions / Run Tests [Chrome] 1/6

[Chrome] › crypto/decryption-failure-messages.spec.ts:33:13 › Cryptography › decryption failure messages › should handle device-relative historical messages

1) [Chrome] › crypto/decryption-failure-messages.spec.ts:33:13 › Cryptography › decryption failure messages › should handle device-relative historical messages Test timeout of 60000ms exceeded.
Copyright 2024 New Vector Ltd.
Copyright 2022-2024 The Matrix.org Foundation C.I.C.

Expand Down Expand Up @@ -28,6 +28,8 @@
});

test.describe("decryption failure messages", () => {
test.skip(isDendrite, "Dendrite lacks support for MSC3967 so requires additional auth here");

test("should handle device-relative historical messages", async ({
homeserver,
page,
Expand Down Expand Up @@ -63,7 +65,7 @@
// Finally, log out again, and back in, skipping verification for now, and see what we see.
await logOutOfElement(page);
await logIntoElement(page, credentials);
await page.locator(".mx_AuthPage").getByRole("button", { name: "Skip verification for now" }).click();

Check failure on line 68 in playwright/e2e/crypto/decryption-failure-messages.spec.ts

View workflow job for this annotation

GitHub Actions / Run Tests [Chrome] 1/6

[Chrome] › crypto/decryption-failure-messages.spec.ts:33:13 › Cryptography › decryption failure messages › should handle device-relative historical messages

1) [Chrome] › crypto/decryption-failure-messages.spec.ts:33:13 › Cryptography › decryption failure messages › should handle device-relative historical messages Error: locator.click: Test timeout of 60000ms exceeded. Call log: - waiting for locator('.mx_AuthPage').getByRole('button', { name: 'Skip verification for now' }) 66 | await logOutOfElement(page); 67 | await logIntoElement(page, credentials); > 68 | await page.locator(".mx_AuthPage").getByRole("button", { name: "Skip verification for now" }).click(); | ^ 69 | await page.locator(".mx_AuthPage").getByRole("button", { name: "I'll verify later" }).click(); 70 | await app.viewRoomByName("Test room"); 71 | at /home/runner/work/element-web/element-web/playwright/e2e/crypto/decryption-failure-messages.spec.ts:68:107
await page.locator(".mx_AuthPage").getByRole("button", { name: "I'll verify later" }).click();
await app.viewRoomByName("Test room");

Expand Down
7 changes: 4 additions & 3 deletions playwright/e2e/crypto/device-verification.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -219,9 +219,10 @@ test.describe("Device verification", { tag: "@no-webkit" }, () => {
/* And we're all done! */
const infoDialog = page.locator(".mx_InfoDialog");
await infoDialog.getByRole("button", { name: "They match" }).click();
await expect(
infoDialog.getByText(`You've successfully verified (${aliceBotClient.credentials.deviceId})!`),
).toBeVisible();
// We don't assert the full string as the device name is unset on Synapse but set to the user ID on Dendrite
await expect(infoDialog.getByText(`You've successfully verified`)).toContainText(
`(${aliceBotClient.credentials.deviceId})`,
);
await infoDialog.getByRole("button", { name: "Got it" }).click();
});
});
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/crypto/logout.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,10 @@ Please see LICENSE files in the repository root for full details.

import { test, expect } from "../../element-web-test";
import { createRoom, enableKeyBackup, logIntoElement, sendMessageInCurrentRoom } from "./utils";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Logout tests", () => {
test.skip(isDendrite, "Dendrite lacks support for MSC3967 so requires additional auth here");
test.beforeEach(async ({ page, homeserver, credentials }) => {
await logIntoElement(page, credentials);
});
Expand Down
3 changes: 3 additions & 0 deletions playwright/e2e/editing/editing.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import type { EventType, IContent, ISendEventResponse, MsgType, Visibility } fro
import { expect, test } from "../../element-web-test";
import { ElementAppPage } from "../../pages/ElementAppPage";
import { SettingLevel } from "../../../src/settings/SettingLevel";
import { isDendrite } from "../../plugins/homeserver/dendrite";

async function sendEvent(app: ElementAppPage, roomId: string): Promise<ISendEventResponse> {
return app.client.sendEvent(roomId, null, "m.room.message" as EventType, {
Expand All @@ -31,6 +32,8 @@ function mkPadding(n: number): IContent {
}

test.describe("Editing", () => {
test.skip(isDendrite, "due to a Dendrite bug https://github.com/element-hq/dendrite/issues/3488");

// Edit "Message"
const editLastMessage = async (page: Page, edit: string) => {
const eventTile = page.locator(".mx_RoomView_MessageList .mx_EventTile_last");
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/knock/create-knock-room.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,10 @@ Please see LICENSE files in the repository root for full details.
import { test, expect } from "../../element-web-test";
import { waitForRoom } from "../utils";
import { Filter } from "../../pages/Spotlight";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Create Knock Room", () => {
test.skip(isDendrite, "Dendrite does not have support for knocking");
test.use({
displayName: "Alice",
labsFlags: ["feature_ask_to_join"],
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/knock/knock-into-room.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,10 @@ import { type Visibility } from "matrix-js-sdk/src/matrix";
import { test, expect } from "../../element-web-test";
import { waitForRoom } from "../utils";
import { Filter } from "../../pages/Spotlight";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Knock Into Room", () => {
test.skip(isDendrite, "Dendrite does not have support for knocking");
test.use({
displayName: "Alice",
labsFlags: ["feature_ask_to_join"],
Expand Down
2 changes: 2 additions & 0 deletions playwright/e2e/knock/manage-knocks.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,10 @@ Please see LICENSE files in the repository root for full details.

import { test, expect } from "../../element-web-test";
import { waitForRoom } from "../utils";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Manage Knocks", () => {
test.skip(isDendrite, "Dendrite does not have support for knocking");
test.use({
displayName: "Alice",
labsFlags: ["feature_ask_to_join"],
Expand Down
28 changes: 22 additions & 6 deletions playwright/e2e/lazy-loading/lazy-loading.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,12 @@ import { Bot } from "../../pages/bot";
import type { Locator, Page } from "@playwright/test";
import type { ElementAppPage } from "../../pages/ElementAppPage";
import { test, expect } from "../../element-web-test";
import { Credentials } from "../../plugins/homeserver";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Lazy Loading", () => {
test.skip(isDendrite, "due to a Dendrite bug https://github.com/element-hq/dendrite/issues/3488");

const charlies: Bot[] = [];

test.use({
Expand All @@ -35,12 +39,18 @@ test.describe("Lazy Loading", () => {
});

const name = "Lazy Loading Test";
const alias = "#lltest:localhost";
const charlyMsg1 = "hi bob!";
const charlyMsg2 = "how's it going??";
let roomId: string;

async function setupRoomWithBobAliceAndCharlies(page: Page, app: ElementAppPage, bob: Bot, charlies: Bot[]) {
async function setupRoomWithBobAliceAndCharlies(
page: Page,
app: ElementAppPage,
user: Credentials,
bob: Bot,
charlies: Bot[],
) {
const alias = `#lltest:${user.homeServer}`;
const visibility = await page.evaluate(() => (window as any).matrixcs.Visibility.Public);
roomId = await bob.createRoom({
name,
Expand Down Expand Up @@ -95,7 +105,13 @@ test.describe("Lazy Loading", () => {
}
}

async function joinCharliesWhileAliceIsOffline(page: Page, app: ElementAppPage, charlies: Bot[]) {
async function joinCharliesWhileAliceIsOffline(
page: Page,
app: ElementAppPage,
user: Credentials,
charlies: Bot[],
) {
const alias = `#lltest:${user.homeServer}`;
await app.client.network.goOffline();
for (const charly of charlies) {
await charly.joinRoom(alias);
Expand All @@ -107,19 +123,19 @@ test.describe("Lazy Loading", () => {
await app.client.waitForNextSync();
}

test("should handle lazy loading properly even when offline", async ({ page, app, bot }) => {
test("should handle lazy loading properly even when offline", async ({ page, app, bot, user }) => {
test.slow();
const charly1to5 = charlies.slice(0, 5);
const charly6to10 = charlies.slice(5);

// Set up room with alice, bob & charlies 1-5
await setupRoomWithBobAliceAndCharlies(page, app, bot, charly1to5);
await setupRoomWithBobAliceAndCharlies(page, app, user, bot, charly1to5);
// Alice should see 2 messages from every charly with the correct display name
await checkPaginatedDisplayNames(app, charly1to5);

await openMemberlist(app);
await checkMemberList(page, charly1to5);
await joinCharliesWhileAliceIsOffline(page, app, charly6to10);
await joinCharliesWhileAliceIsOffline(page, app, user, charly6to10);
await checkMemberList(page, charly6to10);

for (const charly of charlies) {
Expand Down
3 changes: 3 additions & 0 deletions playwright/e2e/login/login-consent.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import { expect, test } from "../../element-web-test";
import { selectHomeserver } from "../utils";
import { Credentials, HomeserverInstance } from "../../plugins/homeserver";
import { consentHomeserver } from "../../plugins/homeserver/synapse/consentHomeserver.ts";
import { isDendrite } from "../../plugins/homeserver/dendrite";

// This test requires fixed credentials for the device signing keys below to work
const username = "user1234";
Expand Down Expand Up @@ -113,6 +114,8 @@ test.use({

test.describe("Login", () => {
test.describe("Password login", () => {
test.skip(isDendrite, "Dendrite lacks support for MSC3967 so requires additional auth here");

test("Loads the welcome page by default; then logs in with an existing account and lands on the home screen", async ({
credentials,
page,
Expand Down
2 changes: 0 additions & 2 deletions playwright/e2e/oidc/oidc-native.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,10 @@ Please see LICENSE files in the repository root for full details.
import { test, expect } from "../../element-web-test.ts";
import { registerAccountMas } from ".";
import { ElementAppPage } from "../../pages/ElementAppPage.ts";
import { isDendrite } from "../../plugins/homeserver/dendrite";
import { masHomeserver } from "../../plugins/homeserver/synapse/masHomeserver.ts";

test.use(masHomeserver);
test.describe("OIDC Native", { tag: ["@no-firefox", "@no-webkit"] }, () => {
test.skip(isDendrite, "does not yet support MAS");
test.slow(); // trace recording takes a while here

test("can register the oauth2 client and an account", async ({
Expand Down
3 changes: 3 additions & 0 deletions playwright/e2e/one-to-one-chat/one-to-one-chat.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,15 @@ Please see LICENSE files in the repository root for full details.

import { test as base, expect } from "../../element-web-test";
import { Credentials } from "../../plugins/homeserver";
import { isDendrite } from "../../plugins/homeserver/dendrite";

const test = base.extend<{
user2?: Credentials;
}>({});

test.describe("1:1 chat room", () => {
test.skip(isDendrite, "due to a Dendrite bug https://github.com/element-hq/dendrite/issues/3492");

test.use({
displayName: "Jeff",
user2: async ({ homeserver }, use, testInfo) => {
Expand Down
2 changes: 1 addition & 1 deletion playwright/e2e/permalinks/permalinks.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ test.describe("permalinks", () => {
await charlotte.prepareClient();

// We don't use a bot for danielle as we want a stable MXID.
const danielleId = "@danielle:localhost";
const danielleId = `@danielle:${user.homeServer}`;

const room1Id = await app.client.createRoom({ name: room1Name });
const room2Id = await app.client.createRoom({ name: room2Name });
Expand Down
3 changes: 3 additions & 0 deletions playwright/e2e/polls/polls.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,11 @@ import { Bot } from "../../pages/bot";
import { SettingLevel } from "../../../src/settings/SettingLevel";
import { Layout } from "../../../src/settings/enums/Layout";
import type { Locator, Page } from "@playwright/test";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Polls", () => {
test.skip(isDendrite, "due to a Dendrite bug https://github.com/element-hq/dendrite/issues/3492");

type CreatePollOptions = {
title: string;
options: string[];
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,11 @@ Please see LICENSE files in the repository root for full details.
/* See readme.md for tips on writing these tests. */

import { test } from ".";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Read receipts", { tag: "@mergequeue" }, () => {
test.skip(isDendrite, "due to Dendrite bug https://github.com/element-hq/dendrite/issues/2970");

test.describe("editing messages", () => {
test.describe("in threads", () => {
test("An edit of a threaded message makes the room unread", async ({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,11 @@ Please see LICENSE files in the repository root for full details.
/* See readme.md for tips on writing these tests. */

import { test } from ".";
import { isDendrite } from "../../plugins/homeserver/dendrite";

test.describe("Read receipts", { tag: "@mergequeue" }, () => {
test.skip(isDendrite, "due to Dendrite bug https://github.com/element-hq/dendrite/issues/2970");

test.describe("editing messages", () => {
test.describe("in the main timeline", () => {
test("Editing a message leaves a room read", async ({ roomAlpha: room1, roomBeta: room2, util, msg }) => {
Expand Down
Loading
Loading