Intégration continue - Exigences
Voici la liste des exigences les plus importantes pour l'intégration continue.
Check-In Regularly- La pratique la plus importante pour que l'intégration continue fonctionne correctement est des enregistrements fréquents dans le tronc ou la ligne principale du référentiel de code source. L'enregistrement du code doit avoir lieu au moins deux fois par jour. L'enregistrement régulier apporte de nombreux autres avantages. Cela rend les changements plus petits et donc moins susceptibles de casser la construction. Cela signifie que la version la plus récente du logiciel vers laquelle revenir est connue lorsqu'une erreur est commise dans une version ultérieure.
Cela aide également à être plus discipliné dans la refactorisation du code et à s'en tenir à de petits changements qui préservent le comportement. Cela permet de garantir que les modifications modifiant de nombreux fichiers sont moins susceptibles d'entrer en conflit avec le travail d'autres personnes. Cela permet aux développeurs d'être plus explorateurs, d'essayer des idées et de les rejeter en revenant à la dernière version validée.
Create a Comprehensive Automated Test Suite- Si vous ne disposez pas d'une suite complète de tests automatisés, une version réussie signifie uniquement que l'application peut être compilée et assemblée. Bien que pour certaines équipes, il s'agisse d'une étape importante, il est essentiel de disposer d'un certain niveau de test automatisé pour garantir que votre application fonctionne réellement.
Normalement, il existe 3 types de tests effectués en intégration continue à savoir unit tests, component tests, et acceptance tests.
Les tests unitaires sont écrits pour tester le comportement de petits éléments de votre application de manière isolée. Ils peuvent généralement être exécutés sans démarrer l'ensemble de l'application. Ils n'atteignent pas la base de données (si votre application en a une), le système de fichiers ou le réseau. Ils ne nécessitent pas que votre application s'exécute dans un environnement de type production. Les tests unitaires devraient s'exécuter très rapidement - toute votre suite, même pour une application volumineuse, devrait pouvoir s'exécuter en moins de dix minutes.
Les tests de composants testent le comportement de plusieurs composants de votre application. Comme les tests unitaires, ils ne nécessitent pas toujours de démarrer l'application entière. Cependant, ils peuvent frapper la base de données, le système de fichiers ou d'autres systèmes (qui peuvent être supprimés). Les tests de composants prennent généralement plus de temps à s'exécuter.
Keep the Build and Test Process Short - Si la construction du code et l'exécution des tests unitaires prennent trop de temps, vous rencontrerez les problèmes suivants.
Les utilisateurs arrêteront de faire une compilation complète et exécuteront les tests avant de s'enregistrer. Vous commencerez à avoir plus de builds défaillants.
Le processus d'intégration continue prendra tellement de temps que plusieurs validations auraient eu lieu au moment où vous pouvez exécuter à nouveau la génération, de sorte que vous ne saurez pas quel enregistrement a interrompu la génération.
Les gens s'enregistreront moins souvent parce qu'ils doivent rester assis pendant des siècles à attendre que le logiciel soit créé et que les tests soient exécutés.
Don’t Check-In on a Broken Build- La plus grande bévue de l'intégration continue consiste à vérifier une version cassée. Si la construction est interrompue, les développeurs responsables attendent de la réparer. Ils identifient la cause de la casse dès que possible et la réparent. Si nous adoptons cette stratégie, nous serons toujours les mieux placés pour déterminer la cause de la casse et la réparer immédiatement.
Si l'un de nos collègues a effectué un enregistrement et a par conséquent cassé la version, alors pour avoir les meilleures chances de le réparer, il aura besoin d'une analyse claire du problème. Lorsque cette règle est enfreinte, il faut inévitablement beaucoup plus de temps pour que la construction soit corrigée. Les gens s'habituent à voir la construction cassée, et très rapidement vous vous retrouvez dans une situation où la construction reste cassée tout le temps.
Always Run All Commit Tests Locally Before Committing- Assurez-vous toujours que les tests conçus pour l'application sont d'abord exécutés sur une machine locale avant de les exécuter sur le serveur CI. Ceci permet de garantir que les bons cas de test sont écrits et s'il y a un échec dans le processus CI, c'est en raison des résultats de test ratés.
Take Responsibility for All Breakages that Result from Your Changes- Si vous validez un changement et que tous les tests que vous avez écrits réussissent, mais que d'autres échouent, la compilation est toujours interrompue. Cela signifie généralement que vous avez introduit un bogue de régression dans l'application. Il est de votre responsabilité - parce que vous avez effectué la modification - de corriger tous les tests qui ne réussissent pas suite à vos modifications. Dans le contexte de l'IC, cela semble évident, mais en réalité ce n'est pas une pratique courante dans de nombreux projets.