BunsenBurner.Http 6.1.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package BunsenBurner.Http --version 6.1.1                
NuGet\Install-Package BunsenBurner.Http -Version 6.1.1                
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.Http" Version="6.1.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add BunsenBurner.Http --version 6.1.1                
#r "nuget: BunsenBurner.Http, 6.1.1"                
#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.Http as a Cake Addin
#addin nuget:?package=BunsenBurner.Http&version=6.1.1

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

Bunsen Burner Bunsen Burner Http

Nuget

Getting Started

To use this library, simply include BunsenBurner.Http.dll in your project or grab it from NuGet, and add this to the top of each test .cs file that needs it:

using BunsenBurner.Http;
// allows for fluent building of requests and responses
using HttpBuildR;
using Req = System.Net.Http.HttpMethod;
using Resp = System.Net.HttpStatusCode;

What?

This provides a set of extensions and types to make testing HTTP based services easy!

Compose a request like so,

using HttpBuildR;
using Req = System.Net.Http.HttpMethod;
...
var req = 
    // start with a HTTP method
    Req.Get
    // flurl can be used for the URL composition
    .To("/hello-world".SetQueryParam("a", 1)) // all http verbs as covered
    // the non-url based parts are covered by methods
    // including JWT based auth token construction
    .WithHeader("b", 123, x => x.ToString())

Then convert the request to a scenario that can be run against a test or real server.

The test server builder provides an opinionated way to build test servers.

req.ArrangeRequest() // convert to a scenario
    // run the request against the test server defined by the Startup class
   .ActAndCall(TestServerBuilderOptions.New<Startup>().Build())
    // a response context contains the http response and all log messages produced
    // while handling the request
   .Assert(ctx => ctx.Response.StatusCode == HttpStatusCode.OK);

And HttpClient can be mocked out via a HttpMessageStore

using HttpBuildR;
using static BunsenBurner.Http.HttpMessageMatchers;
using Req = System.Net.Http.HttpMethod;
using Resp = System.Net.HttpStatusCode;

var store = HttpMessageStore.New();
store.Setup(
    // for a given named client
    "PersonService",
    // matchers can be used and composed to match incomming requests
    HasMethod(HttpMethod.Put).And(HasJsonContent((Person p) => p.Age > 19))),
    // response builder can be provided
    req => Resp.OK.Result(request: req)
                  .WithJsonContent(new { LastUpdatedDate = DateTime.Now })
...
// now a store can be converted to a client, or passed to a DummyFactory
var client = store.CreateClient("PersonService");
// now call the client
var result = await client.SendAsync(Req.Put.To("some-endpoint")
                                           .WithBearerToken(...)
                                           .WithJsonContent(new Person(25)));
// the store records all requests and responses made against it
Assert.True(store.Any(m => m.ClientName == "PersonService"
                        && m.Request.Method == HttpMethod.Put
                        && m.Response.StatusCode == Resp.OK))

That's it! Just compose requests and assert against responses.

For more examples check out the test project, create an issue or start a discussion.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 is compatible.  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 is compatible.  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. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 is compatible. 
.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 11,330 6/20/2023
6.2.3 161 6/5/2023
6.2.2 209 4/25/2023
6.2.1 258 3/11/2023
6.2.0 306 1/29/2023
6.1.1 755 1/19/2023
6.1.0 2,315 1/12/2023
6.0.0 317 1/11/2023
5.3.1 516 1/7/2023
5.3.0 530 1/6/2023
5.2.0 562 12/17/2022
5.1.0 814 12/12/2022
5.0.0 532 12/11/2022
4.0.1 552 12/11/2022
4.0.0 571 12/11/2022
3.0.0 551 12/10/2022
2.2.0 511 12/9/2022
2.1.0 541 12/9/2022
2.0.0 616 12/9/2022
1.6.2 641 12/2/2022
1.6.1 599 12/1/2022
1.6.0 563 11/30/2022
1.5.1 624 11/26/2022
1.5.0 611 11/21/2022
1.4.1 611 11/19/2022
1.4.0 597 11/19/2022
1.3.0 611 11/19/2022
1.2.1 626 11/17/2022
1.2.0 603 11/16/2022
1.1.1 636 11/15/2022
1.1.0 608 11/15/2022
1.0.4 485 11/8/2022
1.0.3 519 11/6/2022
1.0.2 522 11/6/2022
1.0.1 513 11/6/2022
1.0.0 526 11/6/2022