๐ง Building Playwright Framework Step By Step - Implementing POM as Fixture and Auth User Session

๐ฏ Introduction
Fixtures in Playwright provide a powerful mechanism to set up the environment for your tests, manage resources, and share common objects or context across multiple tests! ๐ These reusable components allow you to define custom setup and teardown procedures that automate the preparation and cleanup processes, ensuring a consistent testing environment and optimizing your workflows.
๐ก What are Fixtures?: Think of fixtures as your testing toolkit - they provide the foundation and tools your tests need to run consistently and efficiently.
โ Prerequisites
This article builds directly on the concepts from previous ones. To get the most out of it, you should have:
๐ ๏ธ Implement POM (Page Object Model) as Fixture
๐ Create Fixtures Folder
Create fixtures/pom folders in the root directory of the project.
project-root/
โโโ fixtures/
โ โโโ pom/
โ โโโ page-object-fixture.ts
โ โโโ test-options.ts
โโโ tests/
โโโ playwright.config.ts
๐ญ Create Fixtures Files
Create and implement fixtures for the client site for all pages of the application.
๐ง Page Object Fixture
page-object-fixture.ts: This file is used for extending the test fixture from@playwright/test
import { test as base } from '@playwright/test';
import { HomePage } from '../../pages/clientSite/homePage';
import { NavPage } from '../../pages/clientSite/navPage';
import { ArticlePage } from '../../pages/clientSite/articlePage';
export type FrameworkFixtures = {
homePage: HomePage;
navPage: NavPage;
articlePage: ArticlePage;
};
export const test = base.extend<FrameworkFixtures>({
homePage: async ({ page }, use) => {
await use(new HomePage(page));
},
navPage: async ({ page }, use) => {
await use(new NavPage(page));
},
articlePage: async ({ page }, use) => {
await use(new ArticlePage(page));
},
});
export { expect } from '@playwright/test';
โ๏ธ Test Options Configuration
test-options.ts: This file is used for merging all extended test fixtures
import { test as base, mergeTests } from '@playwright/test';
import { test as pageObjectFixture } from './page-object-fixture';
const test = mergeTests(pageObjectFixture);
const expect = base.expect;
export { test, expect };
๐ Implement Auth User Session
๐ฏ Strategic Advantage: Leveraging authenticated user sessions in Playwright is a strategic approach to streamline testing of password-protected applications!
This method involves pre-creating and reusing authentication tokens or session information, allowing automated tests to bypass the login UI. It significantly reduces the time and resources required for tests that need an authenticated user context, enhancing test efficiency and reliability.
๐ Advantages of Using Authenticated User Sessions in Playwright:
โก Speed: Directly using authenticated sessions eliminates the overhead of navigating through login screens for each test, accelerating the test execution process
๐ก๏ธ Stability: Tests become less prone to failures related to UI changes in the authentication flow, increasing their reliability
๐ฏ Focus: Allows tests to concentrate on the core functionalities that require authentication, rather than the login process itself, making them more targeted and concise
๐ Create Auth Script File
Create auth.setup.ts file in the test directory of the project.
import { test as setup } from '../fixtures/pom/test-options';
setup('auth user', async ({ homePage, navPage, page }) => {
await setup.step('create logged in user session', async () => {
await homePage.navigateToHomePageGuest();
await navPage.logIn(process.env.EMAIL!, process.env.PASSWORD!);
await page.context().storageState({ path: '.auth/userSession.json' });
});
});
โ๏ธ Update Configuration File
Add the following configuration to your playwright.config.ts:
projects: [
{
name: 'setup',
use: {
...devices['Desktop Chrome'],
viewport: { width: 1366, height: 768 },
},
testMatch: /.*\.setup\.ts/,
},
{
name: 'chromium',
use: {
...devices['Desktop Chrome'],
storageState: '.auth/userSession.json',
viewport: { width: 1366, height: 768 },
},
dependencies: ['setup'],
},
{
name: 'firefox',
use: { ...devices['Desktop Firefox'] },
},
{
name: 'webkit',
use: { ...devices['Desktop Safari'] },
},
],
๐ Add File to .gitignore
โ ๏ธ Security Best Practice: Add
userSession.jsonfile to.gitignorefile in the root directory of the project.
# Authentication User file
userSession.json
๐โโ๏ธ Create Auth User Session
Run the auth.setup.ts file to create auth user session:
npx playwright test auth.setup.ts
๐ค Create Guest User Session
Create guestSession.json file in the .auth directory of the project and add {} to it.
๐ก Guest Sessions: Empty JSON object represents an unauthenticated state for tests that require guest access.
๐ฏ What's Next?
In the next article we will implement UI Tests - bringing your framework to life with comprehensive user interface testing!
๐ฌ Community: Please feel free to initiate discussions on this topic, as every contribution has the potential to drive further refinement.
โจ Ready to enhance your testing capabilities? Let's continue building this robust framework together!
๐๐ป Thank you for reading! Building robust, scalable automation frameworks is a journey best taken together. If you found this article helpful, consider joining a growing community of QA professionals ๐ who are passionate about mastering modern testing.
Join the community and get the latest articles and tips by signing up for the newsletter.






