behave 1.2.4

behave is behaviour-driven development, Python style

behave is behavior-driven development, Python style.

Behavior-driven development (or BDD) is an agile software development technique that encourages collaboration between developers, QA and non-technical or business participants in a software project.

behave uses tests written in a natural language style, backed up by Python code.

First, install *behave*.

Now make a directory called "features/". In that directory create a file called "example.feature" containing:

# -- FILE: features/example.feature
Feature: Showing off behave

  Scenario: Run a simple test
    Given we have behave installed
     When we implement 5 tests
     Then behave will test them for us!

Make a new directory called "features/steps/". In that directory create a file called "example_steps.py" containing:

# -- FILE: features/steps/example_steps.py
from behave import given, when, then, step

@given('we have behave installed')
def step_impl(context):
    pass

@when('we implement {number:d} tests')
def step_impl(context, number):  # -- NOTE: number is converted into integer
    assert number > 1 or number == 0
    context.tests_count = number

@then('behave will test them for us!')
def step_impl(context):
    assert context.failed is False
    assert context.tests_count >= 0

Run behave:

$ behave
Feature: Showin off behave # features/example.feature:2

  Scenario: Run a simple test          # features/example.feature:4
    Given we have behave installed     # features/steps/example_steps.py:4
    When we implement 5 tests          # features/steps/example_steps.py:8
    Then behave will test them for us! # features/steps/example_steps.py:13

1 feature passed, 0 failed, 0 skipped
1 scenario passed, 0 failed, 0 skipped
3 steps passed, 0 failed, 0 skipped, 0 undefined

Now, continue reading to learn how to the most of behave. To get started, we recommend the tutorial and then the feature testing language and api references.

More Information

Testing Domains

Behave and other BDD frameworks allow you to provide step libraries to reuse step definitions in similar projects that address the same problem domain.

Support of the following testing domains is currently known:

Testing Domain Name Description
Command-line behave4cmd Test command-line tools, like behave, etc. (coming soon).
Web Apps django-behave Test Django Web apps with behave.
Web, SMS, ... behaving Test Web Apps, Email, SMS, Personas (step library).
BSD

Author

Benno Rice, Richard Jones and Jens Engel

Pip

behave==1.2.4

Classifiers

  • Topic :: Software Development :: Testing
  • Programming Language :: Python :: Implementation :: PyPy
  • Programming Language :: Python :: Implementation :: Jython
  • Programming Language :: Python :: Implementation :: CPython
  • Programming Language :: Python :: 3.3
  • Programming Language :: Python :: 3.2
  • Programming Language :: Python :: 2.7
  • Programming Language :: Python :: 2.6
  • Programming Language :: Python :: 2.5
  • Operating System :: OS Independent
  • License :: OSI Approved :: BSD License
  • Intended Audience :: Developers
  • Environment :: Console
  • Development Status :: 4 - Beta
File Type Python Version Uploaded On Downloads
behave-1.2.4.tar.gz Source March 2, 2014 73,985
Version Release Date
1.2.4 March 2, 2014
1.2.3 July 8, 2013
1.2.2 Aug. 21, 2012
1.2.1 Aug. 19, 2012
1.2.0 Aug. 17, 2012
1.1.0 Jan. 23, 2012
1.0.0 Dec. 5, 2011
Date Package Version Action
Nov. 4, 2014, 11:21 a.m. behave 1.2.1 Release Created
Nov. 4, 2014, 11:21 a.m. behave 1.2.0 Release Created
Nov. 4, 2014, 11:21 a.m. behave 1.2.3 Release Created
Nov. 4, 2014, 11:21 a.m. behave 1.2.2 Release Created
Nov. 4, 2014, 11:21 a.m. behave 1.2.4 Release Created
Nov. 4, 2014, 11:21 a.m. behave 1.0.0 Release Created
Nov. 4, 2014, 11:21 a.m. behave 1.1.0 Release Created
Nov. 4, 2014, 11:21 a.m. behave Package Created