UNPKG

playwright-cucumber-ts-steps

Version:

A collection of reusable Playwright step definitions for Cucumber in TypeScript, designed to streamline end-to-end testing across web, API, and mobile applications.

222 lines (221 loc) 10.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.Then_I_see_role_with_name = Then_I_see_role_with_name; exports.Then_I_do_not_see_role_with_name = Then_I_do_not_see_role_with_name; exports.Then_I_see_testid = Then_I_see_testid; exports.Then_I_do_not_see_testid = Then_I_do_not_see_testid; exports.Then_I_see_testid_has_attribute_with_value = Then_I_see_testid_has_attribute_with_value; exports.Then_I_see_testid_has_attribute = Then_I_see_testid_has_attribute; exports.Then_I_see_testid_does_not_have_attribute = Then_I_see_testid_does_not_have_attribute; exports.Then_I_see_testid_attribute_contains = Then_I_see_testid_attribute_contains; const cucumber_1 = require("@cucumber/cucumber"); const test_1 = require("@playwright/test"); // =================================================================================== // ASSERTIONS: ROLE-BASED ELEMENTS // =================================================================================== /** * Asserts that an element with the given ARIA role and exact accessible name is visible on the page. * * ```gherkin * Then I see role {string} with name {string} * ``` * * @param role - The ARIA role of the element (e.g., "button", "heading", "textbox"). * @param name - The exact accessible name of the element (e.g., button text, label text). * * @example * Then I see role "button" with name "Submit" * Then I see role "heading" with name "Welcome" * * @remarks * This step uses Playwright's `page.getByRole()` with `exact: true` for precise matching. * It asserts that the matched element is visible in the viewport. * @category Role-Based Assertion Steps */ async function Then_I_see_role_with_name(role, name) { const locator = this.page.getByRole(role, { name, exact: true }); await (0, test_1.expect)(locator).toBeVisible({ timeout: 5000 }); this.log?.(`✅ Verified role "${role}" with name "${name}" is visible.`); } (0, cucumber_1.Then)(/^I see role "(.*)" with name "(.*)"$/, Then_I_see_role_with_name); /** * Asserts that an element with the given ARIA role and exact accessible name does NOT exist in the DOM. * * ```gherkin * Then I do not see role {string} with name {string} * ``` * * @param role - The ARIA role of the element. * @param name - The exact accessible name of the element. * * @example * Then I do not see role "button" with name "Cancel" * Then I do not see role "alert" with name "Error message" * * @remarks * This step uses Playwright's `page.getByRole()` with `exact: true` and asserts that * no such element exists in the DOM (i.e., its count is 0). * @category Role-Based Assertion Steps */ async function Then_I_do_not_see_role_with_name(role, name) { const locator = this.page.getByRole(role, { name, exact: true }); await (0, test_1.expect)(locator).toHaveCount(0, { timeout: 5000 }); this.log?.(`✅ Verified role "${role}" with name "${name}" does NOT exist.`); } (0, cucumber_1.Then)(/^I do not see role "(.*)" with name "(.*)"$/, Then_I_do_not_see_role_with_name); // =================================================================================== // ASSERTIONS: TEST ID-BASED ELEMENTS // =================================================================================== /** * Asserts that an element with the given `data-testid` attribute (or configured test ID) is visible on the page. * * ```gherkin * Then I see testid {string} * ``` * * @param testId - The value of the `data-testid` attribute. * * @example * Then I see testid "main-content" * Then I see testid "user-profile-section" * * @remarks * This step uses Playwright's `page.getByTestId()` and asserts that the matched element is visible. * @category Test ID-Based Assertion Steps */ async function Then_I_see_testid(testId) { const locator = this.page.getByTestId(testId); await (0, test_1.expect)(locator).toBeVisible({ timeout: 5000 }); this.log?.(`✅ Verified test ID "${testId}" is visible.`); } (0, cucumber_1.Then)(/^I see testid "(.*)"$/, Then_I_see_testid); /** * Asserts that an element with the given `data-testid` attribute (or configured test ID) does NOT exist in the DOM. * * ```gherkin * Then I do not see testid {string} * ``` * * @param testId - The value of the `data-testid` attribute. * * @example * Then I do not see testid "sidebar" * Then I do not see testid "legacy-component" * * @remarks * This step uses Playwright's `page.getByTestId()` and asserts that no such element exists (i.e., its count is 0). * @category Test ID-Based Assertion Steps */ async function Then_I_do_not_see_testid(testId) { const locator = this.page.getByTestId(testId); await (0, test_1.expect)(locator).toHaveCount(0, { timeout: 5000 }); this.log?.(`✅ Verified test ID "${testId}" does NOT exist.`); } (0, cucumber_1.Then)(/^I do not see testid "(.*)"$/, Then_I_do_not_see_testid); // =================================================================================== // ASSERTIONS: ATTRIBUTE-BASED ASSERTIONS (on Test ID elements) // =================================================================================== /** * Asserts that an element identified by its `data-testid` has a specific attribute with an exact expected value. * * ```gherkin * Then I see testid {string} has attribute {string} with value {string} * ``` * * @param testId - The value of the `data-testid` attribute. * @param attr - The name of the attribute (e.g., "data-state", "aria-expanded"). * @param value - The exact expected value of the attribute. * * @example * Then I see testid "main-content" has attribute "data-state" with value "active" * Then I see testid "toggle-button" has attribute "aria-pressed" with value "true" * * @remarks * This step uses Playwright's `page.getByTestId()` to find the element and then * `expect(locator).toHaveAttribute()` for the assertion. * @category Test ID-Based Attribute Assertion Steps */ async function Then_I_see_testid_has_attribute_with_value(testId, attr, value) { const locator = this.page.getByTestId(testId); await (0, test_1.expect)(locator).toHaveAttribute(attr, value, { timeout: 5000 }); this.log?.(`✅ Verified test ID "${testId}" has attribute "${attr}" with value "${value}".`); } (0, cucumber_1.Then)(/^I see testid "(.*)" has attribute "(.*)" with value "(.*)"$/, Then_I_see_testid_has_attribute_with_value); /** * Asserts that an element identified by its `data-testid` has a specific attribute, regardless of its value. * * ```gherkin * Then I see testid {string} has attribute {string} * ``` * * @param testId - The value of the `data-testid` attribute. * @param attr - The name of the attribute expected to exist (e.g., "data-custom-id", "disabled"). * * @example * Then I see testid "main-content" has attribute "data-state" * Then I see testid "submit-button" has attribute "disabled" * * @remarks * This step uses Playwright's `page.getByTestId()` to find the element, then retrieves * the attribute's value and asserts that it is not `null` (meaning the attribute is present). * @category Test ID-Based Attribute Assertion Steps */ async function Then_I_see_testid_has_attribute(testId, attr) { const locator = this.page.getByTestId(testId); const attrValue = await locator.getAttribute(attr, { timeout: 5000 }); (0, test_1.expect)(attrValue).not.toBeNull(); this.log?.(`✅ Verified test ID "${testId}" has attribute "${attr}".`); } (0, cucumber_1.Then)(/^I see testid "(.*)" has attribute "(.*)"$/, Then_I_see_testid_has_attribute); /** * Asserts that an element identified by its `data-testid` does NOT have a specific attribute. * * ```gherkin * Then I see testid {string} does not have attribute {string} * ``` * * @param testId - The value of the `data-testid` attribute. * @param attr - The name of the attribute expected NOT to exist. * * @example * Then I see testid "main-content" does not have attribute "data-state" * Then I see testid "enabled-button" does not have attribute "disabled" * * @remarks * This step uses Playwright's `page.getByTestId()` to find the element, then retrieves * the attribute's value and asserts that it is `null` (meaning the attribute is not present). * @category Test ID-Based Attribute Assertion Steps */ async function Then_I_see_testid_does_not_have_attribute(testId, attr) { const locator = this.page.getByTestId(testId); const attrValue = await locator.getAttribute(attr, { timeout: 5000 }); (0, test_1.expect)(attrValue).toBeNull(); this.log?.(`✅ Verified test ID "${testId}" does NOT have attribute "${attr}".`); } (0, cucumber_1.Then)(/^I see testid "(.*)" does not have attribute "(.*)"$/, Then_I_see_testid_does_not_have_attribute); /** * Asserts that an element identified by its `data-testid` has a specific attribute whose value contains a given substring. * * ```gherkin * Then I see testid {string} attribute {string} contains {string} * ``` * * @param testId - The value of the `data-testid` attribute. * @param attr - The name of the attribute to check (e.g., "class", "aria-label"). * @param part - The substring expected to be contained within the attribute's value. * * @example * Then I see testid "main-content" attribute "class" contains "active" * Then I see testid "search-input" attribute "aria-label" contains "search product" * * @remarks * This step uses Playwright's `page.getByTestId()` to find the element and then * `expect(locator).toHaveAttribute()` with a regular expression for the contains check. * @category Test ID-Based Attribute Assertion Steps */ async function Then_I_see_testid_attribute_contains(testId, attr, part) { const locator = this.page.getByTestId(testId); await (0, test_1.expect)(locator).toHaveAttribute(attr, new RegExp(part), { timeout: 5000 }); this.log?.(`✅ Verified test ID "${testId}" attribute "${attr}" contains "${part}".`); } (0, cucumber_1.Then)(/^I see testid "(.*)" attribute "(.*)" contains "(.*)"$/, Then_I_see_testid_attribute_contains);