Kad Dembele

L'artisanat du logiciel

Dans mon billet précédent, je vous ai parlé de l'architecture logicielle et principalement des principes de base de la conception logicielle. Et nous avons vu que les deux indicateurs de qualité logicielle, les plus importants(La facilité d'utilisation et la maintenabilité) étaient les plus négligés car la plus part des architectes se limitent à la livraison de logiciels fonctionnels (Get It Done).

Et c'est tout là, la différence entre un industriel qui se contente de produire à la chaîne de manière répétitive des produits basés sur un modèle et un artisan qui use de son savoir faire pour créer des œuvres artistiques (Architecture des bâtiments, ..., Architecture des logiciels) et de ses fonctions cognitives pour s'améliorer au fil du temps. D'où le mouvement software craftsmanship.

Un artisan du logiciel est avant tout celui qui conçoit bien son logiciel, dans le sens de l'architecture logicielle bien sûr (Get it Right). D'où les quatre valeurs prônées par l'artisanat du logiciel

  • Pas seulement des logiciels opérationnels,
    • mais aussi des logiciels bien conçus.
  • Pas seulement l'adaptation aux changements,
    • mais aussi l'ajout constant de la valeur.
  • Pas seulement les individus et leurs interactions,
    • mais aussi une communauté de professionnels.
  • Pas seulement la collaboration avec les clients,
    • mais aussi des partenariats productifs.

De ces valeurs que tout aspirant Artisan du logiciel doit respecter, Il ressort clairement l'envie de bien faire les choses, d'améliorer de façon constante, de partager le savoir faire et d’intégrer le client au cycle de vie du logiciel.

J'ai eu à lire sur de nombreux blogs des personnes qui disent qu'une entreprise a besoin d'industrialiser ses processus pour pouvoir produire et qu'un artisan n'a pas sa place au sein d'une entreprise, ces personnes ont entièrement raison, sauf que le but d'un artisan logiciel n'est pas de transformer une entreprise industrielle en entreprise artisanale mais plutôt de concevoir des logiciels dignes des plus grandes œuvres artistiques en:

  • Affectant au mieux les responsabilités dans le code (Principe de responsabilité unique)
  • Rendant le code le plus extensible possible (Principe d'ouverture/fermeture)
  • Permettant aux objets de la même famille de se substituer mutuellement (Principe de substitution de Liskov)
  • Limitant l'accès aux objets à des méthodes dont ils n'ont pas besoin (Principe de ségrégation des interfaces)
  • Assurant que les dépendances entre les différents modules soient gérées par abstraction (Principe d'inversion des dépendances)

Ces différents principes (SOLID) énoncés par Uncle Bob visent à simplifier les techniques de conception logicielle et à rendre les logiciels conçus maintenables, évolutifs et compréhensibles.

Pour revenir sur l'industrialisation des processus de travail, il est évident que la deuxième valeur du manifeste de l'artisanat du logiciel qui vise à créer constamment de la valeur ajoutée passe par la mise en place des processus d'automatisation des phases de test et de déploiement de l’œuvre créée (logiciel) mais n'équivaut en aucun cas à industrialiser la phase de conception elle même.

Pour conclure, je dirai que l'artisanat du logiciel est l'art de bien concevoir des logiciels (Get It Right) grâce à un savoir faire et un apprentissage continuel et peut être / doit être considérer comme un complément technique à l'agilité.

733 comments

  • arrancy
    arrancy, 2 April, 2018 11:04 Comment Link

    viagra gel
    cheap viagra
    viagra ejaculation
    buy generic viagra

  • Uploasy
    Uploasy, 1 April, 2018 11:04 Comment Link

    l-citrulline viagra
    generic viagra
    where can i buy viagra
    generic viagra online

  • Obeply
    Obeply, 1 April, 2018 07:04 Comment Link

    viagra commercial women
    cheap viagra online
    difference between cialis and viagra
    generic viagra online

  • cropsy
    cropsy, 1 April, 2018 06:04 Comment Link

    sell cialis generic
    buy cialis online
    cialis online canada no prescription
    buy cialis online

  • Wommold
    Wommold, 1 April, 2018 03:04 Comment Link

    donde puedo comprar viagra
    buy generic viagra
    viagra 3 days in a row
    buy viagra

  • cropsy
    cropsy, 1 April, 2018 11:04 Comment Link

    prednisone crush cialis generic pills
    buy cialis
    buy cialis online india
    buy cheap cialis online

  • Uploasy
    Uploasy, 1 April, 2018 09:04 Comment Link

    viagra warning label
    buy generic viagra
    plant viagra 6800mg
    buy viagra

  • stuctSes
    stuctSes, 1 April, 2018 08:04 Comment Link

    text payday loans
    payday loans online
    need loan bad credit
    payday loans

  • Vulknubs
    Vulknubs, 1 April, 2018 03:04 Comment Link

    cheap generic cialis tadalafil
    cheap cialis
    generic cialis ship to canada
    buy generic cialis

  • Geogpemi
    Geogpemi, 31 March, 2018 07:03 Comment Link

    cheap buy generic cialis online
    buy cialis online
    buy tadalafil online
    cialis

Leave a comment

Make sure you enter the (*) required information where indicated. HTML code is not allowed.