Search code examples
playwrightpageobjects

Re-Creating Page Objects in Playwright?


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?


Solution

  • 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.