In Playwright (Like many other automation frameworks) you can create page objects. Using an example from Playwrights documentation: https://playwright.dev/docs/test-fixtures#without-fixtures
You have a .spec file that looks like this (The actual page object class itself can be seen above, not posting it just because it's long):
const { test } = require('@playwright/test');
const { TodoPage } = require('./todo-page');
test.describe('todo tests', () => {
let todoPage;
test.beforeEach(async ({ page }) => {
todoPage = new TodoPage(page);
await todoPage.goto();
await todoPage.addToDo('item1');
await todoPage.addToDo('item2');
});
test.afterEach(async () => {
await todoPage.removeAll();
});
test('should add an item', async () => {
await todoPage.addToDo('my item');
// ...
});
test('should remove an item', async () => {
await todoPage.remove('item1');
// ...
});
});
However I wonder in such a case is there really a need to re-create the page object before each test? Wouldn't creating the page object once be good enough? (Since we would have access to all the methods/etc... and those shouldn't be changing between tests?
Is there any reason to re-create a page object for each test?
Use beforeAll
to instantiate page object so that all tests in a file can share the page
object as todoPage is suite level variable declared outside any test.
test.beforeAll(async ({ page }) => {
todoPage = new TodoPage(page);
});
The Playwright Docs suggest to use as beforeEach to promote test isolation so that tests can be run in parallel as they should be absolutely independent.