Description
LightBDD is a behaviour-driven development test framework offering ability to write tests that are easy to read, easy to track during execution and summarize in user friendly report, while allowing developers to use all of the standard development tools to maintain them.
LightBDD alternatives and similar packages
Based on the "Testing" category.
Alternatively, view LightBDD alternatives based on common mentions on social networks and blogs.
-
Bogus
:card_index: A simple fake data generator for C#, F#, and VB.NET. Based on and ported from the famed faker.js. -
Fluent Assertions
A very extensive set of extension methods that allow you to more naturally specify the expected outcome of a TDD or BDD-style unit tests. Targets .NET Framework 4.7, as well as .NET Core 2.1, .NET Core 3.0, .NET 6, .NET Standard 2.0 and 2.1. Supports the unit test frameworks MSTest2, NUnit3, XUnit2, MSpec, and NSpec3. -
Testcontainers
A library to support tests with throwaway instances of Docker containers for all compatible .NET Standard versions. -
AutoFixture
AutoFixture is an open source library for .NET designed to minimize the 'Arrange' phase of your unit tests in order to maximize maintainability. Its primary goal is to allow developers to focus on what is being tested rather than how to setup the test scenario, by making it easier to create object graphs containing test data. -
SpecFlow
#1 .NET BDD Framework. SpecFlow automates your testing & works with your existing code. Find Bugs before they happen. Behavior Driven Development helps developers, testers, and business representatives to get a better understanding of their collaboration -
Verify
Verify is a snapshot tool that simplifies the assertion of complex data models and documents. -
NBomber
Modern and flexible load testing framework for Pull and Push scenarios, designed to test any system regardless a protocol (HTTP/WebSockets/AMQP etc) or a semantic model (Pull/Push). -
WireMock.Net
WireMock.Net is a flexible product for stubbing and mocking web HTTP responses using advanced request matching and response templating. Based on the functionality from http://WireMock.org, but extended with more functionality. -
Compare-Net-Objects
What you have been waiting for :+1: Perform a deep compare of any two .NET objects using reflection. Shows the differences between the two objects. -
Machine.Specifications
Machine.Specifications is a Context/Specification framework for .NET that removes language noise and simplifies tests. -
GenFu
GenFu is a library you can use to generate realistic test data. It is composed of several property fillers that can populate commonly named properties through reflection using an internal database of values or randomly created data. You can override any of the fillers, give GenFu hints on how to fill them. -
ArchUnitNET
A C# architecture test library to specify and assert architecture rules in C# for automated testing. -
Expecto
A smooth testing lib for F#. APIs made for humans! Strong testing methodologies for everyone! -
Fine Code Coverage
Visualize unit test code coverage easily for free in Visual Studio Community Edition (and other editions too) -
NFluent
Smooth your .NET TDD experience with NFluent! NFluent is an ergonomic assertion library which aims to fluent your .NET TDD experience (based on simple Check.That() assertion statements). NFluent aims your tests to be fluent to write (with a super-duper-happy 'dot' auto-completion experience), fluent to read (i.e. as close as possible to plain English expression), but also fluent to troubleshoot, in a less-error-prone way comparing to the classical .NET test frameworks. NFluent is also directly inspired by the awesome Java FEST Fluent assertion/reflection library (http://fest.easytesting.org/) -
xBehave.net
DISCONTINUED. ✖ An xUnit.net extension for describing each step in a test with natural language. -
SpecsFor
SpecsFor is a light-weight Behavior-Driven Development framework that focuses on ease of use for *developers* by minimizing testing friction. -
Xunit.Gherkin.Quick
BDD in .NET Core - using Xunit and Gherkin (compatible with both .NET Core and .NET) -
SimpleStubs
*SimpleStubs* is a simple mocking framework that supports Universal Windows Platform (UWP), .NET Core and .NET framework. SimpleStubs is currently developed and maintained by Microsoft BigPark Studios in Vancouver. -
Moq.Contrib.HttpClient
A set of extension methods for mocking HttpClient and IHttpClientFactory with Moq. -
#<Sawyer::Resource:0x00007f89811b9240>
:fire: A small library to help .NET developers leverage Microsoft's dependency injection framework in their Xunit-powered test projects -
SecTester
SecTester is a new tool that integrates our enterprise-grade scan engine directly into your unit tests.
InfluxDB - Purpose built for real-time analytics at any scale.
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest.
Do you think we are missing an alternative of LightBDD or a related project?
README
LightBDD The Lightweight Behavior Driven Development test framework
Project description
LightBDD is a behaviour-driven development test framework offering ability to write tests that are easy to read, easy to track during execution and summarize in user friendly report, while allowing developers to use all of the standard development tools to maintain them.
Features
- Native support for refactoring, code analysis (like finding unused methods), test running and all features that Visual Studio / Intellisense / Resharper offer during code development,
- Easy to read scenario definitions,
- Scenario steps execution tracking and time measurement, usable during longer test execution,
- Support for parameterized steps with smart rules of inserting argument values to formatted step name,
- Support for advanced in-line and tabular verifiable parameters,
- Support for contextual scenario execution where steps shares dedicated context,
- Support for DI containers,
- Feature report generation in HTML, XML or Plain text format,
- In-code LightBDD configuration allowing to customize all LightBDD features,
- Productivity extensions for VisualStudio with Feature Class Templates, Project Templates and Code Snippets,
- Integration with NUnit, xUnit, MsTest.TestFramework and Fixie frameworks,
- Async scenario and steps execution support,
- Cross-platform support (.NET Framework / .NET Standard / .NET Core / UWP).
Tests structure and conventions
LightBDD runs on top of NUnit, xUnit, MsTest.TestFramework and Fixie, allowing to leverage the well known test frameworks and their features in writing the behavioral style scenarios, which makes it very easy to learn, adapt and use.
To learn more, please see LightBDD wiki page, or jump straight to:
- Quick Start and followup documentation pages,
- What Is New section with the newest features introduced in the library,
- Examples demonstrating features and integrations of LightBDD,
- Tutorials with complete sample projects using LightBDD features.
Example
[FeatureDescription(
@"In order to access personal data
As an user
I want to login into system")] //feature description
[Label("Story-1")]
public partial class Login_feature //feature name
{
[Scenario]
[Label("Ticket-1")]
public void Successful_login() //scenario name
{
Runner.RunScenario(
Given_the_user_is_about_to_login, //steps
Given_the_user_entered_valid_login,
Given_the_user_entered_valid_password,
When_the_user_clicks_login_button,
Then_the_login_operation_should_be_successful,
Then_a_welcome_message_containing_user_name_should_be_returned);
}
}
[FeatureDescription(
@"In order to pay for products
As a customer
I want to receive invoice for bought items")] //feature description
[Label("Story-2")]
public partial class Invoice_feature //feature name
{
[Scenario]
[Label("Ticket-2")]
public void Receiving_invoice_for_products() //scenario name
{
Runner.RunScenario(
_ => Given_product_is_available_in_product_storage("wooden desk"), //steps
_ => Given_product_is_available_in_product_storage("wooden shelf"),
_ => When_customer_buys_product("wooden desk"),
_ => When_customer_buys_product("wooden shelf"),
_ => Then_an_invoice_should_be_sent_to_the_customer(),
_ => Then_the_invoice_should_contain_product_with_price_of_AMOUNT("wooden desk", 62),
_ => Then_the_invoice_should_contain_product_with_price_of_AMOUNT("wooden shelf", 37));
}
}
The above example shows feature partial classes containing scenario definitions only, which makes it easier to read.
The Login_feature
class uses basic scenario format for defining scenario steps.
The Invoice_feature
class uses extended scenario format allowing to use parameterized steps.
LightBDD offers multiple scenario formats and flavors suitable for various use cases - for details, please check Scenario Steps Definition page.
The implementation of step methods is located in other part of the class, in separate file and leverages standard features of the underlying test framwork (such as assert mechanisms) empowered by LightBDD features such as:
- Dependency Injection,
- Inline and Tabular parameters,
- Expectation Expressions,
- Step comments,
- Scenario and Step Decorators.
Example console output during tests execution:
What LightBDD offers for free is the scenario output provided in Visual Studio/Resharper test screens and/or Console window.
Where possible, the output is provided as the test executes, allowing to track the progress of the scenarios.
FEATURE: [Story-1] Login feature
In order to access personal data
As an user
I want to login into system
SCENARIO: [Ticket-1] Successful login
STEP 1/6: GIVEN the user is about to login...
STEP 1/6: GIVEN the user is about to login (Passed after 2ms)
STEP 2/6: AND the user entered valid login...
STEP 2/6: AND the user entered valid login (Passed after <1ms)
STEP 3/6: AND the user entered valid password...
STEP 3/6: AND the user entered valid password (Passed after <1ms)
STEP 4/6: WHEN the user clicks login button...
STEP 4/6: WHEN the user clicks login button (Passed after 125ms)
STEP 5/6: THEN the login operation should be successful...
STEP 5/6: THEN the login operation should be successful (Passed after 4ms)
STEP 6/6: AND a welcome message containing user name should be returned...
STEP 6/6: AND a welcome message containing user name should be returned (Passed after 9ms)
SCENARIO RESULT: Passed after 164ms
FEATURE: [Story-2] Invoice feature
In order to pay for products
As a customer
I want to receive invoice for bought items
SCENARIO: [Ticket-4] Receiving invoice for products
STEP 1/7: GIVEN product "wooden desk" is available in product storage...
STEP 1/7: GIVEN product "wooden desk" is available in product storage (Passed after 2ms)
STEP 2/7: AND product "wooden shelf" is available in product storage...
STEP 2/7: AND product "wooden shelf" is available in product storage (Passed after <1ms)
STEP 3/7: WHEN customer buys product "wooden desk"...
STEP 3/7: WHEN customer buys product "wooden desk" (Passed after <1ms)
STEP 4/7: AND customer buys product "wooden shelf"...
STEP 4/7: AND customer buys product "wooden shelf" (Passed after <1ms)
STEP 5/7: THEN an invoice should be sent to the customer...
STEP 5/7: THEN an invoice should be sent to the customer (Passed after <1ms)
STEP 6/7: AND the invoice should contain product "wooden desk" with price of "£62.00"...
STEP 6/7: AND the invoice should contain product "wooden desk" with price of "£62.00" (Passed after <1ms)
STEP 7/7: AND the invoice should contain product "wooden shelf" with price of "£37.00"...
STEP 7/7: AND the invoice should contain product "wooden shelf" with price of "£37.00" (Passed after <1ms)
SCENARIO RESULT: Passed after 30ms
For more information, please visit Test Progress Notification page.
Example HTML report generated after test execution:
When all tests are finished, LightBDD generates the HTML report file, providing the summary and the details of the executed scenarios - the fragment of the report is presented below.
To read more, please see Generating Reports wiki page.
Installation
The LightBDD is available on NuGet:
PM> Install-Package LightBDD.NUnit3
for package using NUnit 3xPM> Install-Package LightBDD.XUnit2
for package using xUnit 2xPM> Install-Package LightBDD.MsTest2
for package using MsTest.TestFrameworkPM> Install-Package LightBDD.Fixie2
for package using Fixie 2x
Productivity Extensions for Visual Studio
LightBDD project offers also a VSIX extension for Visual Studio, containing:
- Project Templates for all integrations (nunit/xunit/mstest/fixie),
- Feature Class Templates for all integrations (nunit/xunit/mstest/fixie),
- Code Snippets for creating Scenarios and Composite Steps.
The VSIX extension can be downloaded from: Visual Studio Gallery (Visual Studio 2012 and newer versions supported).
Migrating LightBDD
The current LightBDD version series is 3.X. To find out how to migrate from previous versions, please visit Migrating LightBDD Versions wiki page.
Debugging LightBDD from NuGet packages
LightBDD provides debug symbols helping with diagnostics - please check Debugging LightBDD Scenarios for details.
More information about LightBDD
If you are interested about background of LightBDD creation or getting insight into what is driving it's evolution, please feel free to take a look at my blog posts.
Community Projects
- LightBdd.TabularAttributes - Designed to be used with LightBdd Tabular Parameters to allow for specifying input and output data for tests via attributes, in a truth table format.