Skip to content

Commit

Permalink
Improved end-to-end tests structure
Browse files Browse the repository at this point in the history
* using a page object to abstract things away
* mocking an HTML page to load custom configs
  • Loading branch information
felixgirault committed Jan 16, 2025
1 parent 71799ef commit 1c7ac65
Show file tree
Hide file tree
Showing 3 changed files with 226 additions and 169 deletions.
114 changes: 114 additions & 0 deletions e2e/OrejimePage.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,114 @@
import {expect, BrowserContext, Page} from '@playwright/test';
import Cookie from 'js-cookie';
import {Config} from '../src/ui';

export class OrejimePage {
constructor(
public readonly page: Page,
public readonly context: BrowserContext
) {}

async load(config: Partial<Config>) {
await this.page.route('/', async (route) => {
await route.fulfill({
body: `
<!DOCTYPE html>
<html>
<head>
<title>Orejime</title>
<link rel="stylesheet" href="orejime.css" />
</head>
<body>
<script>
window.orejimeConfig = ${JSON.stringify(config)}
</script>
<script src="orejime.js"></script>
</body>
</html>
`
});
});

await this.page.goto('/');
}

get banner() {
return this.page.locator('.orejime-Banner');
}

get leanMoreBannerButton() {
return this.page.locator('.orejime-Banner-learnMoreButton');
}

get firstFocusableElementFromBanner() {
return this.page.locator('.orejime-Banner :is(a, button)').first();
}

get modal() {
return this.page.locator('.orejime-Modal');
}

purposeCheckbox(purposeId: string) {
return this.page.locator(`#orejime-purpose-${purposeId}`);
}

async focusNext() {
await this.page.keyboard.press('Tab');
}

async acceptAllFromBanner() {
await this.page.locator('.orejime-Banner-saveButton').click();
}

async declineAllFromBanner() {
await this.page.locator('.orejime-Banner-declineButton').click();
}

async openModalFromBanner() {
await this.leanMoreBannerButton.click();
}

async enableAllFromModal() {
await this.page.locator('.orejime-PurposeToggles-enableAll').click();
}

async disableAllFromModal() {
await this.page.locator('.orejime-PurposeToggles-disableAll').click();
}

async saveFromModal() {
await this.page.locator('.orejime-Modal-saveButton').click();
}

async closeModalByClickingButton() {
await this.page.locator('.orejime-Modal-closeButton').click();
}

async closeModalByClickingOutside() {
// We're clicking in a corner to avoid clicking on the
// modal itself, which has no effect.
await this.page.locator('.orejime-ModalOverlay').click({
position: {
x: 1,
y: 1
}
});
}

async closeModalByPressingEscape() {
await this.page.keyboard.press('Escape');
}

async expectConsents(consents: Record<string, unknown>) {
expect(await this.getConsentsFromCookies()).toEqual(consents);
}

async getConsentsFromCookies() {
const name = 'eu-consent';
const cookies = await this.context.cookies();
const {value} = cookies.find((cookie) => cookie.name === name)!;
return JSON.parse(Cookie.converter.read(value, name));
}
}
9 changes: 0 additions & 9 deletions e2e/demo.spec.ts

This file was deleted.

Loading

0 comments on commit 1c7ac65

Please sign in to comment.