BunsenBurner 1.0.3
See the version list below for details.
dotnet add package BunsenBurner --version 1.0.3
NuGet\Install-Package BunsenBurner -Version 1.0.3
<PackageReference Include="BunsenBurner" Version="1.0.3" />
paket add BunsenBurner --version 1.0.3
#r "nuget: BunsenBurner, 1.0.3"
// Install BunsenBurner as a Cake Addin #addin nuget:?package=BunsenBurner&version=1.0.3 // Install BunsenBurner as a Cake Tool #tool nuget:?package=BunsenBurner&version=1.0.3
Bunsen Burner Core
This provides the core dependency free test abstraction that Bunsen Burner is built on.
Getting Started
To use this library, simply include BunsenBurner.dll
in your project or grab
it from NuGet, and add this to
the top of each test .cs
file
that needs it:
using static BunsenBurner.Aaa; // For Arrange act assert
or
using static BunsenBurner.Bdd; // For Given when then
What?
The type that makes this library possible is a Scenario.
This is an ADT that models a single test. It has the following structure,
Scenario<
// Supported Syntax, either arrange act assert (Aaa) or given when then (Bdd)
TSyntax
>.(
// Scenario that has been arranged and is ready to act on, returning a TData
Arranged<TData> |
// Scenario that has been acted on, taking a TData returning a TResult and is ready to assert against
Acted<TData, TResult> |
// Scenario that is asserted against a TResult. This can be run.
Asserted<TData, TResult>)
This structure represents a lazy asynchronous immutable test that can be composed and later run.
The aim is for the type parameters to be fully inferable. There are a few edge cases to this, but the core abstractions require no provided type parameters.
How to use
To start using it import either the Aaa or Bdd syntax and start composing the test.
Arrange, Act, Assert
using static BunsenBurner.Aaa;
[Fact(DisplayName = "Some simple test")]
public async Task Case1() =>
await Arrange(() => 1)
.And(x => x.ToString())
.Act(x => x.Length)
.And((_, r) => r + 1)
.Assert((_, r) => Assert.Equal(2, r));
Given, When, Then
using static BunsenBurner.Bdd;
[Fact(DisplayName = "Some simple test")]
public async Task Case1() =>
await Given(() => 1)
.And(x => x.ToString())
.When(x => x.Length)
.And((_, r) => r + 1)
.Then((_, r) => Assert.Equal(2, r));
The test is run using a custom awaiter, so async await is required.
Also as the pipeline is fully async, you need to always await a Scenario, even if all your components are synchronous.
Benefits
- Standardised - All tests are built on the same abstraction, it can model any
test,
- Must be composed in the correct sequence
- Arrange/Given
- Act/When
- Assert/Then
- And steps can be used between to allow for transformations
- Must be composed in the correct sequence
- Data driven - Scenarios are just data, can be passed to and from functions, can be put in a list, assigned to variables
- Composable - Both within a single test and over multiple tests
- Write custom extension methods to extend the syntax in any direction, with the comfort of knowing it will make sure the developer uses it correctly. Just look at the other libraries provided for inspiration
- Functional first, its just data with functions that operate on that data
- Readable - Enforced structures with no easy way to shoot yourself in the foot, should result in code that is easier to maintain and read
- Simple - 1 data type, and functions that operate on it
- Flexible
- No dependencies
- No assumptions around test frameworks
- No assumptions around SUT
- No requirements on the user code
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- No dependencies.
NuGet packages (12)
Showing the top 5 NuGet packages that depend on BunsenBurner:
Package | Downloads |
---|---|
BunsenBurner.Http
Extension methods for testing Http servers |
|
BunsenBurner.Verify.Xunit
Integration with [Verify.Xunit](https://github.com/VerifyTests/Verify) to simplify assert steps |
|
BunsenBurner.AutoFixture
Integration with [AutoFixture](https://github.com/AutoFixture) to simplify arrange steps |
|
BunsenBurner.Hedgehog
Integration with [Hedgehog](https://github.com/hedgehogqa/fsharp-hedgehog) to write property based tests |
|
BunsenBurner.Bogus
Integration with [Bogus](https://github.com/bchavez/Bogus) to simplify arrange steps |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
7.0.1 | 140 | 1/3/2025 |
7.0.0 | 2,070 | 6/23/2024 |
6.2.4 | 14,958 | 6/20/2023 |
6.2.3 | 1,494 | 6/5/2023 |
6.2.2 | 3,534 | 4/25/2023 |
6.2.1 | 5,869 | 3/11/2023 |
6.2.0 | 2,826 | 1/29/2023 |
6.1.1 | 3,294 | 1/19/2023 |
6.1.0 | 4,547 | 1/12/2023 |
6.0.0 | 2,613 | 1/11/2023 |
5.3.1 | 2,688 | 1/7/2023 |
5.3.0 | 2,662 | 1/6/2023 |
5.2.0 | 2,720 | 12/17/2022 |
5.1.0 | 3,027 | 12/12/2022 |
5.0.0 | 2,709 | 12/11/2022 |
4.0.1 | 2,702 | 12/11/2022 |
4.0.0 | 2,724 | 12/11/2022 |
3.0.0 | 2,684 | 12/10/2022 |
2.2.0 | 2,648 | 12/9/2022 |
2.1.0 | 2,656 | 12/9/2022 |
2.0.0 | 2,765 | 12/9/2022 |
1.6.2 | 3,055 | 12/2/2022 |
1.6.1 | 2,996 | 12/1/2022 |
1.6.0 | 2,917 | 11/30/2022 |
1.5.1 | 3,076 | 11/26/2022 |
1.5.0 | 3,010 | 11/21/2022 |
1.4.1 | 2,423 | 11/19/2022 |
1.4.0 | 2,345 | 11/19/2022 |
1.3.0 | 2,207 | 11/19/2022 |
1.2.1 | 2,039 | 11/17/2022 |
1.2.0 | 2,104 | 11/16/2022 |
1.1.1 | 2,140 | 11/15/2022 |
1.1.0 | 2,034 | 11/15/2022 |
1.0.4 | 1,725 | 11/8/2022 |
1.0.3 | 1,849 | 11/6/2022 |
1.0.2 | 1,871 | 11/6/2022 |
1.0.1 | 1,849 | 11/6/2022 |
1.0.0 | 1,867 | 11/6/2022 |