ArwynFr.IntegrationTesting 0.3.1

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

// Install ArwynFr.IntegrationTesting as a Cake Tool
#tool nuget:?package=ArwynFr.IntegrationTesting&version=0.3.1                

ArwynFr.IntegrationTesting

This library provides utility classes for writing integration tests in dotnet using XUnit and WebApplicationFactory.

Nuget.org Nuget.org GitHub
License

Installation

dotnet new classlib -n MyTestProject
dotnet add package ArwynFr.IntegrationTesting
dotnet add package Microsoft.NET.Test.Sdk
dotnet add package xunit.runner.visualstudio

Usage

Read advanced usage documentation for further details.

By default, the lib redirects the tested application logs to XUnit output, so you get them in the test output in case of failure. It also overwrites the application configuration with values from user secrets and environement variables.

public class MyTest(ITestOutputHelper output) : IntegrationTestBase<Program>(output)
{
    // Override a service with fake implementation in the tested app
    protected override void ConfigureAppServices(IServiceCollection services)
        => services.AddSingleton<IMyService, FakeService>();

    [Fact]
    public async Task OnTest()
    {
        // Call system under test
        var response = await Client.GetFromJsonAsync<OrderDto>($"/order");

        response.Should().HaveValue();
    }
}

EntityFrameworkCore integration

If your application uses EFcore, add the DbContext as a generic parameter and provide a configuration method. You can override the DbContext lifetime strategy according to your needs:

public class TestBaseDb(ITestOutputHelper output) : IntegrationTestBase<Program, MyDbContext>(output)
{
    // Create and drop a database for every test execution
    protected override IDatabaseTestStrategy<Context> DatabaseTestStrategy
        => IDatabaseTestStrategy<MyDbContext>.DatabasePerTest;

    // Configure EFcore with a random database name par test
    protected override void ConfigureDbContext(DbContextOptionsBuilder builder)
        => builder.UseSqlite($"Data Source={Guid.NewGuid()}.sqlite");

    [Fact]
    public async Task OnTest()
    {
        // Access the injected dbcontext
        var value = await Database.Values
            .Where(val => val.Id == 1)
            .Select(val => val.Result)
            .FirstOrDefaultAsync();

        // Call system under test
        var result = await Client.GetFromJsonAsync<int>("/api/value/1");

        result.Should().Be(value + 1);
    }
}

OpenTelemetry integration

You can access OTEL activities produced by your application in your tests. This requires you to list which activities to monitor:

public class OpenTelemetryTests(ITestOutputHelper output) : IntegrationTestBase<Program>(output)
{
    // Tell the library which OTEL sources you want to monitor
    // Traces from other sources will be ignored
    protected override string[] OpenTelemetrySourceNames => ["SourceA", "SourceB"];

    [Fact]
    public async Task Otel()
    {
        // Call system under test
        await Client.GetAsync("/otel");

        // Assert on the collection of all activities collected
        Activities.Any(activity => activity.DisplayName == "Hello").Should().BeTrue();
    }
}

Contributing

This project welcomes contributions:

Request for support:
We do not provide commercial support for this product.

Disclose vulnerability:
Read our security policy
Create a new security advisory on GitHub

Report malfunctions:
Create a new issue on GitHub

Suggest a feature:
Create a new issue on GitHub

Offer some code:
Read our definition of done
Fork the repository
Submit a pull-request

Moderate contributions:
Read our governance policy
This project is not currently appointing new moderators.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
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
0.3.10 92 9/27/2024
0.3.9 85 9/25/2024
0.3.8 77 9/23/2024
0.3.7 127 9/16/2024
0.3.6 97 9/10/2024
0.3.5 98 9/9/2024
0.3.4 103 9/5/2024
0.3.3 126 8/23/2024
0.3.2 110 8/20/2024
0.3.1 117 8/17/2024
0.3.0 130 8/16/2024
0.2.41 106 8/16/2024
0.2.40 120 8/14/2024
0.2.39 118 8/13/2024
0.2.37 96 8/7/2024
0.2.35 94 7/9/2024
0.2.34 113 7/8/2024
0.2.33 101 6/26/2024
0.2.32 95 6/26/2024
0.2.31 98 6/18/2024
0.2.30 100 6/14/2024
0.2.29 81 6/7/2024
0.2.28 99 6/2/2024
0.2.27 83 5/22/2024
0.2.26 108 5/17/2024
0.2.25 96 5/16/2024
0.2.24 100 5/16/2024
0.2.23 106 5/15/2024
0.2.22 97 5/15/2024
0.2.21 93 5/15/2024
0.2.20 108 5/14/2024
0.2.19 86 5/13/2024
0.2.18 132 4/28/2024
0.2.17 99 4/24/2024
0.2.16 106 4/18/2024
0.2.15 87 4/17/2024
0.2.14 83 4/17/2024
0.2.12 98 4/12/2024
0.2.11 117 4/12/2024
0.2.10 119 4/10/2024
0.2.9 94 4/8/2024
0.2.8 99 4/8/2024
0.2.7 127 3/15/2024
0.2.6 128 3/15/2024
0.2.5 116 3/6/2024
0.2.4 118 2/24/2024
0.2.3 103 2/16/2024
0.2.2 119 2/14/2024
0.2.1 133 2/8/2024
0.2.0 113 2/2/2024
0.1.2 112 1/30/2024
0.1.1 110 1/30/2024
0.1.0 113 1/26/2024