DEV Community

Cover image for Playwright's LocatorHandler: Simplifying Web Testing and overlay handling
Gaurav J
Gaurav J

Posted on • Updated on

Playwright's LocatorHandler: Simplifying Web Testing and overlay handling

Ever feel like a whack-a-mole when unexpected elements like cookie consent popups disrupt your Playwright tests? You're not alone. These overlays can block actions and make tests unreliable. But fear not, Playwright's addLocatorHandler comes to the rescue, offering a streamlined solution to handle these interruptions effectively.

What is addLocatorHandler?

Introduced in Playwright version 1.42, addLocatorHandler provides a mechanism to dynamically handle overlays that appear during automated testing. These overlays, like cookie consent dialogs, can block automated actions such as clicking buttons or filling out forms, making tests unreliable and cumbersome to maintain.

How does it work?

The addLocatorHandler method allows you to define a custom function that is triggered whenever a specified element locator is detected on the page. This function, known as a handler, is responsible for removing the overlay or taking any necessary actions to mitigate its impact on the test.

Example Usage:

Let's face a common foe: the cookie consent dialog. We can use addLocatorHandler to automatically dismiss it whenever it appears:

await page.addLocatorHandler(page.getByRole('button', { name: 'Accept all cookies' }), async () => {
  await page.getByRole('button', { name: 'Reject all cookies' }).click();
});

await page.goto('https://example.com');
await page.getByRole('button', { name: 'Start here' }).click();
Enter fullscreen mode Exit fullscreen mode

In this scenario, when the Accept all cookies button appears (our trigger), the handler function clicks the Reject all cookies button instead. This dismisses the dialog and allows your test to proceed as planned.

Benefits of addLocatorHandler:

  1. Improved Test Reliability: By automatically handling overlays, tests become more robust and reliable, reducing the chances of false positives or test failures due to unexpected elements.

  2. Simplified Test Maintenance: With addLocatorHandler, there's no need to manually handle overlays in each test case. The logic to dismiss overlays is centralized, making tests easier to maintain and update.

  3. Enhanced Test Efficiency: By seamlessly handling interruptions, tests can execute more efficiently without unnecessary delays caused by manual intervention or waiting for overlays to disappear.

Learn More:

For more details on using addLocatorHandler, refer to the official Playwright documentation: Here

Conclusion:

In conclusion, addLocatorHandler simplifies handling overlays in Playwright tests, boosting test reliability and efficiency. It empowers testers to focus on core test logic without worrying about unexpected interruptions.

Don’t forget to Follow me on LinkedIn and Github!!

Gaurav J.

Top comments (0)