BunsenBurner.Http
6.1.1
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
<PackageReference Include="BunsenBurner.Http" Version="6.1.1" />
paket add BunsenBurner.Http --version 6.1.1
#r "nuget: BunsenBurner.Http, 6.1.1"
// 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 Http
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 | Versions 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. |
-
.NETCoreApp 3.1
- BunsenBurner (>= 6.1.1)
- BunsenBurner.Logging (>= 6.1.1)
- Flurl (>= 3.0.7)
- HttpBuildR.Request (>= 1.0.0)
- HttpBuildR.Response (>= 1.0.0)
- JWT (>= 10.0.0)
- LanguageExt.Core (>= 4.4.0)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 3.1.31)
- Microsoft.AspNetCore.TestHost (>= 3.1.31)
- Microsoft.Extensions.Http (>= 3.1.32)
- Microsoft.IdentityModel.Tokens (>= 6.25.1)
-
.NETStandard 2.0
- BunsenBurner (>= 6.1.1)
- BunsenBurner.Logging (>= 6.1.1)
- Flurl (>= 3.0.7)
- HttpBuildR.Request (>= 1.0.0)
- HttpBuildR.Response (>= 1.0.0)
- JWT (>= 10.0.0)
- LanguageExt.Core (>= 4.4.0)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 2.2.0)
- Microsoft.AspNetCore.TestHost (>= 2.2.0)
- Microsoft.Extensions.Configuration.Json (>= 2.2.0)
- Microsoft.Extensions.Http (>= 2.2.0)
- Microsoft.IdentityModel.Tokens (>= 6.25.1)
-
net6.0
- BunsenBurner (>= 6.1.1)
- BunsenBurner.Logging (>= 6.1.1)
- Flurl (>= 3.0.7)
- HttpBuildR.Request (>= 1.0.0)
- HttpBuildR.Response (>= 1.0.0)
- JWT (>= 10.0.0)
- LanguageExt.Core (>= 4.4.0)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 6.0.13)
- Microsoft.AspNetCore.TestHost (>= 6.0.13)
- Microsoft.Extensions.Http (>= 6.0.0)
- Microsoft.IdentityModel.Tokens (>= 6.25.1)
-
net7.0
- BunsenBurner (>= 6.1.1)
- BunsenBurner.Logging (>= 6.1.1)
- Flurl (>= 3.0.7)
- HttpBuildR.Request (>= 1.0.0)
- HttpBuildR.Response (>= 1.0.0)
- JWT (>= 10.0.0)
- LanguageExt.Core (>= 4.4.0)
- Microsoft.AspNetCore.Authentication.JwtBearer (>= 7.0.2)
- Microsoft.AspNetCore.TestHost (>= 7.0.2)
- Microsoft.Extensions.Http (>= 7.0.0)
- Microsoft.IdentityModel.Tokens (>= 6.25.1)
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 |