Méthodologie de développement logiciel agile vs traditionnelle
Il existe aujourd'hui un certain nombre de méthodologies de développement de logiciels différentes utilisées dans l'industrie du logiciel. La méthode de développement en cascade est l'une des premières méthodes de développement de logiciels. V-Model, RUP et quelques autres méthodes linéaires, itératives et combinées linéaires-itératives, qui sont venues après la méthodologie de la cascade, destinées à éliminer de nombreux problèmes de la méthode de la cascade. Toutes ces méthodologies antérieures sont appelées méthodologies traditionnelles de développement de logiciels. Le modèle Agile est un modèle de développement logiciel plus récent introduit pour combler les lacunes des modèles traditionnels. L'objectif principal d'Agile est d'incorporer les tests le plus tôt possible et de publier une version fonctionnelle du produit très tôt, en décomposant le système en sous-parties très petites et gérables.
Qu'est-ce que la méthodologie traditionnelle de développement de logiciels?
Les méthodologies logicielles telles que la méthode Waterfall, le V-Model et le RUP sont appelées méthodologies de développement logiciel traditionnelles. La méthodologie Waterfall est l'un des premiers modèles de développement logiciel. Comme son nom l'indique, il s'agit d'un processus séquentiel dans lequel la progression passe par plusieurs phases (analyse des besoins, conception, développement, test et mise en œuvre) de haut en bas, comme une cascade. V-Model est considéré comme une extension du modèle de développement logiciel Waterfall. V-Model utilise les mêmes relations entre les phases définies dans le modèle Waterfall. Mais au lieu de descendre linéairement (comme le modèle Waterfall), le V-Model descend en diagonale puis remonte (après la phase de codage), formant la forme de la lettre V. RUP (Rational Unified Process) est un cadre de processus adaptable (pas un seul procédé concret),qui peuvent être personnalisés par l'organisation de développement en fonction de ses besoins. Légèrement similaire à la cascade, il a des phases fixes comme la conception, l'élaboration, la construction et la transition. Mais contrairement à la cascade, RUP est un processus itératif.
Qu'est-ce que Agile?
Agile est une méthodologie de développement logiciel très récente (ou plus exactement, un groupe de méthodologies) basée sur le manifeste agile. Ceci a été développé pour résoudre certaines lacunes des méthodologies traditionnelles de développement de logiciels. Les méthodes agiles sont basées sur une priorité élevée à la participation du client au début du cycle de développement. Il recommande d'intégrer les tests par le client le plus tôt possible et le plus souvent possible. Les tests sont effectués à chaque étape lorsqu'une version stable devient disponible. La base d'Agile est basée sur le démarrage des tests depuis le début du projet et sur la poursuite jusqu'à la fin du projet. La programmation Scrum et Extreme sont deux des variantes les plus populaires des méthodes Agile.
La valeur clé d'Agile est «la qualité est la responsabilité de l'équipe», qui souligne que la qualité du logiciel est la responsabilité de toute l'équipe (pas seulement de l'équipe de test). Un autre aspect important d'Agile est de décomposer le logiciel en plus petites parties gérables et de les livrer au client très rapidement. Fournir un produit fonctionnel est de la plus haute importance. Ensuite, l'équipe continue d'améliorer le logiciel et de livrer en continu à chaque étape majeure. Ceci est réalisé en ayant des cycles de publication très courts (appelés sprints dans Scrum) et en obtenant des commentaires d'amélioration à la fin de chaque cycle. Les contributeurs sans trop d'interactions de l'équipe, tels que les développeurs et les testeurs dans les méthodes précédentes, travaillent désormais ensemble au sein du modèle Agile.
Quelle est la différence entre la méthodologie de développement logiciel agile et traditionnelle?
Bien que la méthode Agile soit basée sur le développement itératif comme certaines des approches traditionnelles, les méthodologies Agile et Traditionnelle présentent des différences clés. Les approches traditionnelles utilisent la planification comme mécanisme de contrôle, tandis que les modèles Agile utilisent les commentaires des utilisateurs comme mécanisme de contrôle principal. Agile peut être appelé une approche centrée sur les personnes que les méthodes traditionnelles. Le modèle Agile fournit une version fonctionnelle du produit très tôt par rapport aux méthodologies traditionnelles afin que le client puisse réaliser rapidement certains des avantages. Le temps de cycle de test d'Agile est relativement court par rapport aux méthodes traditionnelles, car les tests sont effectués parallèlement au développement. La plupart des modèles traditionnels sont très rigides et relativement moins flexibles que le modèle Agile. En raison de tous ces avantages, Agile est préféré aux méthodologies traditionnelles du moment.