Although I’m mostly focused on manual testing as I am attempting to get to know the business, I’ve been trying to get myself up to speed with the automation framework they are using, Serenity BDD. I have a long term goal of combining their current Serenity BDD test suite with Appium, so when we start developing a regression test suite, I can possibly automate it.
As I Tweeted a few days ago… Oh, this is going to take a while!
@tjmaher1 @AppiumDevs @reactnative @Android You might want to see how integration with Serenity Screenplay could work, it might be faster.— Serenity BDD (@serenitybdd) March 25, 2017
Hrm… thank you, Serenity BDD! I need to look into that.
Oh, and thank you very much, John Smart, for your words of encouragement on this blog series:
An excellent introduction to Serenity BDD by @tjmaher1 : https://t.co/WXzk7wmLe8 #bdd #SerenityBDD
— John Ferguson Smart (@wakaleo) March 29, 2017
For now, since I am studying how to implement Serenity using a testing framework invented by Aslak Hellesoy called "Cucumber".
BDD and The Cucumber Book
For those who were wondering, the “BDD” in Serenity BDD stands for “Behavior Driven Development”. I first encountered BDD when I was supervising an offshore testing team attempting to translate my manual mobile test scripts into Cucumber / Ruby automation using Calabash-IOS. That is when I first encountered Matt Wynne’s “The Cucumber Book: Behaviour-Driven Development for Testers and Developers” (2012), which was quite helpful describing BDD.“Matt Wynne and Aslak Hellesøy [the creator of Cucumber] show you how to express your customers’ wild ideas as a set of clear, executable specifications that everyone on the team can read. You’ll learn how to feed those examples into Cucumber and let it guide your development. You’ll build just the right code to keep your customers happy, and not a line more. Although it was born in the Ruby community, you can use Cucumber to test almost any system, from a simple shell script or Perl script, to web applications written in PHP, Java, or any platform”. - The Cucumber Book, The Pragmatic Bookshelf
About the Authors
Note: The Cucumber Book now a second edition, released on February 27, 2017.
“Matt Wynne is a long-standing member of the Cucumber core team, fascinated by the challenge of helping tech and business to understand one another. He's one of the co-founders of Cucumber Ltd., the company behind Cucumber. He lives on the west coast of Scotland on an old farm with his family, two cats, their dog, and some ducks. Matt tweets from @mattwynne and @cucumberbdd.
“Aslak Hellesoy is the creator of Cucumber. During his career Aslak has worked with both small and large organizations in industries such as telecom, trading, insurance, car manufacturing, education, and government. Aslak is a co-founder of Cucumber Ltd, the company behind Cucumber. He tweets from @aslak_hellesoy and @cucumberbdd.
"Steve Tooke is a programmer, trainer, and coach who is dedicated to improving his craft and helping others improve theirs. He's a co-founder of Cucumber Ltd. Steve tweets from @tooky and @cucumberbdd”.
Oh, and Why Is It Called "Cucumber"?
Why the name "Cucumber"? Read Aslak Hellesoy's answer on Quora, how he asked his fiancee, Patty for naming suggestions:"Patty, I need a name for this new tool I just started hacking on. I want it to have a catchy, non-geeky sounding name.
"She paused for a few seconds, then said: Cucumber!
"And I thought: Cucumber? Really? Well, it's a lot better than Stories - so I'll go with that for now. I'll rename it again when I come up with something better".
What is an Acceptance Test for a Feature?
Here’s an example Matt Wynne lists in The Cucumber Book:
Feature: Sign up
Sign up should be quick and friendly.
Scenario: Successful sign up
New users should get a confirmation email and be greeted personally by the site once signed in.
Given I have chosen to sign up
When I sign up with valid details
Then I should receive a confirmation email
And I should see a personalized greeting message
… This is an example of what is called an acceptance test. “Instead of a business stakeholder passing requirements to the development team without much opportunity for feedback, the developer and stakeholder collaborate to write automated tests that express the outcome that the stakeholder wants. We call them acceptance tests because they express what the software needs to do in order for the stakeholder to find it acceptable. The test fails at the time of writing, because no code has been written yet, but it captures what the stakeholder cares about and gives everyone a clear signal as to what it will take to be done”.
The Product Owner, a business analyst representing the customer’s wants and needs on an Agile Software Development project can express a client’s wishes and expectations in an easy-to-read format. They can be expressed in terms of behavior wanted in the finished product.
As Matt Wynne mentions, “Acceptance tests written in this style become more than just tests; they are executable specifications […]
“For many teams, they become the definitive source of truth as to what the system does. Having a single place to go for this information saves a lot of time that is often wasted trying to keep requirements documents, tests, and code all in sync. It also helps to build trust within the team, because different parts of the team no longer have their own personal versions of the truth”. - The Cucumber Book
How Do Features Get Turned Into Steps and Step Definitions?
But how does it work?“When you run [Cucumber], it reads in your specifications from plain-language text files called features, examines them for scenarios to test, and runs the scenarios against your system. Each scenario is a list of steps for Cucumber to work through. So that Cucumber can understand these feature files, they must follow some basic syntax rules. The name for this set of rules is Gherkin. Along with the features, you give Cucumber a set of step definitions, which map the business-readable language of each step into Ruby code to carry out whatever action is being described by the step. In a mature test suite, the step definition itself will probably just be one or two lines of Ruby that delegate to a library of support code, specific to the domain of your application, that knows how to carry out common tasks on the system. Normally that will involve using an automation library, like the browser automation library Capybara, to interact with the system itself”. - The Cucumber Book
Does Serenity BDD Still Use Features Files and Step Definitions?
If you are using Serenity BDD with Cucumber, it will follow the same exact steps.
- Narratives describe the story you want to tell.
- Feature files describe the features of the product, breaking it down into scenarios outlining how the feature will be used.
- Step definitions walk through step-by-step how to execute the code.
“Step definitions sit right on the boundary between the business’s domain and the programmer’s domain. […] Their responsibility is to translate each plain-language step in your Gherkin scenarios into concrete actions in […] code”.
What is the difference between Steps and Step Definitions?
“Each Gherkin scenario is made up of a series of steps, written in plain language. On its own, a step is just documentation; it needs a step definition to bring it to life. A step definition is a piece of Ruby code that says to Cucumber, ‘If you see a step that looks like this…, then here’s what I want you to do….’ When Cucumber tries to execute each step, it looks for a matching step definition to execute. So, how does Cucumber match a step definition to a step"
“Gherkin steps are expressed in plain text. Cucumber scans the text of each step for patterns that it recognizes, which you define using a regular expression. If you haven’t used regular expressions before, then just think of them like a slightly more sophisticated version of the wildcards you’d use to search for a file”. - The Cucumber Book
What is the Difference Between BDD and ATDD?
To answer this questions, let's jump to a sidebar in “BDD in Action” written by John Ferguson Smart, the creator of Serenity BDD.“BDD by any other name
“Many of the ideas around BDD are not new and have been practiced for many years under a number of different names. Some of the more common terms used for these practices include Acceptance-Test-Driven Development, Acceptance Test-Driven Planning, and Specification by Example. To avoid confusion, let’s clarify a few of these terms in relation to BDD.
“Specification by Example describes the set of practices that have emerged around using examples and conversation to discover and describe requirements. In his seminal book of the same name,14 Gojko Adzic chose this term as the most representative name to refer to these practices. Using conversation and examples to specify how you expect a system to behave is a core part of BDD, and we’ll discuss it at length in the first half of this book.
“Acceptance-Test-Driven Development (ATDD) is now a widely used synonym for Specification by Example, but the practice has existed in various forms since at least the late 1990s. Kent Beck and Martin Fowler mentioned the concept in 2000,15 though they observed that it was difficult to implement acceptance criteria in the form of conventional unit tests at the start of a project. But unit tests aren’t the only way to write automated acceptance tests, and since at least the early 2000s, innovative teams have asked users to contribute to executable acceptance tests and have reaped the benefits
“Acceptance-Test-Driven Planning is the idea that defining acceptance criteria for a feature leads to better estimates than doing a task breakdown”.
What is the Goal of BDD?
“One of the key goals of BDD is to ensure that everyone has a clear understanding of what a project is trying to deliver, and of the underlying business objectives of the project. This, in itself, goes a long way toward ensuring that the application actually meets these objectives.
“You can achieve this by working with users and other stakeholders to define or clarify a set of high-level business goals for the application. These goals should provide a concise vision of what you need to build. Business goals are about delivering value, so it’s common to see them expressed in terms of increasing or protecting revenue, or of decreasing costs”. - BDD in Action
Now that the research has been done, we can start assembling a new Serenity BDD project..
Learning Serenity BDD
- Part One: Serenity BDD: An Automation Framework That Uses Specification by Example (SBE)
- Part Two: What is the Difference Between TDD and BDD?
- Part Three: Studying BDD using The Cucumber Book and BDD in Action
- Part Four: Scaffolding a new project using Maven Archetypes
- Part Five: Reviewing The Serenity Screenplay Tutorial
-T.J. Maher
Twitter | LinkedIn | GitHub
// Sr. QA Engineer, Software Engineer in Test, Software Tester since 1996.
// Contributing Writer for TechBeacon.
// "Looking to move away from manual QA? Follow Adventures in Automation on Facebook!"
48 comments:
Great post! I must appreciate your efforts for writing the post. Found it interesting as well as informative. Keep it up! car with driver in dubai
Valuable content you have posted here, I have seen the value in your endeavors for creating this article, it is a informative content, well really you have done a good job! car rental with driver in Dubai
These websites are quite useful and provide a wealth of information. bus for rent in dubai
A very well-written article, this one. You have to acknowledge that I've read some of the best writing from you. I like the thoughtfulness of this article. website/
Hey, thanks for the post. Thanks again. Will keep reading.…
Hi!
Ich bin immer auf der Suche nach qualitativ hochwertigen Beiträgen und Artikeln und habe sie hier gefunden. Vielen Dank, dass Sie diesen freundlichen informativen Beitrag mit uns geteilt haben
Hier sind unsere Dienstleistungen
Hey, ich bin beeindruckt von deiner tollen Arbeit. Ich mag deine Artikel sehr. Danke, dass Sie diese Art von Inhalt teilen
Hi, your company is very good, I like it very much, I got a lot of new information, thank you
This is our service.
Hello, this is probably the best article I've ever read, I feel great.
Thank you for another excellent article. Where else could anybody get that kind of info in such an ideal way of writing? I’ve a presentation next week, and I am on the look for such information.
Hey, ich bin beeindruckt von deiner tollen Arbeit. Ich mag deine Artikel sehr. Danke, dass Sie diese Art von Inhalt teilen
https://enterprisecarsales.wixsite.com/enterprise-autoverka
Great article!!! I really hope to check out the same high-grade content from you later on as well. In fact, your creative writing abilities has encouraged me to get my very own blog now 😉 I found it very informative and useful. Thank you for posting such a nice content… Keep posting such a good content .
We will help you to have the best Limo service
Please click here for more information
Your explanation was clear.
google ads services
great post appreciated keep it up with more interesting blogs bus rental Dubai
Thank you for sharing your insights in this article. Your depth of knowledge and ability to present complex ideas in an easily digestible format is truly commendable. It's refreshing to read content that is both informative and engaging. Keep up the great work! By the way, if anyone is interested in transportation solutions, I recently wrote an article on Bus Rental Dubai that might be of interest.
I am eagerly anticipating your next work. Your writing is truly inspiring.
This is a must-read for anyone interested in this subject.
Bus Rental in Sharjah
I appreciate the author's dedication to fostering intellectual curiosity through their writing.
The way you structure your content is exemplary. It makes the information easy to follow.
Marble in Dubai
I appreciate the author's attention to detail. The thoroughness of the content makes it a reliable source for anyone seeking information on this topic.
Mini Bus for rent
I always learn something new from your blog.
Thank you for this well-researched post.
This was exactly what I needed to read today.
I appreciate the insights shared here. It reminds me of how important clear communication is in any field, including healthcare. If you're looking for healthcare assignment help, understanding BDD can also enhance how we document and approach patient care scenarios.
I recently booked my Umrah trip through an amazing Umrah Packages, and the experience was seamless! The package covered everything from flights to accommodations, making the whole journey stress-free. If you're planning your pilgrimage, I highly recommend checking out the various Umrah packages available to make your trip as smooth and memorable as possible!
Welcome to our exclusive Umrah package 2025 from Pakistan, where we offer you a transformative and deeply spiritual pilgrimage experience to the blessed cities of Makkah and Madinah. Embark on a journey of a lifetime as you fulfill your spiritual obligations and seek blessings from the divine in the holiest sites of Islam.
The process of acquiring land can be complex, but understanding the key factors buyers of land should consider—like location, zoning regulations, and future development plans—can make all the difference. For new buyers, especially, it’s essential to do thorough research and, if possible, consult with experts to avoid costly mistakes. I’d also love to hear your thoughts on how technology is shaping the experience for buyers of land.
We specialize in providing fast, hassle-free solutions for individuals looking to sell land for cash in texas. Whether you own vacant lots, rural acreage, or undeveloped property, our mission is to offer a seamless process to turn your land into cash, quickly and efficiently.
The author did a great job of breaking down the topic into manageable pieces. The advice is practical and easy to implement.
wholesale grocery tote bags have emerged as a practical, eco-friendly solution that benefits retailers, customers, and the planet. Whether you own a grocery store, a retail shop, or an event planning business, investing in wholesale tote bags can be a smart move. In this blog, we will explore the advantages of these reusable bags, the different types available, and how to choose the best wholesale supplier for your needs.
Looking for an unforgettable spiritual journey! Check out our Umrah Package from Canada, designed to offer convenience, comfort, and affordability. With personalized services, guided tours, and hassle-free travel arrangements, this package ensures a memorable pilgrimage experience. Book now and fulfill your spiritual dreams with ease!
When you think of Mauritius, images of pristine beaches, crystal-clear waters, and vibrant landscapes often come to mind. But beyond its natural beauty, the island also offers a treasure trove of cultural experiences, one of the most unique being the mauritius photography museum. For those who are passionate about photography, history, or simply discovering the art behind capturing a moment in time, this museum offers a fascinating journey through the evolution of photography on the island.
Studying BDD with The Cucumber Book and BDD in Action is a great way to learn how to write better tests! It’s all about clarity and collaboration—just like a Pilot and Car service that ensures smooth travel. Speaking of smooth experiences, Airport Transfer Services Dubai makes getting around stress-free and efficient. Learning and traveling both work best when things are well-structured! Pilot and Car
In the world of eco-friendly and affordable marketing solutions, wholesale non woven tote bags have become a top choice for businesses, event organizers, and individuals alike. These versatile bags offer a great balance of sustainability, durability, and cost-effectiveness, making them an ideal promotional product or gift. In this blog post, we’ll dive deep into why non-woven tote bags are a smart investment for your business, the different options available, and how to choose the best wholesale supplier.
Great article!!! I truly hope to see more high-quality content like this from you in the future. Your clear and engaging writing has inspired me to start my own blog.I found the insights very informative and practical. If anyone’s planning group travel, I’d highly recommend checking out luxury bus rental Dubai
services. Thanks for sharing such valuable content
This post really helped me understand BDD in a practical way. It’s like when you rent a car with driver. You get to focus on the journey, not the stress of driving.
This article offers a clear and insightful journey into mastering BDD through The Cucumber Book and BDD in Action — truly valuable for both beginners and seasoned developers. While diving deep into tech learning, don’t forget how convenient it is to rent a car with driver for stress-free travel to coding boo camps, tech meetups, or peaceful study retreats.
Insightful and well-structured—this guide makes mastering BDD feel approachable! Just like clear frameworks help developers, smart travel choices like rent a car with driver in Riyadh make city navigation simpler and more efficient.
Great post! Studying BDD with Serenity has been a game-changer for our QA team. Using The Cucumber Book and BDD in Action side-by-side just makes it click. Honestly, it reminded me of when I chose to
rent a car with driver in Dubai—it made everything flow without the usual headaches.
Clear and practical explanation of BDD through real tools. Whether it’s coding or exploring a new city, it helps to have support—like when you rent a car with driver in dubai for stress-free mobility.
This article nails the BDD learning curve! Makes me think—guidance in coding is like having a pro when you rent a car with driver in Dubai. Smooth, efficient, and no guesswork!
Appreciate how this article breaks down Serenity and Cucumber—great for anyone diving into BDD. It’s like choosing to rent a car with driver in Dubai when you want to stay focused on your destination.
Great insights on learning BDD! I’ve been exploring The Cucumber Book and BDD in Action, and your explanation really highlights the practical benefits of Behavior-Driven Development. Studying BDD this way helps in understanding both collaboration and test automation more effectively. For students and professionals working on systematic literature review assignments, approaching BDD methodically can offer structured techniques to break down complex requirements into manageable scenarios. Your post emphasizes the importance of hands-on practice, which is essential for mastering BDD concepts. Thanks for sharing such a clear roadmap for learners aiming to integrate BDD into real-world projects.
Insightful post on mastering BDD through The Cucumber Book and BDD in Action! Just as precision matters in coding, men’s suits Dubai also rely on fine craftsmanship.
Chauffeur service in Dubai, Looking for a luxury limo? Hire Luxury Cars & Vans With Driver at low rates. Call for booking at +971 50 9852818
Excellent post on mastering BDD through The Cucumber Book and BDD in Action — just as precision and structure in Healthcare Uniforms reflect the professionalism essential in software development.
Post a Comment