Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
@badeball/cypress-cucumber-preprocessor
Advanced tools
[![Build status](https://github.com/badeball/cypress-cucumber-preprocessor/actions/workflows/build.yml/badge.svg)](https://github.com/badeball/cypress-cucumber-preprocessor/actions/workflows/build.yml) [![Npm package weekly downloads](https://badgen.net/n
@badeball/cypress-cucumber-preprocessor is a plugin for Cypress that allows you to use Cucumber syntax for writing your end-to-end tests. It enables you to write tests in a more human-readable format using Gherkin language, which can improve collaboration between developers, testers, and non-technical stakeholders.
Writing Gherkin Scenarios
This feature allows you to write test scenarios in Gherkin syntax, which is a human-readable language. The example demonstrates a simple login scenario.
Feature: Login functionality
Scenario: Successful login
Given I am on the login page
When I enter valid credentials
Then I should be redirected to the dashboard
Step Definitions
This feature allows you to define the steps for your Gherkin scenarios using JavaScript. The example shows how to implement the steps for the login scenario.
import { Given, When, Then } from '@badeball/cypress-cucumber-preprocessor';
Given('I am on the login page', () => {
cy.visit('/login');
});
When('I enter valid credentials', () => {
cy.get('input[name="username"]').type('user');
cy.get('input[name="password"]').type('password');
cy.get('button[type="submit"]').click();
});
Then('I should be redirected to the dashboard', () => {
cy.url().should('include', '/dashboard');
});
Data-Driven Testing
This feature allows you to run the same scenario with different sets of data using the Scenario Outline and Examples keywords. The example demonstrates how to test unsuccessful login attempts with different credentials.
Feature: Login functionality
Scenario Outline: Unsuccessful login
Given I am on the login page
When I enter <username> and <password>
Then I should see an error message
Examples:
| username | password |
| user1 | wrongpass|
| user2 | wrongpass|
| user3 | wrongpass|
cypress-cucumber-preprocessor is another plugin for integrating Cucumber with Cypress. It provides similar functionality to @badeball/cypress-cucumber-preprocessor, allowing you to write Gherkin syntax for your tests. However, @badeball/cypress-cucumber-preprocessor is a fork of this package and may have additional features or improvements.
jest-cucumber is a package that allows you to use Cucumber with Jest, a popular JavaScript testing framework. While it provides similar Gherkin syntax support, it is designed for unit and integration testing rather than end-to-end testing like Cypress.
This preprocessor aims to provide a developer experience and behavior similar to that of Cucumber, to Cypress.
:information_source: The repositor has recently moved from
github.com/TheBrainFamily
togithub.com/badeball
. Read more about the transfer of ownership here.
$ npm install @badeball/cypress-cucumber-preprocessor
The preprocessor (with its dependencies) parses Gherkin documents and allows you to write tests as shown below.
# cypress/e2e/duckduckgo.feature
Feature: duckduckgo.com
Scenario: visiting the frontpage
When I visit duckduckgo.com
Then I should see a search bar
// cypress/e2e/duckduckgo.ts
import { When, Then } from "@badeball/cypress-cucumber-preprocessor";
When("I visit duckduckgo.com", () => {
cy.visit("https://www.duckduckgo.com");
});
Then("I should see a search bar", () => {
cy.get("input").should(
"have.attr",
"placeholder",
"Search the web without being tracked"
);
});
Building can be done once using:
$ npm run build
Or upon file changes with:
$ npm run watch
There are multiple types of tests, all ran using npm scripts:
$ npm run test:fmt
$ npm run test:types
$ npm run test:unit
$ npm run test:integration # make sure to build first
$ npm run test # runs all of the above
A special thanks goes out to Łukasz Gandecki for developing and maintaning the cypress-cucumber integration before me, in addition to all other contributors. Some of the work has partially been sponsored by Klaveness Digital.
FAQs
[![Build status](https://github.com/badeball/cypress-cucumber-preprocessor/actions/workflows/build.yml/badge.svg)](https://github.com/badeball/cypress-cucumber-preprocessor/actions/workflows/build.yml) [![Npm package weekly downloads](https://badgen.net/n
The npm package @badeball/cypress-cucumber-preprocessor receives a total of 287,713 weekly downloads. As such, @badeball/cypress-cucumber-preprocessor popularity was classified as popular.
We found that @badeball/cypress-cucumber-preprocessor demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.