Le principe DRY : trouver l’équilibre délicat entre réutilisation et clarté du code

· Imen Ezzine · Temps de lecture: 3 minutes
Lego

Cet article étudie le principe DRY (Don't Repeat Yourself) et son impact sur la qualité du code. Tout en soulignant son importance pour éviter les répétitions et faciliter la maintenance, il met en évidence les risques d'une application excessive de ce principe, qui peut nuire à la clarté et à l'évolution du projet. L'objectif est de trouver un juste équilibre entre réutilisation et simplicité.

Dans cet article, nous explorons le principe DRY (Don’t Repeat Yourself) et son impact sur la qualité du code. Bien qu’essentiel pour éviter les redondances et faciliter la maintenance, son application excessive peut parfois compliquer la compréhension et l’évolution du projet. Découvrons ensemble comment trouver le juste équilibre entre réutilisation et clarté.


Le principe DRY : une arme à double tranchant

Récemment, nous avons apporté les dernières touches à la version initiale de notre projet actuel, qui sera bientôt lancé en production. Avec l’évolution de la complexité de notre code due à la nature du projet, nous nous attachons à le rendre plus simple et plus épuré. En mettant en œuvre des bonnes pratiques telles que le principe DRY (Don’t Repeat Yourself) pour éviter les redondances, nous visons à maintenir une haute qualité.
Cela me conduit à discuter d’un principe que je considère comme étant à double tranchant, et qu’il convient d’utiliser judicieusement tout en restant pragmatique.

Pourquoi appliquer le principe DRY ?

Le principe DRY «Don’t Repeat Yourself», est une philosophie de développement logiciel visant à minimiser la redondance dans le code source. Bien que cette approche soit largement saluée pour son efficacité dans la gestion de la complexité du code, il est essentiel de comprendre comment son application rigide peut parfois créer des confusions.

L’objectif principal du DRY est d’encourager la réutilisation du code, ce qui permet de réduire les erreurs potentielles et d’améliorer la maintenance. En évitant de dupliquer des morceaux de code, les développeurs peuvent centraliser la logique métier, facilitant ainsi les mises à jour et les corrections.

Exemple :

Prenons un cas où nous avons deux entités dans une application Symfony : User et Admin. Ces deux entités partagent des propriétés communes, comme firstname, lastname, et email. Toutefois, sans normalisation, nous dupliquerions ces propriétés dans chaque entité, ce qui enfreint le principe DRY. Voici un exemple de ce que cela donnerait sans normalisation :

// src/Entity/User.php

namespace App\Entity;

class User
{
    private string $firstname;
    private string $lastname;
    private string $email;
    private string $job;
}
// src/Entity/Admin.php

namespace App\Entity;

class Admin
{
    private string $firstname;
    private string $lastname;
    private string $email;
    private array $roles;
}

Dans ce cas, l’inspecteur de PhpStorm ou PHP Mess Detector signalerait une duplication des propriétés firstname, lastname, et email dans les deux entités. Une suggestion classique serait d'utiliser l'héritage pour centraliser ces propriétés dans une classe parent, Account, afin d'éliminer la duplication :

//src/Entity/Account.php

namespace App\Entity;

abstract class Account
{
    private string $firstname;
    private string $lastname;
    private string $email;
}

Ensuite, nous faisons hériter User et Admin de cette classe Account, tout en ajoutant les propriétés spécifiques à chacune de ces entités :

//src/Entity/User.php

namespace App\Entity;

class User extends Account
{
    private string $job;
}
//src/Entity/Admin.php

namespace App\Entity;

class Admin extends Account
{
    private array $roles;
}

Cette approche centralise les propriétés partagées dans une classe de base. Elle améliore la lisibilité et réduit les risques d’erreurs liés à la duplication. Cependant, il est important de garder à l’esprit que cette solution ne doit pas systématiquement être couplée à une intégration ORM comme Doctrine. Parfois, travailler directement avec un modèle objet pur est plus adapté pour garder le code indépendant de tout framework. Si l’utilisation de Doctrine devient nécessaire par la suite, vous pourrez toujours mapper ces modèles avec des outils comme MappedSuperclass ou SingleTableInheritance.

Quand l’abstraction devient excessive

Cependant, cette quête de réduction de la redondance peut parfois conduire à des abstractions excessives. Lorsque les développeurs cherchent à généraliser trop rapidement, le code devient plus difficile à comprendre pour ceux qui ne sont pas familiers avec les détails spécifiques du projet. Les abstractions complexes peuvent créer des couches d’indirection qui, au lieu de clarifier le code, introduisent des niveaux supplémentaires de confusion.

Un autre aspect à considérer est que la persistance à suivre strictement le principe DRY peut conduire à des structures de code génériques qui ne sont pas optimales pour chaque cas particulier. Par exemple, lorsqu’on factorise une propriété comme un identifiant unique (ID) pour différentes entités, on peut constater que les règles associées varient en fonction du contexte métier. Prenons le cas d’un système où les utilisateurs ont des IDs numériques simples, tandis que les clients nécessitent des IDs avec un préfixe régional (par exemple, EU-12345). Dans ce cas, vouloir centraliser la gestion des IDs peut complexifier le code avec des conditions supplémentaires. Parfois, la duplication intentionnelle de certaines parties du code, adaptée à chaque entité, peut améliorer la lisibilité et la maintenance, surtout lorsque des variations spécifiques sont susceptibles d’apparaître à l'avenir.

DRY dans le contexte des architectures modernes

Dans les architectures modernes, notamment avec les microservices et les stratégies Polyrepo, il est parfois encouragé de faire du copier-coller entre des services isolés. Chaque service étant autonome et indépendant, une duplication modérée du code entre les différents services peut permettre une meilleure gestion des modifications locales et faciliter le déploiement sans impacter d’autres parties du système.

Trouver le bon équilibre entre la réutilisation du code et la clarté est un défi constant pour les développeurs. Il est important de reconnaître que le DRY est une directive, pas une règle absolue. Des compromis peuvent être nécessaires pour maintenir un code lisible et compréhensible tout en bénéficiant des avantages de la réutilisation.

Conclusion

En conclusion, bien que le principe DRY soit un guide précieux pour améliorer la qualité du code, son application rigide peut parfois créer des confusions. Dans le contexte des architectures complexes comme les microservices, les développeurs peuvent même être encouragés à dupliquer du code pour garantir l’indépendance des services. L’important est de rester conscient du contexte du projet et de trouver un équilibre optimal entre la réutilisation, la lisibilité et la maintenance du code.

Vous cherchez à appliquer le principe DRY sans compromettre la lisibilité et la maintenabilité de votre code ?

Les experts Symfony et PHP de SensioLabs vous accompagnent pour structurer vos projets de manière efficace. Par exemple, grâce à la factorisation intelligente du code, aux bonnes pratiques de développement et à de l'architecture évolutive.

Cela pourrait aussi vous intéresser

Chart going up
Silas Joisten Nouveau

Les bonnes raisons de tester votre application, expliqué à votre manager

Découvrez pourquoi les tests représentent un investissement stratégique et non un coût. Cet article explique à votre manager la valeur métier des tests, pourquoi ils sont essentiels pour le ROI, comment ils réduisent vos risques et améliorent votre agilité. Des explications claires, chiffres et cas concrets à l'appui.

En savoir plus
Code happy in lights
Imen Ezzine

La Revue de Code : Types, Organisation et Bonnes Pratiques

La Revue de Code (ou code review) est une étape essentielle du cycle de développement logiciel, permettant d’améliorer la qualité du code, de réduire les bugs et d’encourager le partage des connaissances au sein de l’équipe. GitLab et GitHub, deux des plateformes de gestion de code les plus populaires, offrent des fonctionnalités avancées pour faciliter ce processus. Cet article aborde les différents types de revues de code, comment s’organiser, et comment tirer partie des templates et check-lists pour améliorer l’efficacité des PR (Pull Requests).

En savoir plus
Many Lego figurines on a white table with hands playing with them
Alexandre Nesson

Scrum Guide Expansion Pack (2025) Ce qu'il faut savoir

Une nouvelle brique est venue enrichir le Scrum Guide ! Alors, poudre aux yeux ou réelle plus value ? Découvrons le ensemble dans cet article rédigé par l’un de nos experts.

En savoir plus
The SensioLabs team celebrating the 20th anniversary of Symfony with balloons
Jules Daunay

L'histoire continue : SensioLabs célèbre les 20 ans de Symfony

Le temps passe vite, surtout quand on écrit le futur du développement ! L’équipe de SensioLabs vient de souffler les 20 bougies du framework Symfony. Nous avons marqué le coup au bureau, mais la fête n'est pas terminée. Le rendez-vous est déjà pris pour une célébration XXL à SymfonyCon Amsterdam 2025 les 27 au 28 novembre.

En savoir plus
PHP 8.5 URI extension
Oskar Stark

La nouvelle extension URI de PHP 8.5 : Une révolution pour l'analyse des URL

PHP 8.5 introduit une nouvelle extension URI puissante qui modernise la gestion des URL. Grâce au support des standards RFC 3986 et WHATWG, la nouvelle classe Uri fournit des objets immuables, des interfaces fluides et une validation appropriée, résolvant ainsi toutes les limites de la fonction historique parse_url(). Cet articl présente des exemples pratiques avant/après et explique quand utiliser chaque standard.

En savoir plus
Open in new tab
Silas Joisten

Le piège des onglets: pourquoi forcer l'ouverture de nouveaux onglets est une mauvaise pratique en UX

Nous l'avons tous fait — ajouter target="_blank" à un lien pour « aider les utilisateurs » à rester sur notre site. Mais ce qui semble être une commodité inoffensive crée souvent de la confusion, diminue l'accessibilité et introduit des risques de sécurité cachés.

En savoir plus
3 dog heads
Mathieu Santostefano

Venez avec votre propre client HTTP

Libérez-vous des dépendances rigides de vos SDK PHP. Dans cet article, apprenez à utiliser les normes PSR-7, PSR-17 et PSR-18, ainsi que la bibliothèque php-http/discovery, pour permettre à vos utilisateurs d'utiliser le client HTTP de leur choix, qu'il s'agisse de Guzzle, de Symfony HttpClient ou d'un autre. Un incontournable pour les développeurs PHP et Symfony.

En savoir plus
Vegetables on a wooden board with a knife with a pan on top
Rémi Brière

L'Agilité en entreprise - 2. Pourquoi Scrum échoue (et comment y remédier)

Scrum est souvent perçu comme le cadre évident pour structurer et dynamiser le développement d’un produit, particulièrement numérique. Pourtant, son adoption ne garantit pas systématiquement le succès. Mais que permet réellement Scrum ? Plus important encore, quelles sont les conditions nécessaires à son efficacité et surtout les écueils à éviter pour en faire un véritable atout ?

En savoir plus
Blue sign on a building with several Now What? letters
Thibaut Chieux

Comment prioriser les messages lors du développement d'applications asynchrones avec Symfony Messenger

Le traitement asynchrone offre des avantages tels que la découplage des processus et des temps de réponse plus rapides, mais la gestion des priorités des messages peut s'avérer complexe. Pour traiter des tâches allant de la réinitialisation de mot de passe à des exports complexes, il est essentiel de garantir la livraison rapide des messages critiques. Cet article examine les problèmes fréquents liés au traitement asynchrone et propose des solutions avec Symfony Messenger pour optimiser votre application sans refonte majeure.

En savoir plus
SensioLabs University Courses Annonce La nouvelle formation Master de niveau 3 est disponible sur un fond vert
Jules Daunay

Master Symfony : Devenez un expert de Symfony avec notre nouvelle formation

Améliorez votre maîtrise de Symfony grâce à la nouvelle formation Master de niveau 3 sur Symfony ! Maîtrisez les sujets les plus complexes du framework et développez des compétences approfondies.

En savoir plus
PHP 8.5
Oskar Stark

Quoi de neuf dans PHP 8.5 ? Un aperçu complet

PHP 8.5 sort en novembre 2025 et apporte plusieurs nouvelles fonctionnalités utiles et des améliorations. Cette nouvelle version se concentre sur l'amélioration de l'expérience développeur, de nouvelles fonctions utilitaires et de meilleures capacités de débogage.

En savoir plus
Two images: on the left many cars stuck in a traffic jam with the sign "All directions" above, on the right a blue car moving forward alone on the highway with the sign "Service Subscriber" and a Symfony logo above
Steven Renaux

Les Lazy Services de Symfony : Boostez votre DX en utilisant les Service Subscribers

Optimisez la performance de votre application Symfony et l'expérience développeur ! Apprenez à utiliser les Service Subscribers et les attributs de chargement différé des services afin de réduire l'instanciation rapide, de simplifier les dépendances et de créer un code modulaire et maintenable.

En savoir plus
the surface of the earth seen from the space with city lights forming networks
Imen Ezzine

Les verbes HTTP : votre Guide Complet

Apprenez les bases des verbes HTTP : GET, POST, PUT, DELETE, et plus encore. Cet article vous explique leur fonctionnement, leurs utilisations et les conséquences en matière de sécurité.

En savoir plus
Affiche sur l'interview de Guillaume Loulier
Salsabile El-Khatouri

Dans les coulisses d’une formation SensioLabs

À quoi ressemble une formation Symfony donnée par SensioLabs ? Découvrez-le dans cette interview avec Guillaume Loulier, développeur & formateur passionné, qui nous explique tout sur le fonctionnement des formations officielles sur le framework.

En savoir plus
AI and Symfony
Silas Joisten

Créez des fonctionnalités basées sur l’IA dans Symfony

L’IA transforme le développement web — et avec php-llm/llm-chain, les développeurs PHP peuvent facilement intégrer des fonctionnalités LLM puissantes dans leurs applications Symfony. Cet article vous montre comment démarrer grâce à des chatbots, des assistants intelligents, et plus encore.

En savoir plus
Image