Integration Testing an Asp.Net Core Web API with xUnit.net

Summary

In this post I would like to show you how to go about adding Integration tests to your Asp.Net Core Web API project using Xunit.net.

Pre-requisites

Why I would want to add Integration testing to my Web API

Integration tests are a great way to test infrastructure connectivity of various components of a solution such as testing request/response to your Web API, against external systems such as databases file systems etc..

Why am I choosing to use xUnit.net as my test framework

ASP.NET Core uses it internally to test the product. So it will be well supported and improved throughout Asp.Net Core’s evolution.

Asp.Net Core makes it easy and efficient to perform integration testing due to its support of a test web host and and in-memory test server allowing us to make actual HttpClient requests without going over the wire so no firewall or network config issues to deal with as well as this these calls are fast whilst still working with routing, model binding & validation etc.

I will use an already created out of the box Asp.Net Core Web API which will be our ‘SUT’ or System Under Test and create our Test(xUnit.net) project which will be the project containing and executing our tests against our SUT using the test runner.

Lets’ go….

I am purposely neglecting clean typical solution folder structure, exception handling etc. in order to keep the post focused on the objective.

This is how the Solution currently stands

image

It just has an out of the box Web API project I called Test.API

Create the Test project

Right click the solution and select Add then New project

type xunit in the search field on the top right of the window, the results should be filtered and you should see  ‘xUnit Test Project(.Net Core)’

image

select it and name the project ‘IntegrationTests’

Lets go ahead and delete the class UnitTest1.cs file that gets created by default and create two new classes called:

‘TestScenarios’ and ‘TestScenarioBase’

TestScenarios is our class containing our tests and TestScenarioBase is our base class containing the code to create a server to fire up our API in order to call that we will leverage in our out TestScenarios class.

Within the base class make the class public and paste the below method in to the class

<br>
public TestServer CreateServer()<br>
{<br>
    var webHostBuilder = WebHost.CreateDefaultBuilder();<br>
    webHostBuilder.UseStartup&amp;lt;Startup&amp;gt;();   <br>
    var testServer = new TestServer(webHostBuilder); <br>
    return testServer;<br>
}<br>

We will want to add the following Nuget packages :

  • Microsoft.AspNetCore
  • Microsoft.AspNetCore.TestHost
  • Microsft.AspNetCore.MVC

And we will need to add the folowing namespaces to the top of our class

  • using Microsoft.AspNetCore;
  • using Microsoft.AspNetCore.Hosting;
  • using Microsoft.AspNetCore.TestHost;
  • using Test.API;

The class should finally look like the below

image

In our TestScenarios class lets add the following code

<br>
[Fact]<br>
public async Task GetTest()<br>
{<br>
    using (var server = CreateServer())<br>
    {<br>
        var response = await server.CreateClient()<br>
        .GetAsync($"api/values/5");</p>
<p>Assert.Equal("value", await response.Content.ReadAsStringAsync());<br>
    }<br>
}<br>

Inherit from TestScenarioBase

Reference the namespaces:

  • using System.Threading.Tasks;
  • using Xunit;

Make the class public

The class should finally look like the below

image

In the code above we are calling our Get method in our Values Controller passing in an arbitrary value(5) to receive a response back to compare – by default our method simply returns “value”

Run the test using the test runner and we should receive a Successful test run.

That’s it!

In my MyReverie repository in GitHub I have implemented Integration Testing in to my Solution if you would like to see the code I referenced.

Adding Swagger to my ASP.Net Core API

I would like to show just how easy it is to add testing and documentation to your Asp.Net Core API using Swagger.

The reason I chose Swagger is simply that it is the largest framework of API developer tools for the OpenAPI specific which allows rapid documentation and testing of APIs with great ease.

For reference check out their website @ https://swagger.io/

First we want to add the Swashbuckle package from Nuget.

Right click your API project and click Manage Nuget Packages

Under the Browse tab search for Swashbuckle.AspNetCore

Package

Once found click install

Once installed we want to add the Swashbuckle namespace ‘Swashbuckle.AspNetCore.Swagger’ to our Startup class and in the ConfigureServices method the following:

services.AddSwaggerGen(c =&amp;amp;amp;amp;amp;amp;amp;gt;
{
    c.SwaggerDoc("v1", new Info { Title = "[Title]", Version = "v1" });
});

Replacing [Title] with the Title you would like to set

Next, In the Configure method within the scope of the env.IsDevelopment() check add

app.UseSwagger();

app.UseSwaggerUI(options =&amp;amp;amp;amp;amp;amp;amp;gt;
{
    options.SwaggerEndpoint("/swagger/v1/swagger.json", "[Name]");
});

Replacing [Name] with the API spec you would like to set

To try it out simply select one of the buttons corresponding to one of your API methods

Click the ‘Try it out’ button on top right

Then hit the Execute button

image

That’s it!

We’ve just added swagger, which will dynamically update as you add, remove or update your API removing the maintenance of separate documentation processes – fantastic.

My Reverie

MyReverie is a new simple side project I am working on. The idea is to build a goal tracking solution and be able to set target dates and milestone markers against those goals to track progress.

I will routinely push new updates to the GitHub repo : MyReverie

I have a rough idea of some of the features to add which I will list under the Projects Tab.

This is also a way to experiment and learn new technologies as I go, some technologies I will be looking to incorporate are Asp.Net Core, Swagger, Docker,  xUnit.Net and EF Core as well as patterns and approaches such as Microservices and DDD among others.

Let’s see how it goes!

Getting Started with Azure Service Fabric

I wanted to show a simple example of using Azure Service Fabric to create a reliable & scalable micro service that would perform addition functionality on an input string for example “1+1” using a console application as the client.

The string is parsed out to two integers and calculates the result. Obviously this is extremely simplistic type of example. I wanted to really just do a quick test on passing input and expecting output.

The code is listed up on my GitHub account under the ServiceFabric Repo.

ASP.NET Core Web API with Docker

This post simply demonstrates creating a simple service called ‘AdditionMicroservice’ that adds two numbers provided as query string parameters.

I will add this code to my GitHub account under Getting started with Microservices repo

Pre-requisites:

Docker for Windows

1) Create a new ASP.NET Core Web Application project

image

Select the Web API Template

image

Check the Enable Docker Support checkbox

Select Windows as the OS

Click

Open Values Controller file under Controllers

image 

Remove all other methods except first Get method and change to below as below

image

The change  launchUrl’s from api/value to api/addition in launchsettngs.json file:

image

Run the app and append to the URL both the x and y parameters along with their set values to view the result:

image