Un aspetto storicamente spesso problematico, è sempre stato quello di eseguire integration test su un'applicazione in maniera affidabile. Ci sono molteplici scogli da superare, per esempio avere un server attivo su cui effettuare le chiamate, o integrarsi con un database, ma spesso questi strumenti sono l'unico modo per verificare il corretto comportamento di componenti quali filtri, controller, middleware, ecc.
Come sappiamo, ASP.NET Core contiene al suo interno il web server Kestrel, cosa che semplifica di molto il nostro compito, visto che
- non dobbiamo integrarci con un server esterno e
- possiamo controllarne la configurazione e lo startup da C#.
Immaginiamo di aver creato un progetto Web API - per esempio il template di default - e di voler invocare WeatherForecastController per verificarne la risposta. Per prima cosa abbiamo bisogno di avviare il Kestrel. Allo scopo, è sufficiente che il nostro progetto di test referenzi la web application e, se stiamo usando XUnit, possiamo semplicemente invocare il metodo Program.Main nel costruttore della nostra classe di test:
public class WeatherControllerTests { public WeatherControllerTests() { Task.Run(() => WebApplication1.Program.Main(new string[0])); } // .. qui test code .. }
Il codice è piuttosto elementare, l'unica nota riguarda il fatto che la chiamata a Program.Main per avviare Kestrel è bloccante, e pertanto dobbiamo eseguirla all'interno di un Task in background.
A questo punto, il nostro server è effettivamente raggiungibile e possiamo finalmente scrivere il nostro test:
[Fact] public async Task WeatherController_ReturnsWeatherData() { var client = new HttpClient(); var response = await client.GetAsync("https://localhost:5001/WeatherForecast"); response.EnsureSuccessStatusCode(); var result = JsonConvert.DeserializeObject<IEnumerable<WeatherForecast>>( await response.Content.ReadAsStringAsync()); Assert.NotEmpty(result); }
Come possiamo notare, si tratta di un vero e proprio integration test, visto che non stiamo invocando il controller come oggetto .NET, ma stiamo effettuando una chiamata HTTP verso un endpoint.
L'esempio è volutamente banale, dato che WeatherController non ha alcuna dipendenza verso oggetti esterni (database, servizi, ecc.). In un prossimo script vedremo come effettuare il mocking di eventuali dipendenze così da rendere i nostri test più controllabili e veloci da eseguire.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Effettuare il deploy di immagini solo da container registry approvati in Kubernetes
Utilizzare domini personalizzati gestiti automaticamente con Azure Container Apps
Utilizzare la versione generica di EntityTypeConfiguration in Entity Framework Core
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Hosting di componenti WebAssembly in un'applicazione Blazor static
Implementare l'infinite scroll con QuickGrid in Blazor Server
Routing statico e PreRendering in una Blazor Web App
Evitare il flickering dei componenti nel prerender di Blazor 8
Implementare il throttling in ASP.NET Core
Gestire liste di tipi semplici con Entity Framework Core
Sfruttare lo streaming di una chiamata Http da Blazor
Generare file per il download da Blazor WebAssembly
I più letti di oggi
- ASP.NET Core Identity 8: è rivoluzione?
- Tutorial ASP.NET Dynamic Data Control
- Accesso dai dati con Entity Framework 7
- Utilizzare la classe XmlDataDocument per leggere un Feed RSS
- Microsoft Security Bulletin MS08-067
- Le novità di ASP.NET 4.5
- Mostrare tutti i cookie creati in fase di debug
- MIX 2011: Tutte le novità dei tool di ASP.NET MVC 3
- Usare il sensore di luminosità ambientale nelle Universal App