Intégration continue - Test

L'une des principales caractéristiques de l'intégration continue est de garantir que on-going testingcontient tout le code généré par le serveur CI. Une fois la génération effectuée par le serveur CI, il faut s'assurer que les cas de test sont en place pour faire tester le code requis. Chaque serveur CI a la possibilité d'exécuter des cas de test unitaires dans le cadre duCI suite. Dans.Net, le test unitaire est une fonctionnalité intégrée au .Net framework et la même chose peut également être intégrée au serveur CI.

Ce chapitre va voir comment nous pouvons définir un cas de test dans .Netpuis laissez notre serveur TeamCity exécuter ce cas de test une fois la construction terminée. Pour cela, nous devons d'abord nous assurer que nous avons défini un test unitaire pour notre exemple de projet.

Pour ce faire, nous devons suivre les étapes suivantes avec le plus grand soin.

Step 1- Ajoutons une nouvelle classe à notre solution, qui sera utilisée dans notre test unitaire. Cette classe aura une variable de nom, qui contiendra la chaîne «Intégration continue». Cette chaîne sera affichée sur la page Web. Faites un clic droit sur le projet simple et choisissez l'option de menuAdd → Class.

Step 2 - Donnez un nom à la classe comme Tutorial.cs et cliquez sur le bouton Ajouter en bas de l'écran.

Step 3- Ouvrez le fichier Tutorial.cs et ajoutez-y le code suivant. Ce code crée simplement une chaîne appeléeName, et dans le constructeur, attribuez le nom à une valeur de chaîne comme Continuous Integration.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace Simple {
   public class Tutorial {
      public String Name;
      public Tutorial() {
         Name = "Continuous Integration";
      }
   }
}

Step 4 - Faisons le changement de notre Demo.aspx.csfile pour utiliser cette nouvelle classe. Mettez à jour le code de ce fichier avec le code suivant. Donc, ce code va maintenant créer une nouvelle instance de la classe créée ci-dessus.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

namespace Simple {
   public partial class Demo : System.Web.UI.Page {
      Tutorial tp = new Tutorial();
      protected void Page_Load(object sender, EventArgs e) {
         tp.Name = "Continuous Integration";
      }
   }
}

Step 5 - Dans notre demo.aspx fichier, référençons maintenant le tp.Name variable, qui a été créée dans le aspx.cs fichier.

<%@ Page Language = "C#" AutoEventWireup = "true" 
   CodeBehind = "Demo.aspx.cs" Inherits = "Simple.Demo" %>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml">
   
   <head runat = "server">
      <title>TutorialsPoint1</title>
   </head>
   
   <body>
      <form id = "form1" runat = "server">
         <div>
            <% = tp.Name%>)
         </div>
      </form>
   </body>
   
</html>

Pour vous assurer que notre code fonctionne correctement avec ces modifications, vous pouvez exécuter le code dans Visual Studio. Vous devriez obtenir la sortie suivante une fois la compilation terminée.

Step 6- Il est maintenant temps d'ajouter nos tests unitaires au projet. Faites un clic droit surSolution et choisissez l'option de menu Add → New Project.

Step 7 - Accédez à Test et sur le côté droit, choisissez Unit Test Project. Donnez un nom commeDemoTest puis cliquez sur OK.

Step 8 - Dans votre Demo Test project, vous devez ajouter une référence au projet Simple et au nécessaire testing assemblies. Faites un clic droit sur le projet et choisissez l'option de menuAdd Reference.

Step 9 - Dans l'écran suivant qui apparaît, allez dans Projets, choisissez Simple Reference et cliquez sur OK.

Step 10 - Cliquez Add Reference encore une fois, allez dans Assemblys et tapez Webdans la zone de recherche. Ajoutez ensuite une référence deSystem.Web.

Step 11 - Dans le Unit Test file, ajoutez le code suivant. Ce code garantira que la classe Tutorial a une variable de nom de chaîne. Il affirmera également le fait que le nom doit être égal à une valeur d '«intégration continue». Ce sera notre cas de test simple.

using System;
using Microsoft.VisualStudio.TestTools.UnitTesting;
using Microsoft.VisualStudio.TestTools.UnitTesting.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Simple;

namespace DemoTest {
   [TestClass]
   public class UnitTest1 {
      [TestMethod]
      public void TestMethod1() {
         Tutorial tp = new Tutorial();
         Assert.AreEqual(tp.Name, "Continuous Integration");
      }
   }
}

Step 12- Exécutons maintenant notre test dans Visual Studio pour nous assurer qu'il fonctionne. Dans Visual Studio, choisissez l'option de menuTest → Run → All Tests.

Après avoir exécuté le test, vous verrez le test s'exécuter avec succès sur le côté gauche de Visual Studio.

Activation des tests continus dans TeamCity - Maintenant que tous les cas de test sont en place, il est temps de les intégrer dans notre serveur Team City.

Step 13- Pour cela, nous devons créer une étape de construction dans notre configuration de projet. Accédez à la page d'accueil de votre projet et cliquez sur Modifier les paramètres de configuration.

step 14 - Ensuite, allez à Étape de construction → Construction MS et cliquez sur Ajouter une étape de construction comme illustré dans la capture d'écran suivante.

Dans l'écran suivant qui apparaît, ajoutez les valeurs suivantes -

  • Choisissez le type de runner comme tests Visual Studio.

  • Entrez un nom d'étape de test facultatif.

  • Choisissez le type de moteur de test comme VSTest.

  • Choisissez la version du moteur de test comme VSTest2013.

  • Dans le nom des fichiers de test, indiquez l'emplacement comme DemoTest\bin\Debug\DemoTest.dll - Souviens-toi que DemoTestest le nom de notre projet qui contient nos tests unitaires. leDemoTest.dll sera généré par notre première étape de construction.

  • Cliquez sur Enregistrer qui sera disponible à la fin de l'écran.

Vous aurez maintenant 2 étapes de construction pour votre projet. La première est l'étape Build qui va générer votre code d'application et votre projet de test. Et le suivant sera utilisé pour exécuter vos cas de test.

Step 15- Il est maintenant temps d'enregistrer tout votre code dans Git, afin que tout le processus de construction puisse être déclenché. La seule différence est que cette fois, vous devez exécuter legit add et git commit commande du Demo parent folder comme indiqué dans la capture d'écran suivante.

Maintenant, lorsque la construction est déclenchée, vous verrez une sortie initiale indiquant que le test a réussi.

Step 16 - Si vous cliquez sur le résultat Test réussi et allez dans l'onglet Test, vous verrez maintenant que le UnitTest1 a été exécuté et qu'il est passé.