BDD

Agenda

  • What is TDD?
  • TDD rules
  • TDD pros/cons
  • How BDD differs?
  • BDD key principles
  • Business value understanding issues
  • Gherkin
  • Organizing steps and scenarios
  • BDD antipaterns
  • BDD disadvantages
  • BDD tools

What is Test Driven Development(TDD)?

TDD rules?

You are not allowed to write any production code unless it is to make a failing unit test pass

 

You are not allowed to write any more of a unit test than is sufficient to fail; and compilation failures are failures

 

You are not allowed to write any more production code than is sufficient to pass the one failing unit test

TDD GOALS

  • ensure that source code is thoroughly tested
  • ensure that the application is written for testability
  • enable safe refactoring
  • provide early understanding of the product requirements
  • provide a working specification of your functional code
  • less manual testing
  • reduce bug fixing time

TDD Pros

  • large numbers of tests help to limit the number of defects in the code
  • can lead to more modularized, flexible, and extensible code
  • automated test save a lot of time compared to manually testing functionality
  • reduced time allocated for regression testing
  • tests written ahead of time will also ensure good code quality
  • tests serve as a living documentation
  • time of running and manually testing your application

TDD cons

  • may not be right for developers who mostly work with a non-TDD approach
  • promotes Microdesign over Macrodesign
  • complex scenarios requiring a greater time investment
  • rapidly changing requirements makes creation and maintenance of these tests onerous
  • requires more time for maintaining tests
  • the tests may be hard to write, esp. beyond the unit testing level
  • hard to apply to existing legacy code
  • whole system can quickly degrade unless everyone on the team correctly maintains their tests 
  • too detail focused and without broader picture

How is BDD different from TDD?

  • BDD isn’t about the tools. It’s about the conversations you have
  • bridge the communication gap between development and business
  • conversations are documented using concrete examples in a language we call Gherkin
  • solves the more complex communication problems that are (by definition) beyond the scope of TDD
  • creates a common understanding
  • It is a way to describe the behavior of a system and a way to make sure that it is developed to behave as it should
  • living documentation understandable by non technical people

Key principles

  • Enough is enough
  • Deliver stakeholder value
  • It’s all behavior
  • Reduced waste
  • Reduced costs
  • Easier and safer changes
  • Faster releases 

Business value understanding issues

  • Traditional specifications issues
  • Written communication
  • Cooperation
  • Feedback cycles
  • Any conversations are just as bad as writing a specification using a word processor

BDD isn’t about the tools. It’s about the conversations you have

What can we do about it?

  • Specification by Example
  • Simplify the specification
  • Test the specification
  • Three amigos session involving
    • Business - What problem are we trying to solve?
    • Development - How might we build a solution to solve that problem?
    • Testing - What about this, what could possibly happen?
  • Faster feedback

Where should you use it?

Gherkin 

  • everyone can read and understand examples
  • executable
  • acting as an acceptance criteria

A formal language fulfilling the requirements that a good specification is:

Feature: Google Searching
 As a web surfer,
 I want to search Google,
 so that I can learn new things.
  
  Scenario: Simple Google search
    Given a web browser is on the Google page
    When the search phrase "panda" is entered
    Then results for "panda" are shown
    And the related results include "Panda Express"
    But the related results do not include "pandemonium"
Feature: Google Searching
  As a web surfer, I want to search Google, so that I can learn new things.
  Background:
    Given a web browser is on the Google page

  Scenario: Simple Google search for pandas
    When the search phrase "panda" is entered
    Then results for "panda" are shown

  Scenario: Simple Google search for elephants
    When the search phrase "elephant" is entered
    Then results for "elephant" are shown

  Scenario: Simple Google search for elephants
    When the search phrase "elephant" is entered
    Then results for "elephant" are shown
  Examples: Phrases
      | phrase   |
      | panda    |
      | elephant |
  Scenario: Simple Google search
    When the search phrase "panda" is entered
    Then results for "panda" are shown
    And the following related results are shown
      | related       |
      | Panda Express |
      | giant panda   |
      | panda videos  |

Gherkin scenarios - good properties

  • Outcome
  • Concrete
  • No implementation details
  • No irrelevant details
  • Hide unimportant setup
  • Good diagnosis precision
  • Connect as a real user

Organizing steps and scenarios

  • Group steps by model
  • Each step definition file should support one domain concept
  • Group features by…feature
  • Avoid feature coupled step definitions
  • Avoid conjunction steps
  • Be DRY: Refactor and Reuse Step Definitions

BDD antipaterns

  • Bad collaboration
  • Business people create scenarios in isolation
  • Devs or testers writing scenarios without talking to business people
  • Too high level
  • No living documentation
  • When you read Gherkin and it is bad documentation
  • Incidental details
  • Testing multiple things at the same time
  • Bad name on a scenario
  • Lots of user interface details
  • Keeping all scenarios forever
  • No clear separation between

Disadvantages and potential challenges

  • Requires high business engagement and collaboration
  • Works best in an Agile or iterative context
  • Doesn’t work well in a silo
  • Poorly written tests can lead to higher test-maintenance costs
  • BDD requires scripting skills
  • Preparation of tests may take 20-30% more time

Questions?

BDD tools

  1. BDD Testing Tools Comparison
  2. Specflow(.Net)
  3. Nspec(.Net)
  4. Cucumber(Ruby)
  5. Rspec(Ruby)
  6. Behave(Python)
  7. Lettuce(Python)
  8. JBehave(Java)
  9. Behat(PHP)
  10. Kahlan(PHP)
  11. Jasmine(JS)
  12. Spock(Groovy)

References

BDD

By Igor Sosnovskyy

BDD

  • 235