Partager via


Tests unitaires C# avec MSTest et .NET

Ce tutoriel vous guide tout au long d’une expérience interactive qui crée un exemple de solution pas à pas pour apprendre les concepts de test unitaire. Si vous préférez suivre le didacticiel à l’aide d’une solution prédéfinie, afficher ou télécharger l’exemple de code avant de commencer. Pour obtenir des instructions de téléchargement, consultez Exemples et didacticiels.

Cet article concerne le test d’un projet .NET Core. Si vous testez un projet ASP.NET Core, consultez tests d’intégration dans ASP.NET Core.

Conditions préalables

Créer le projet source

Ouvrez une fenêtre shell. Créez un répertoire appelé unit-testing-using-mstest pour contenir la solution. Dans ce nouveau répertoire, exécutez dotnet new sln pour créer un fichier solution pour la bibliothèque de classes et le projet de test. Créez un répertoire PrimeService . Le plan suivant montre le répertoire et la structure de fichiers jusqu’à présent :

/unit-testing-using-mstest
    unit-testing-using-mstest.sln
    /PrimeService

Créez PrimeService le répertoire actif et exécutez dotnet new classlib pour créer le projet source. Renommez Class1.cs en PrimeService.cs. Remplacez le code dans le fichier par le code suivant pour créer une implémentation défaillante de la PrimeService classe :

using System;

namespace Prime.Services
{
    public class PrimeService
    {
        public bool IsPrime(int candidate)
        {
            throw new NotImplementedException("Please create a test first.");
        }
    }
}

Revenez au répertoire unit-testing-using-mstest . Exécutez dotnet sln add pour ajouter le projet de bibliothèque de classes à la solution.

dotnet sln add PrimeService/PrimeService.csproj

Créer le projet de test

Créez le répertoire PrimeService.Tests . Le plan suivant montre la structure de répertoires :

/unit-testing-using-mstest
    unit-testing-using-mstest.sln
    /PrimeService
        Source Files
        PrimeService.csproj
    /PrimeService.Tests

Créez le répertoire PrimeService.Tests le répertoire actif et créez un projet à l’aide de dotnet new mstest. La commande dotnet new crée un projet de test qui utilise MSTest comme bibliothèque de tests. Le modèle configure l’exécuteur de test dans le fichier PrimeServiceTests.csproj :

<ItemGroup>
  <PackageReference Include="MSTest" Version="3.2.0" />
  <PackageReference Include="Microsoft.Testing.Extensions.CodeCoverage" Version="17.10.1" />
</ItemGroup>

Le projet de test nécessite d’autres packages pour créer et exécuter des tests unitaires. dotnet new à l’étape précédente, vous avez ajouté les packages et outils MSTest nécessaires pour la création de rapports de couverture du code.

Ajoutez la PrimeService bibliothèque de classes comme autre dépendance au projet. Utilisez la commande dotnet reference add :

dotnet reference add ../PrimeService/PrimeService.csproj

Vous pouvez voir l’intégralité du fichier dans le référentiel d’exemples sur GitHub.

Le plan suivant montre la disposition finale de la solution :

/unit-testing-using-mstest
    unit-testing-using-mstest.sln
    /PrimeService
        Source Files
        PrimeService.csproj
    /PrimeService.Tests
        Test Source Files
        PrimeServiceTests.csproj

Accédez au répertoire unit-testing-using-mstest , puis exécutez dotnet sln add:

dotnet sln add ./PrimeService.Tests/PrimeService.Tests.csproj

Créer le premier test

Écrivez un test défaillant, faites-le passer, puis répétez le processus. Supprimez UnitTest1.cs du répertoire PrimeService.Tests et créez un fichier C# nommé PrimeService_IsPrimeShould.cs avec le contenu suivant :

using Microsoft.VisualStudio.TestTools.UnitTesting;
using Prime.Services;

namespace Prime.UnitTests.Services
{
    [TestClass]
    public class PrimeService_IsPrimeShould
    {
        private readonly PrimeService _primeService;

        public PrimeService_IsPrimeShould()
        {
            _primeService = new PrimeService();
        }

        [TestMethod]
        public void IsPrime_InputIs1_ReturnFalse()
        {
            bool result = _primeService.IsPrime(1);

            Assert.IsFalse(result, "1 should not be prime");
        }
    }
}

L’attribut TestClass désigne une classe qui contient des tests unitaires. L’attribut TestMethod indique qu’une méthode est une méthode de test.

Enregistrez ce fichier et exécutez dotnet test pour générer les tests et la bibliothèque de classes, puis exécutez les tests. L’exécuteur de test MSTest contient le point d’entrée du programme pour exécuter vos tests. dotnet test démarre l’exécuteur de test à l’aide du projet de test unitaire que vous avez créé.

Votre test échoue. Vous n’avez pas encore créé l’implémentation. Effectuez ce test en écrivant le code le plus simple dans la classe PrimeService qui fonctionne :

public bool IsPrime(int candidate)
{
    if (candidate == 1)
    {
        return false;
    }
    throw new NotImplementedException("Please create a test first.");
}

Dans le répertoire unit-testing-using-mstest , exécutez dotnet test à nouveau. La commande dotnet test exécute une build pour le projet PrimeService, puis pour le projet PrimeService.Tests. Après avoir généré les deux projets, il exécute ce test unique. Ça passe.

Ajouter d’autres fonctionnalités

Maintenant que vous avez passé un test, il est temps d’écrire plus. Il existe quelques autres cas simples pour les nombres premiers : 0, -1. Vous pouvez ajouter de nouveaux tests avec l’attribut TestMethod, mais cela devient rapidement fastidieux. Il existe d’autres attributs MSTest qui vous permettent d’écrire une suite de tests similaires. Une méthode de test peut exécuter le même code, mais elle a des arguments d’entrée différents. Vous pouvez utiliser l’attribut DataRow pour spécifier des valeurs pour ces entrées.

Au lieu de créer de nouveaux tests, appliquez ces deux attributs pour créer un seul test piloté par les données. Le test piloté par les données est une méthode qui teste plusieurs valeurs inférieures à deux, qui est le nombre premier le plus bas. Ajoutez une nouvelle méthode de test dans PrimeService_IsPrimeShould.cs :

[TestMethod]
[DataRow(-1)]
[DataRow(0)]
[DataRow(1)]
public void IsPrime_ValuesLessThan2_ReturnFalse(int value)
{
    var result = _primeService.IsPrime(value);

    Assert.IsFalse(result, $"{value} should not be prime");
}

Exécutez dotnet test, et deux de ces tests échouent. Pour passer tous les tests, modifiez la if clause au début de la IsPrime méthode dans le fichier PrimeService.cs :

if (candidate < 2)

Continuez à itérer en ajoutant d’autres tests, plus de théories et plus de code dans la bibliothèque principale. Vous disposez de la version terminée des tests et de l’implémentation complète de la bibliothèque.

Vous avez créé une petite bibliothèque et un ensemble de tests unitaires pour cette bibliothèque. Vous avez structuré la solution pour que l’ajout de nouveaux packages et tests fasse partie du flux de travail normal. Vous avez concentré la plupart de votre temps et votre effort sur la résolution des objectifs de l’application.

Voir aussi