Need advice about which tool to choose?Ask the StackShare community!
Cucumber vs Selenium: What are the differences?
Developers describe Cucumber as "Simple, human collaboration". Cucumber is a tool that supports Behaviour-Driven Development (BDD) - a software development process that aims to enhance software quality and reduce maintenance costs. On the other hand, Selenium is detailed as "Web Browser Automation". Selenium automates browsers. That's it! What you do with that power is entirely up to you. Primarily, it is for automating web applications for testing purposes, but is certainly not limited to just that. Boring web-based administration tasks can (and should!) also be automated as well.
Cucumber and Selenium are primarily classified as "Testing Frameworks" and "Browser Testing" tools respectively.
Cucumber and Selenium are both open source tools. Selenium with 14.9K GitHub stars and 4.97K forks on GitHub appears to be more popular than Cucumber with 2.54K GitHub stars and 501 GitHub forks.
According to the StackShare community, Selenium has a broader approval, being mentioned in 777 company stacks & 443 developers stacks; compared to Cucumber, which is listed in 58 company stacks and 39 developer stacks.
we are having one web application developed in Reacts.js. in the application, we have only 4 to 5 pages that we need to test. I am having experience in selenium with java. Please suggets which tool I should use. and why ............................ ............................ .............................
with the help of selenium we can automate react js for functional testing
We use Selenium for our FDA validation testing.
For those not familiar with FDA and NASA quality control initiatives and testing requirements, suffice it to say that the federal government tends to talk in terms of 'validation and verification testing' in many of its' regulations. There's decades of history behind this term, and the three important takeaways are the following:
First, a project has to have two or more testing strategies, so as not to fall into a bias with a single testing strategy. Second, one of those testing strategies has to be user-centric, commonly known as validation testing. Examples include crash test dummies and end-to-end software acceptance tests. Third, most any other testing strategy can qualify as verification testing.
So, we use Selenium for our FDA validation testing, because it simulates a user walking through the software.
It's big and bloated and slow, and the legacy version runs on Java, and it's brittle and doubles the amount of code we have to write, and is otherwise a total pain in the ass. But it's like folding your parachute before skydiving or having a depth gauge when SCUBA diving or placing bolts when climbing a wall. There are simply some tasks that you don't want to do without safety gear.
And for all its' pain to use, Selenium is like safety gear for building your tech stack. We've migrated across a half a dozen user interfaces, two entirely different back-end languages, three or four data protocols, and countless utilities over the years. And Selenium warns us when we're in danger and it catches us when we fall.
As bioinformaticists, we regularly get asked to develop apps or websites which are HIPAA compliant, connect to an EHR, or are ready for FDA regulation.
Regarding the last, the FDA has built up best practices over the past 40 or 50 years regarding "validation and verification" testing. Without going into a lengthy history of FDA regulations, suffice it to say that there are two important distinctions about validation and verification testing - the first of which is that there has to be more than one testing methodology, so that manufacturers or developers don't get a sort of biased tunnel vision; and the second is that at least one of the testing methodologies has to be user-centric. So, it's not enough to test the engine of a car, a manufacturer also must have crash test dummies.
In the world of software written for hospitals and clinical environments, we interpret the verification and validation testing requirements in terms of requiring more than one testing framework, one of which is an end-to-end testing harness using a technology like Selenium. It's not enough to have unit testing, but we also need e2e acceptance testing. Selenium has traditionally been the only game in town, and has been a struggle to work with at times. But it's a tank, and keeps on rolling. We particularly like recent incarnations using Chromedriver and WebDriver protocols, which is slowly reducing the reliance on the legacy Java server.
Pros of Cucumber
- Simple Syntax20
- Simple usage8
- Huge community5
- Nice report3
Pros of Selenium
- Automates browsers173
- Testing154
- Essential tool for running test automation101
- Record-Playback24
- Remote Control24
- Data crawling8
- Supports end to end testing7
- Functional testing6
- Easy set up6
- The Most flexible monitoring system4
- End to End Testing3
- Easy to integrate with build tools3
- Comparing the performance selenium is faster than jasm2
- Record and playback2
- Compatible with Python2
- Easy to scale2
- Integration Tests2
- Integrated into Selenium-Jupiter framework0
Sign up to add or upvote prosMake informed product decisions
Cons of Cucumber
Cons of Selenium
- Flaky tests8
- Slow as needs to make browser (even with no gui)4
- Update browser drivers1