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é.

508 comments

  • cedeFamn
    cedeFamn, 13 February, 2018 06:02 Comment Link

    cialis 20mg tablets cialis
    buy cheap cialis
    buy cialis in mexico cialis
    buy cialis
    1 a day cialis 20mg

  • joyncjiz
    joyncjiz, 13 February, 2018 06:02 Comment Link

    cialis
    buy generic cialis
    buy tadalafil india cipla
    cheap cialis online
    experiences cialis 20mg

  • entilt
    entilt, 13 February, 2018 06:02 Comment Link

    cialis on
    cialis cheap
    cheap cialis
    buy cheap cialis online
    tadalafil api cialis pills

  • Appeabs
    Appeabs, 13 February, 2018 05:02 Comment Link

    viagra half dose cialis pills
    buy cheap cialis
    viagra shipped overnight cialis generic
    generic cialis
    next day cialis generic

  • Kixoxync
    Kixoxync, 13 February, 2018 04:02 Comment Link

    us cialis generic
    cialis
    spam viagra cialis generic levitra
    buy cialis online
    viagra rap buy cialis online

  • mouchTug
    mouchTug, 13 February, 2018 04:02 Comment Link

    buy generic cialis online no prescription
    generic cialis online
    walgreens cialis online pharmacy
    online cialis
    yahoo cialis online pharmacy

  • Criliakb
    Criliakb, 13 February, 2018 12:02 Comment Link

    cheap cialis
    viagra v levitra cialis pills cialis a
    http://cialiskntrc.com
    cheapest generic cialis online
    buy cheap cialis coupon

  • Steagsb
    Steagsb, 12 February, 2018 11:02 Comment Link

    buy cheap cialis coupon
    women cialis generic
    http://cialiskntrc.com
    viagra dropship cialis generic
    buy cheap cialis online

  • Advipleb
    Advipleb, 12 February, 2018 11:02 Comment Link

    cheap cialis online
    viagra par internet cialis 20mg
    http://cialiskntrc.com
    order cialis online without otc
    cialis

  • indigob
    indigob, 12 February, 2018 08:02 Comment Link

    buy cialis online
    viagra natural femenina cialis generic
    http://cialiskntrc.com
    cialis discount online
    cheap cialis online

Leave a comment

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