Skip to main content

Extensibilité des applications

Une excellente session par Yann Schwartz, Architecte technique chez Polom et Sébastien Ros, Chief Software Architect chez Evaluant.

Introduction

PIC_0197 Il s'agit de savoir prendre en charge la complexité liée à la gestion d'un système constitué de nombreux morceaux.

Le problème: nos applications sont constituées de nombreuses parties, reposent sur des services locaux ou distants, dépendent d'assemblages tiers (bibliothèques, par exemple pour le traçage), sont exécutées dans différents contextes (notamment de sécurité). Elles sont donc faciles à construire mais difficiles à démêler.

On veut notamment: tester sans dépendances, gérer le cycle de vie des composants, et distinguer les besoins techniques des besoins métier.

Avec un peu de bon sens, on peut imaginer:

  • séparer contrat et implémentation, pour que les deux parties ne se connaissent pas
  • utiliser des factories, car c'est une mauvais idée que chaque composant fasse comme s'il était seul au monde. On ne fait pas de new directement. C'est le "new new".

Mais il reste un problème, même avec les factories: c'est toujours le composant qui décide quand instancier. Avec l'inversion de contrôle, on définit les interfaces et leurs dépendances, et le système s'occupe de l'instanciation.

Tant qu'à faire, on va aussi généraliser la notion de factories en: enregistrant les dépendances, les résolvant en cascade.

Les frameworks d'IoC sont entre-autres:

  • Spring.NET (le plus ancien, venant de Java)
  • Castle Windsor
  • NInject
  • Unity

Unity

Notion de conteneur: c'est lui qui s'occupe de tout. Il est la source unique d'instances. On s'enregistre auprès de lui, et c'est lui ui résoud les demandes de contrats avec au choix:

  • Service Locator: c'est l'équivalent des factories, il est un peu tombé en désuettude.
  • Injection de dépendance (constructeur ou propriétés).

Le conteneur ajoute quelques notions sympa: singleton/instance, implémentations multiples, interception (par exemple pour ajouter du log, du cache, ...).

On peut écrire la configuration en XML, mais on préfère maintenant plutôt le code vu que ce sont des paramètres peu modifiés.

En Unity, on instancie le Container, et on appelle sa méthode RegisterType ou RegisterInstance (singleton) en lui passant interface et classe. On appelle ensuite sa méthode Resolve pour récupérer un objet sur lequel on peut travailler.

Pour les tests unitaires, cela nous simplifie aussi énormément la vie. Car d'habitude on rencontre un problème dès que nos composants utilisent des ressources telles que le réseau, la base de données, ... Avec l'IoC, c'est très simple: l suffit d'injecter des implémentations vides. On a même des frameworks pour éviter d'écrire les implémentations vides (exemple: Rhino.Mocks).

On a ainsi découplé les composants. Mais il reste à gérer l'interaction entre l'application et le monde extérieur. C'est là que MEF arrive.

MEF, Microsoft Extensibility Framework

PIC_0198 C'est le moteur d'extensibilité pour ASP.NET 4.0, Visual Studio 2010, Oslo.

Principe: on utilise les attributs [Import] et [Export] pour mettre en relation fournisseur et consommateur d'interface (c'est de l'IoC). MEF assure la mise en relation, donc le découplage.

Note: on peut exporter des classes entières, mais aussi de simples méthodes sous la forme de délégués.

Pour aller plus loin, on peut trouver des Parts (composants) dynamiquement. Grâce à la classe DirectoryCatalog, on peut même décuvrir les composants dans un répertoire.

Les composants sont paritaires: une Part peut déclarer des Import et des Export.

Conclusion

MEF est simple (utilisation d'attributs), open source, disponible.

Unity a son utilité: MEF permet de découvrir les composants, alors qu'Unity sert à travailler sur un ensemble connu de composants.

Comments

Popular posts from this blog

Gift idea : help your loved ones take their IT skills to the next level

You surely know a special person who works in IT. Learn Kubernetes & Docker enables them to quickly ramp up on those two technologies that one doesn't want to miss in 2021. With smoother operations, better scaling and availability, DevOps tooling, containers and containers orchestration smartly solve many problems that developers and system administrators commonly face. Don't let your loved ones face problems in their IT job : offer them the book that takes them from zero to productive in a matter of days. Grab it now! Get the ebook from Leanpub , Amazon or choose from many retailers . Get the print edition from Lulu .  

Learn Meteor book available

I'm pleased to announce the general release of my Learn Meteor book. It is now available as an ebook or print book from various sources: Learn Meteor print (paperback) on Lulu Learn Meteor ebook on LeanPub Learn Meteor ebook on Barnes & Noble Learn Meteor ebook on iBooks Learn Meteor ebook on Kobo Learn Meteor ebook on Scribd Learn Meteor ebook on Inktera Page Foundry Learn Meteor ebook on 24symbols Learn Meteor ebook on Amazon US Learn Meteor ebook on Amazon UK Learn Meteor ebook on Amazon France Learn Meteor ebook on Amazon Deutschland Learn Meteor ebook on Amazon Canada Learn Meteor ebook on Amazon India Learn Meteor ebook on Amazon Brasil Learn Meteor ebook on Amazon Mexico Learn Meteor ebook on Amazon España Learn Meteor ebook on Amazon Italia Learn Meteor ebook on Amazon Netherlands Learn Meteor ebook on Amazon Japan Learn Meteor ebook on Amazon Australia More sources are coming soon for the print version. Learn Meteor has been a fun expe...

TechDays 2010 Paris live

Vous ne pouvez pas ou n’avez pas pu vous rendre aux TechDays? Pas de panique, voici comment ne rien rater. Les pleinières (comprendre, la grande conférence du matin) seront retransmises en direct ici . Vous retrouverez chaque soir mon compte-rendu écrit sur mon blog . Pourquoi un compte-rendu écrit? C’est du boulot pour moi, mais je sais que c’est plus facile de se retrouver dans du texte que dans une vidéo. Ca permet aussi de lire vite en diagonale. Alors je vais sortir mes petits doigts et tout noter, comme je l’ai fait pour les événements précédents: Les TechDays 2009 Le TechEd Europe 2008 à Barcelone Le ReMix 08 de Paris Les TechDays 2008 (ou l’un des premiers netbooks m’a aidé) Le TechEd Europe 2007 à Barcelone Le Mix07 de Paris Rendez-vous donc sur ce blog à partir de demain. Et sur Twitter pour mes impressions en direct .