Intégration continue - Réduire les risques

Il y a des chances que les choses tournent mal sur un projet. En pratiquant efficacement l'EC, vous découvrez ce qui se passe à chaque étape du processus, plutôt que plus tard lorsque le projet est dans le cycle de développement. L'IC vous aide à identifier et à atténuer les risques lorsqu'ils surviennent, ce qui facilite l'évaluation et le rapport sur la santé du projet sur la base de preuves concrètes.

Cette section va se concentrer sur les risques qui peuvent être évités en utilisant l'intégration continue.

Sur tout projet, de nombreux risques doivent être gérés. En éliminant les risques plus tôt dans le cycle de vie du développement, il y a moins de chances que ces risques se transforment en problèmes plus tard, lorsque le système entre réellement en service.

Risque 1 - Manque de logiciels déployables

“It works on my machine but does not work on another”- C'est probablement l'une des expressions les plus courantes rencontrées dans toute organisation logicielle. En raison du nombre de modifications apportées quotidiennement aux versions logicielles, il y a parfois peu de certitude quant à savoir si la construction du logiciel fonctionne réellement ou non. Cette préoccupation a les trois effets secondaires suivants.

  • Peu ou pas de confiance quant à la possibilité de créer le logiciel.

  • Longues phases d'intégration avant de livrer le logiciel en interne (c'est-à-dire, l'équipe de test) ou en externe (c'est-à-dire le client), pendant lesquelles rien d'autre n'est fait.

  • Incapacité à produire et reproduire des versions testables.

Solution

Élimination du couplage étroit entre l'EDI et les processus de construction. Utilisez une machine distincte uniquement pour intégrer le logiciel. Assurez-vous que tout ce dont vous avez besoin pour créer le logiciel est contenu dans le référentiel de contrôle de version. Enfin, créez un système d'intégration continue.

Le serveur d'intégration continue peut surveiller les modifications dans le référentiel de contrôle de version et exécuter le script de génération de projet lorsqu'il détecte une modification dans le référentiel. La capacité du système d'intégration continue peut être augmentée pour inclure l'exécution de tests, la réalisation d'inspections et le déploiement du logiciel dans les environnements de développement et de test; de cette façon, vous disposez toujours d'un logiciel fonctionnel.

“Inability to synchronize with the database”- Parfois, les développeurs sont incapables de recréer la base de données rapidement pendant le développement et ont donc du mal à apporter des modifications. Cela est souvent dû à une séparation entre l'équipe de base de données et l'équipe de développement. Chaque équipe sera concentrée sur ses propres responsabilités et aura peu de collaboration entre elles. Cette préoccupation a les trois effets secondaires suivants -

  • Peur de faire des changements ou de refactoriser la base de données ou le code source.

  • Difficulté à remplir la base de données avec différents ensembles de données de test.

  • Difficulté à maintenir les environnements de développement et de test (par exemple, développement, intégration, assurance qualité et test).

Solution

La solution au problème ci-dessus consiste à garantir que le placement de tous les artefacts de base de données dans le référentiel de contrôle de version est effectué. Cela signifie que tout ce qui est nécessaire pour recréer le schéma et les données de la base de données: des scripts de création de base de données, des scripts de manipulation de données, des procédures stockées, des déclencheurs et tout autre élément de base de données sont nécessaires.

Reconstruisez la base de données et les données à partir de votre script de construction, en supprimant et en recréant votre base de données et vos tables. Ensuite, appliquez les procédures stockées et les déclencheurs, et enfin, insérez les données de test.

Testez (et inspectez) votre base de données. En règle générale, vous utiliserez les tests des composants pour tester la base de données et les données. Dans certains cas, vous devrez écrire des tests spécifiques à la base de données.

Risque 2 - Découverte des défauts tard dans le cycle de vie

Puisqu'il y a tellement de changements qui se produisent fréquemment par plusieurs développeurs au code source, il y a toujours des chances qu'un défaut puisse être introduit dans le code qui ne pourrait être détecté qu'à un stade ultérieur. Dans de tels cas, cela peut avoir un impact important car plus le défaut est détecté tardivement dans le logiciel, plus il devient coûteux de supprimer le défaut.

Solution

Regression Testing- C'est l'aspect le plus important de tout cycle de développement logiciel, test et test à nouveau. En cas de modification majeure du code logiciel, il est impératif de s'assurer que tous les tests sont exécutés. Et cela peut être automatisé à l'aide du serveur d'intégration continue.

Test Coverage- Il ne sert à rien de tester si les cas de test ne couvrent pas l'ensemble des fonctionnalités du code. Il est important de s'assurer que les cas de test créés pour tester l'application sont complets et que tous les chemins de code sont testés.

Par exemple, si vous avez un écran de connexion qui doit être testé, vous ne pouvez tout simplement pas avoir un scénario de test avec le scénario d'une connexion réussie. Vous devez avoir un cas de test négatif dans lequel un utilisateur entre une combinaison différente de noms d'utilisateur et de mots de passe, puis il est nécessaire de voir ce qui se passe dans de tels scénarios.

Risque 3 - Manque de visibilité du projet

Les mécanismes de communication manuels nécessitent beaucoup de coordination pour assurer la diffusion des informations sur le projet aux bonnes personnes en temps opportun. Se pencher vers le développeur à côté de vous et lui faire savoir que la dernière version est sur le disque partagé est plutôt efficace, mais il ne s'adapte pas très bien.

Que faire s'il y a d'autres développeurs qui ont besoin de ces informations et qu'ils sont en pause ou indisponibles? Si un serveur tombe en panne, comment êtes-vous averti? Certains pensent pouvoir atténuer ce risque en envoyant manuellement un e-mail. Cependant, cela ne peut garantir que les informations sont communiquées aux bonnes personnes au bon moment, car vous pouvez accidentellement omettre les parties intéressées, et certaines peuvent ne pas avoir accès à leur courrier électronique à ce moment-là.

Solution

La solution à ce problème est à nouveau le serveur d'intégration continue. Tous les serveurs CI ont la possibilité de déclencher des e-mails automatisés chaque fois que les builds échouent. Par cette notification automatique à toutes les parties prenantes clés, il est également assuré que tout le monde est à bord sur l'état actuel du logiciel.

Risque 4 - Logiciel de faible qualité

Il y a des défauts, puis des défauts potentiels. Vous pouvez avoir des défauts potentiels lorsque votre logiciel n'est pas bien conçu ou s'il ne respecte pas les normes du projet, ou est complexe à maintenir. Parfois, les gens appellent cela des odeurs de code ou de conception - «un symptôme que quelque chose ne va pas».

Certains pensent qu'un logiciel de qualité inférieure est uniquement un coût de projet différé (après livraison). Il peut s'agir d'un coût de projet différé, mais cela entraîne également de nombreux autres problèmes avant de livrer le logiciel aux utilisateurs. Code trop complexe, code qui ne suit pas l'architecture et code dupliqué - tous conduisent généralement à des défauts dans le logiciel. Trouver ces odeurs de code et de conception avant qu'elles ne se transforment en défauts peut faire gagner du temps et de l'argent, et peut conduire à des logiciels de meilleure qualité.

Solution

Il existe des composants logiciels pour effectuer un contrôle de qualité du code qui peuvent être intégrés au logiciel CI. Cela peut être exécuté après la création du code pour garantir que le code est réellement conforme aux directives de codage appropriées.