search
HomeWeb Front-endJS TutorialSupercharge Your ETests with Playwright and Cucumber Integration

Supercharge Your ETests with Playwright and Cucumber Integration

Introduction

In this post, I'll walk you through why Playwright and Cucumber are exceptional tools for end-to-end (E2E) testing. We'll then dive into the steps for integrating Playwright for seamless usage in a JavaScript frontend application. Finally, I'll share some pro tips to maximize your efficiency with Playwright.

Why Playwright and Cucumber?

While there are numerous capable tools for building E2E test suites, none match the synergy of Playwright and Cucumber.

Here’s why Playwright stands out in the market to write E2E tests, to name a few:

  • 1. Any browser, Any platform, One API
    • a. Cross-browser. Playwright supports all modern rendering engines including Chromium, WebKit, and Firefox.
    • b. Cross-platform. Test on Windows, Linux, and macOS, locally or on CI, headless or headed.
    • c. Cross-language. Use the Playwright API in TypeScript, JavaScript, Python, .NET, and Java.
  • 2. Resilient, No flaky tests
    • a. Auto-wait. The playwright waits for elements to be actionable before performing actions.
    • b. Web-first assertions. Playwright assertions are created specifically for the dynamic web.
  • 3. Powerful Tooling
    • a. Codegen. Generate tests by recording your actions. Save them in any language.
    • b. Playwright inspector. Inspect the page, generate selectors, step through the test execution, see click points, and explore execution logs.

However, without Cucumber managing test code can become a maintenance nightmare. Cucumber facilitates writing tests in plain, human-readable language, making them accessible even to non-technical stakeholders. As a cornerstone of Behavior Driven Development (BDD), Cucumber acts as technical documentation and accelerates onboarding for new engineers.

Integration of Playwright and Cucumber

Step 1: Install Dependencies

Install the necessary packages using npm or yarn.

npm install @playwright/test playwright-core @cucumber/cucumber cucumber-html-reporter concurrently

Step 2: Setup Project Structure

Organize your project like this:

cucumber.js
cucumber.report.js
/e2e
  /features
    example.feature
  /steps
    example.steps.js

Step 3: Configure Cucumber

Create a Cucumber Configuration File - cucumber.js file in the root of your project with the following content:

// filepath: /cucumber.js
module.exports = {
  default: {
    require: ["./steps/**/*.js"],
    format: ["pretty"],
    paths: ["./features/**/*.feature"],
  },
};

Step 4: Configure Test Reporting

Create cucumber.report.js - A file to configure the test report. Configuration options can be found here

// filepath: /cucumber.report.js
import reporter from 'cucumber-html-reporter

const options = {
  theme: 'bootstrap',
  output: report/report.html',
  jsonFile: 'report/report.json',
  brandTitle: 'E2E Test Report'
};

Step 5: Write a Feature File

Create a feature file in the features directory, e.g., example.feature:

npm install @playwright/test playwright-core @cucumber/cucumber cucumber-html-reporter concurrently

Step 6: Write Step Definitions

Create a step definition file in the steps directory, e.g., example.steps.js:

cucumber.js
cucumber.report.js
/e2e
  /features
    example.feature
  /steps
    example.steps.js

Step 7: Add a NPM Test Script

Add a script to your package.json to run the tests:

// filepath: /cucumber.js
module.exports = {
  default: {
    require: ["./steps/**/*.js"],
    format: ["pretty"],
    paths: ["./features/**/*.feature"],
  },
};

concurrently npm package is a handy tool that lets you execute two processes at the same test, as to execute the E2E test you'll need to run the application as well, sometimes locally and sometimes remotely.

Step 8: Run Tests

Execute tests with:

// filepath: /cucumber.report.js
import reporter from 'cucumber-html-reporter

const options = {
  theme: 'bootstrap',
  output: report/report.html',
  jsonFile: 'report/report.json',
  brandTitle: 'E2E Test Report'
};

Playwright Pro Tips

  • 1. Error Messages - Read them carefully—they often pinpoint the problem.
  • 2. Iterative Development - Test small chunks of code to isolate and resolve issues.
  • 3. Playwright Inspector - It can help to record actions and generate test scripts automatically, so would have to write just a piece of code. You can launch Playwright Inspector as below
// filepath: /e2e/features/example.feature
Feature: Example feature

  Scenario: Open a webpage
    Given I open the "https://example.com" page
    Then the title should be "Example.com"
  • 4. Log Console Messages - Print browser console message in headless mode as below
// filepath: /e2e/steps/example.steps.js
import { Before, Given, Then, setDefaultTimeout, After } from '@cucumber/cucumber';
import { chromium, expect } from 'playwright';

setDefaultTimeout(30 * 1000); //milliseconds
let browser, page, context;

Before(async function(){
  browser = await chromium.launch({headless: true});
  context = await brwoser.newContext();
  page = await content.newPage();
});

Given('I open the {string} page', async function (url) {
  await page.goto(url);
});

Then('the title should be {string}', async function (title) {
  const pageTitle = await page.title();
  expect(pageTitle).toHaveText(title);
});

After(async function(){
  await context.close();
  await browser.close();
});
  • 5. Handle Lazy Loading - For lazy loading elements, use the following functions
    • a. waitForSelector or waitFor
    • b. waitForTimeout
    • c. scrollIntoViewIfNeeded
  • 6. Debug DOM - Use document.querySelector or other query selector in the browser console to locate the elements
  • 7. Capture a screenshot of the failure

If you have reached here, then I made a satisfactory effort to keep you reading. Please be kind enough to leave any comments or share corrections.

My Other Blogs:

  • Integrate Web Component/MFE with plain static HTML
  • Cracking Software Engineering Interviews
  • My firsthand experience with web component - learnings and limitations
  • Micro-Frontend Decision Framework
  • Test SOAP Web Service using Postman Tool

The above is the detailed content of Supercharge Your ETests with Playwright and Cucumber Integration. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
JavaScript: Exploring the Versatility of a Web LanguageJavaScript: Exploring the Versatility of a Web LanguageApr 11, 2025 am 12:01 AM

JavaScript is the core language of modern web development and is widely used for its diversity and flexibility. 1) Front-end development: build dynamic web pages and single-page applications through DOM operations and modern frameworks (such as React, Vue.js, Angular). 2) Server-side development: Node.js uses a non-blocking I/O model to handle high concurrency and real-time applications. 3) Mobile and desktop application development: cross-platform development is realized through ReactNative and Electron to improve development efficiency.

The Evolution of JavaScript: Current Trends and Future ProspectsThe Evolution of JavaScript: Current Trends and Future ProspectsApr 10, 2025 am 09:33 AM

The latest trends in JavaScript include the rise of TypeScript, the popularity of modern frameworks and libraries, and the application of WebAssembly. Future prospects cover more powerful type systems, the development of server-side JavaScript, the expansion of artificial intelligence and machine learning, and the potential of IoT and edge computing.

Demystifying JavaScript: What It Does and Why It MattersDemystifying JavaScript: What It Does and Why It MattersApr 09, 2025 am 12:07 AM

JavaScript is the cornerstone of modern web development, and its main functions include event-driven programming, dynamic content generation and asynchronous programming. 1) Event-driven programming allows web pages to change dynamically according to user operations. 2) Dynamic content generation allows page content to be adjusted according to conditions. 3) Asynchronous programming ensures that the user interface is not blocked. JavaScript is widely used in web interaction, single-page application and server-side development, greatly improving the flexibility of user experience and cross-platform development.

Is Python or JavaScript better?Is Python or JavaScript better?Apr 06, 2025 am 12:14 AM

Python is more suitable for data science and machine learning, while JavaScript is more suitable for front-end and full-stack development. 1. Python is known for its concise syntax and rich library ecosystem, and is suitable for data analysis and web development. 2. JavaScript is the core of front-end development. Node.js supports server-side programming and is suitable for full-stack development.

How do I install JavaScript?How do I install JavaScript?Apr 05, 2025 am 12:16 AM

JavaScript does not require installation because it is already built into modern browsers. You just need a text editor and a browser to get started. 1) In the browser environment, run it by embedding the HTML file through tags. 2) In the Node.js environment, after downloading and installing Node.js, run the JavaScript file through the command line.

How to send notifications before a task starts in Quartz?How to send notifications before a task starts in Quartz?Apr 04, 2025 pm 09:24 PM

How to send task notifications in Quartz In advance When using the Quartz timer to schedule a task, the execution time of the task is set by the cron expression. Now...

In JavaScript, how to get parameters of a function on a prototype chain in a constructor?In JavaScript, how to get parameters of a function on a prototype chain in a constructor?Apr 04, 2025 pm 09:21 PM

How to obtain the parameters of functions on prototype chains in JavaScript In JavaScript programming, understanding and manipulating function parameters on prototype chains is a common and important task...

What is the reason for the failure of Vue.js dynamic style displacement in the WeChat mini program webview?What is the reason for the failure of Vue.js dynamic style displacement in the WeChat mini program webview?Apr 04, 2025 pm 09:18 PM

Analysis of the reason why the dynamic style displacement failure of using Vue.js in the WeChat applet web-view is using Vue.js...

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use