BunsenBurner.Hedgehog 6.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package BunsenBurner.Hedgehog --version 6.0.0                
NuGet\Install-Package BunsenBurner.Hedgehog -Version 6.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="BunsenBurner.Hedgehog" Version="6.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BunsenBurner.Hedgehog --version 6.0.0                
#r "nuget: BunsenBurner.Hedgehog, 6.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install BunsenBurner.Hedgehog as a Cake Addin
#addin nuget:?package=BunsenBurner.Hedgehog&version=6.0.0

// Install BunsenBurner.Hedgehog as a Cake Tool
#tool nuget:?package=BunsenBurner.Hedgehog&version=6.0.0                

Bunsen Burner Bunsen Burner Hedgehog

Nuget

This provides integration with Hedgehog to write clean and easy property based tests.

Getting Started

To use this library, simply include BunsenBurner.Hedgehog.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.Hedgehog.Aaa;

or

using static BunsenBurner.Hedgehog.Bdd;

What?

Hedgehog is an easy to use property based testing library.

It provides a way to build data generators that can auto shrink.

Property based tests are great for testing pure/deterministic functions . (Functions that always return the same result for a given set of inputs)

How to use

To start using it import the syntax that your test project is using.

using Hedgehog.Linq;
using Range = Hedgehog.Linq.Range;
using static BunsenBurner.Hedgehog.Aaa;

public class AaaTests
{
    [Fact(DisplayName = "The string is not empty and is less then 25 charecters")]
    public async Task Case1() =>
        // compose a generator using Linq
        await Gen.Alpha
            .String(Range.FromValue(25))
            // convert the generator to a scenario
            .ArrangeGenerator()
            // assert that the provided property holds for generated data
            .AssertPropertyHolds(s => s != string.Empty && s.Length is > 0 and < 26);
            
    [Fact(DisplayName = "Generators can be combined!")]
    public static async Task Case6() =>
        await (
            // use Linq to combine generators together to make more complex ones
            from name in Gen.Alpha.String(Range.FromValue(25))
            from age in Gen.Int32(Range.LinearFromInt32(1, 20, 99))
            select (name, age)
        )
            .ArrangeGenerator()
            .AssertPropertyHolds(t => t.name != null && t.age > 0);
}

For more information on property based testing and how to use Hedgehog with Bunsen Burner checkout the tests or raise a question/issue.

Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
6.2.4 12,659 6/20/2023
6.2.3 143 6/5/2023
6.2.2 172 4/25/2023
6.2.1 222 3/11/2023
6.2.0 273 1/29/2023
6.1.1 286 1/19/2023
6.1.0 2,311 1/12/2023
6.0.0 296 1/11/2023
5.3.1 297 1/7/2023
5.3.0 284 1/6/2023
5.2.0 325 12/17/2022
5.1.0 559 12/12/2022
5.0.0 299 12/11/2022
4.0.1 314 12/11/2022
4.0.0 301 12/11/2022
3.0.0 309 12/10/2022
2.2.0 311 12/9/2022
2.1.0 295 12/9/2022
2.0.0 285 12/9/2022
1.6.2 334 12/2/2022
1.6.1 325 12/1/2022
1.6.0 316 11/30/2022
1.5.1 331 11/26/2022
1.5.0 337 11/21/2022
1.4.1 336 11/19/2022
1.4.0 341 11/19/2022
1.3.0 331 11/19/2022
1.2.1 331 11/17/2022
1.2.0 344 11/16/2022
1.1.1 347 11/15/2022
1.1.0 333 11/15/2022
1.0.4 329 11/8/2022
1.0.3 358 11/6/2022
1.0.2 368 11/6/2022
1.0.1 351 11/6/2022
1.0.0 366 11/6/2022