<?xml version="1.0" encoding="utf-8"?><?xml-stylesheet title="XSL formatting" type="text/xsl" href="http://www.insideit.fr/feed/rss2/xslt" ?><rss version="2.0"
  xmlns:dc="http://purl.org/dc/elements/1.1/"
  xmlns:wfw="http://wellformedweb.org/CommentAPI/"
  xmlns:content="http://purl.org/rss/1.0/modules/content/"
  xmlns:atom="http://www.w3.org/2005/Atom">
<channel>
  <title>insideIT.fr : le blog des architectes IT de SFEIR</title>
  <link>http://www.insideit.fr/</link>
  <atom:link href="http://www.insideit.fr:82/feed/rss2" rel="self" type="application/rss+xml"/>
  <description></description>
  <language>fr</language>
  <pubDate>Mon, 30 Jan 2012 17:01:34 +0100</pubDate>
  <copyright></copyright>
  <docs>http://blogs.law.harvard.edu/tech/rss</docs>
  <generator>Dotclear</generator>
  
    
  <item>
    <title>Noël dans les nuages !</title>
    <link>http://www.insideit.fr/post/2012/01/30/No%C3%ABl-dans-les-nuages-%21</link>
    <guid isPermaLink="false">urn:md5:5bd6d22d2f29425a063eefd66b8c2e40</guid>
    <pubDate>Mon, 30 Jan 2012 15:57:00 +0100</pubDate>
    <dc:creator>Patrice</dc:creator>
        <category>Cloud</category>
        <category>app engine</category><category>eglise catholique</category><category>gae</category><category>gwt</category>    
    <description>    &lt;p&gt;&lt;em&gt;Ou comment Google App Engine, permet de mettre en place un service
supportant une très grosse charge dans un temps très court.&lt;/em&gt;&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;
&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Le projet&lt;/h2&gt;
&lt;p&gt;L'Église Catholique propose depuis plus de 10 ans un site internet pour
chercher les horaires de messes dans toute la France, qui souffrait
historiquement d'un problème majeur : le trafic quotidien est raisonnable
(environ 1 000 visites par jours, et des pointes à 5 000 visites le WE) mais le
site doit faire face à d’importants pics de trafic à Noël et durant la semaine
de Pâques.&lt;/p&gt;
&lt;p&gt;&lt;img src=&quot;http://www.insideit.fr/public/cef/.Tpl_EgliseInfo_v1_m.jpg&quot; alt=&quot;Interface d'EgliseInfo&quot; title=&quot;Interface d'EgliseInfo, janv. 2012&quot; /&gt;&lt;/p&gt;
&lt;p&gt;Or les années précédentes, l'ancien site (&lt;a href=&quot;http://messesinfo.catholique.fr&quot; hreflang=&quot;fr&quot;&gt;messesinfo.catholique.fr&lt;/a&gt;),
développé en PHP/MySQL, ne tenait pas la charge lors de ces pics, s'écroulant
sous les demandes des visiteurs. La technologie utilisée était tout à fait
suffisante pour les besoins courants du site, cependant pour répondre à la
forte charge sans changer de projet, il aurait fallu, soit disposer d’un
serveur plus puissant, soit mettre en place du load balancing entre plusieurs
serveurs. Dans les deux cas, ce n'aurait pas été très flexible, obligeant à
s’équiper d’un serveur sur-dimensionné, pour seulement 6 jours dans
l'année !&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;
&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Nouveau projet&lt;/h2&gt;
&lt;p&gt;Nous avons donc fait le choix de migrer vers une technologie permettant de
gérer cette surcharge ponctuelle, en ne payant que ce qui est réellement
consommé. La refonte du site, permet également d’outrepasser les limitations
imposées par l'ancien système (messes en semaine, autres types de célébrations)
et d'ajouter de nouvelles fonctionnalités (événements, apis, widget, …).&lt;/p&gt;
&lt;p&gt;Notre choix c'est porté sur Google App Engine, par la simplicité de
développement que celui-ci apporte, le dimensionnement automatique des
serveurs, les quotas gratuits et le paiement à la consommation.&lt;/p&gt;
&lt;p&gt;Le projet a démarré en octobre 2010, avec la création d'une simple interface
de recherche développé en GWT sur Google App Engine, mais laquelle se
connectait ensuite à l'ancien site pour récupérer les résultats de la
recherche. Cette première version à été mise en ligne pour Noël 2010, mais les
deux sites n'ont pas tenu le coup car la base de donnée n'a pas accepté le
nombre très élevé de requêtes simultanées ! Nous ne pouvions pas mettre
les données de la base de donnée MySQL directement sur Google App Engine, car
déjà l'interface d'administration n'est pas encore refaite, et la base de
donnée chez App Engine, ne fonctionne pas exactement de la même manière.&lt;/p&gt;
&lt;p&gt;Pour la période de Pâques 2011, Google venait de sortir en test la base de
donnée Google Cloud SQL qui permet d'avoir des bases de données MySQL
directement sur Google App Engine. Nous avons ainsi développé un service qui
recopie la base de l'ancien site, sur le nouveau. Le système a fonctionné, mais
du fait de la nouveauté du service et du manque d'optimisation de notre part,
les bases de données SQL ont régulièrement planté.&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;
&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Noël 2011&lt;/h2&gt;
&lt;p&gt;&lt;a href=&quot;http://www.insideit.fr/public/cef/Noel2012-Visiteurs.png&quot;&gt;&lt;img src=&quot;http://www.insideit.fr/public/cef/.Noel2012-Visiteurs_m.jpg&quot; alt=&quot;Visiteurs le jour de Noël 2011&quot; title=&quot;Visiteurs le jour de Noël 2011, janv. 2012&quot; /&gt;&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;EgliseInfo a relativement bien fonctionné pour Noël 2011, faisant face à une
pointe de 1104 visiteurs simultané, et plus de 800 visiteurs en permanence
durant toute l'après-midi, soit 100 000 visites en 3 jours.&lt;/p&gt;
&lt;p&gt;Nous avons toutefois rencontré trois problèmes :&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Vendredi soir vers 21h, nous avons dépassé le quota que nous avions fixé
(25$), donc tous le site s’est retrouvé bloqué, le temps de changer et de
mettre à 100$&lt;/li&gt;
&lt;li&gt;Samedi matin, nous avons été limité par Google Cloud SQL a 100 requêtes
simultanées. J'ai corrigé en faisait un balancing sur 2 bases SQL, et j'ai
écrit un mail à Google : réponse dans la fin de l'après midi, ils ne
peuvent pas modifier cette limite, et proposaient de passer à un serveur de
plus grande capacité sans être vraiment sûr que cela résoudrait le
problème : base de donnée plus grande, mais pas plus de connexion
simultanées (cela changera plus tard), avec par ailleurs une interruption le
temps de redémarrer le serveur. La double base de données a permis de réduire
le nombre d'erreurs et de fournir une meilleure réactivité. Les responsables de
Google SQL sont en train de tester avec notre jeu de données sur les requêtes
les plus lentes.&lt;/li&gt;
&lt;li&gt;Samedi 18h : EgliseInfo marchait toujours, mais les pubs ne
s'affichait plus (un script PHP sur un serveur de la CEF) car le trop grand
nombre de personnes sur tous les sites (le site de pub, messesinfo, les sites
de paroisses et diocèses) à surchargé le firewall du datacenter où sont
hébergés tout ces sites !&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;img src=&quot;http://www.insideit.fr/public/cef/.Analyse-EgliseInfo_m.jpg&quot; alt=&quot;Analyse EgliseInfo&quot; title=&quot;Analyse EgliseInfo, janv. 2012&quot; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;a href=&quot;http://www.insideit.fr/public/cef/graphique_reccord_1104.png&quot;&gt;&lt;img src=&quot;http://www.insideit.fr/public/cef/.graphique_reccord_1104_s.jpg&quot; alt=&quot;Record de visite : 1104&quot; style=&quot;float:right; margin: 0 0 1em 1em;&quot; title=&quot;Record de visite : 1104, janv. 2012&quot; /&gt;&lt;/a&gt;MessesInfo (Ancienne version
du site fait en PHP, qui est encore référencé) redirigeait presque tous le
trafic vers EgliseInfo, redirection javascript depuis la page de résultat
MessesInfo (pouvait venir d'une recherche Google) vers la recherche
correspondante sur EgliseInfo. Donc pas de plantage du côté de MessesInfo, et
une forte charge sur EgliseInfo qui a bien fonctionné avec des temps de réponse
acceptables (forcément plus lent qu'habituellement).&lt;/p&gt;
&lt;p&gt;&lt;a href=&quot;http://www.insideit.fr/public/cef/instances.png&quot;&gt;&lt;img src=&quot;http://www.insideit.fr/public/cef/.instances_s.jpg&quot; alt=&quot;Evolution des instances App Engine&quot; style=&quot;float:right; margin: 0 0 1em 1em;&quot; title=&quot;Evolution des instances App Engine, janv. 2012&quot; /&gt;&lt;/a&gt;Google nous a mis en
place automatiquement jusqu'à 400 serveurs disponibles (instances de
l'application, qui sont virtualisées sur plusieurs serveurs réels).&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;
&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Conclusion&lt;/h2&gt;
&lt;p&gt;En conclusion, Google App Engine a vraiment permis de gérer la très forte
charge du site pour un coût tout à fait raisonnable. Pour les prochaines fois,
il nous faudra mettre en place une répartition sur plusieurs bases de données,
et dégrader les fonctionnalités pour accélérer les recherches.&lt;/p&gt;</description>
    
    
    
          <comments>http://www.insideit.fr/post/2012/01/30/No%C3%ABl-dans-les-nuages-%21#comment-form</comments>
      <wfw:comment>http://www.insideit.fr/post/2012/01/30/No%C3%ABl-dans-les-nuages-%21#comment-form</wfw:comment>
      <wfw:commentRss>http://www.insideit.fr/feed/atom/comments/663686</wfw:commentRss>
      </item>
    
  <item>
    <title>Sfeir à Devoxx</title>
    <link>http://www.insideit.fr/post/2011/11/30/Sfeir-%C3%A0-Devoxx</link>
    <guid isPermaLink="false">urn:md5:c706aaeb9319e2ea1d09a0bc97caf41b</guid>
    <pubDate>Wed, 30 Nov 2011 21:58:00 +0100</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Conférence</category>
        <category>Devoxx</category><category>sfeir</category>    
    <description>    10 ans … Voilà 10 ans que vers cette période de l’année, plus de 3000
passionnés se réunissent à Anvers pour la plus grosse conférence autour de la
plateforme java. Elle se découpe en 2 parties : université et conférence.&lt;br /&gt;
Pour moi, c’était ma 3ème participation. Par contre, cette fois ci, j'y suis
allé pour la semaine complète avec mes collègues Vincent Bostoen et Benito
d’Almeida. Les autres Sfeiriens, eux, nous ont rejoint le mercredi. Au total,
15 Sfeirens étaient présent. Même si nous sommes partis 2 jours avant les
autres, nous avions tout de même le même point de rendez-vous avant le départ.
Malgré une petite mésaventure dans les transports en commun Anversois, nous
sommes arrivés à bon port au cinéma multiplexe où a lieu la conférence.&lt;br /&gt;
Cette année, gros changement dans l’organisation : au lieu d’un simple badge
avec de petits tickets à échanger contre les repas, nous avons reçu un bracelet
marqué de notre nom et d’un code barre. Heureusement, ce bracelet était
waterproof car nous devions le garder au bras pendant la semaine entière.&lt;br /&gt;
C’est donc le mercredi qu’à la station de tramway nous avons rencontré nos
autres collègues pour la 2ème partie de l’aventure : la conférence. Celle ci a
commencé par l’habituelle keynote de Stephan Jansen, l’organisateur. Pour finir
son discours, il nous a montré une vidéo. On y reconnaît quelques têtes connues
: les organisateurs du Paris JUG... puis s’affiche “Devoxx France” … Et oui, au
mois d’avril, nous aurons une conférence affiliée à Devoxx, ici à Paris, avec
75% des sessions en français. Sfeir est d’ailleurs sponsor de
l’évènement.&lt;br /&gt;
Le retour s’est fait le vendredi après midi, après une semaine plutôt
fatigante.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Mes impressions globales :&lt;br /&gt;
&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;On sent vraiment que Google est partenaire : nous avons eu beaucoup de
sessions autour d’Android et Html5.&lt;/li&gt;
&lt;li&gt;Même chose en avec le duo Spring Source/Cloud Foundry&lt;/li&gt;
&lt;li&gt;Les langages jvm ont du succès : Scala a eu droit à beaucoup de sessions et
remplaçait même java pour des exemples de codes. Ceux un peu moins populaires :
Fantom et Clojure ; et les petits nouveaux : Kotlin et Ceylon venaient se
présenter.&lt;/li&gt;
&lt;li&gt;Moins de sessions cloud que les années précédentes.&lt;/li&gt;
&lt;li&gt;Plus d'animations aux stands : course de petites voitures sur circuit
électrique, roulette de casino virtuelle, ...&lt;/li&gt;
&lt;li&gt;Pas de grosses annonces (mis à part Devoxx France)&lt;/li&gt;
&lt;li&gt;Comme toujours, beaucoup de monde.&lt;/li&gt;
&lt;li&gt;De plus en plus de français.&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Parmi les sessions qui m'ont le plus intéressé :&lt;br /&gt;
&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;JAX-RS 2 qui disposera d'une (meilleure) intégration avec d'autres apis
comme Bean Validation (JSR-303), et surtout d’une partie cliente.&lt;/li&gt;
&lt;li&gt;MongoBD. Je l'avais récemment découvert pour un POC où je voulais stocker
des données en ligne, la session m'a permis de mieux voir les possibilités
qu'il offre.&lt;/li&gt;
&lt;li&gt;Performance et usabilité Android : beaucoup de conseils divers de
développement à ne pas oublier si l’on veut une application qui soit
ergonomique et performante.&lt;/li&gt;
&lt;li&gt;Android sur Google TV, même si on est loin d'avoir ces télévisions aussi
répandues que des smartphones, il est tout de même intéressant de voir les
enjeux et l'ergonomie.&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Pour ceux qui n’ont pas pu venir et qui seraient intéressés pour revoir les
sessions, ou pour ceux qui souhaitent voir certaines sessions qu’ils n'auraient
pas pu voir : il y a Parleys. Ce site offre en effet la possibilité de revoir
les sessions de Devoxx, mais aussi de certains jugs locaux. Les sessions Devoxx
seront disponibles gratuitement pour ceux qui y ont participé, via abonnement
pour les autres. Il faudra quand même patienter jusqu’à la fin de l'année pour
qu'elles soient disponibles....&lt;br /&gt;
&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;a href=&quot;http://2.bp.blogspot.com/-4aR-TVA6524/TsXKUbS67UI/AAAAAAAAEA8/wpTHjj8SI3I/s800/IMG_8053.jpg&quot; style=&quot;margin-left: 1em; margin-right: 1em;&quot;&gt;&lt;img border=&quot;0&quot; height=&quot;302&quot; src=&quot;http://2.bp.blogspot.com/-4aR-TVA6524/TsXKUbS67UI/AAAAAAAAEA8/wpTHjj8SI3I/s320/IMG_8053.jpg&quot; width=&quot;320&quot; /&gt;&lt;/a&gt;&lt;/div&gt;
&lt;br /&gt;
&lt;br /&gt;
Photo par &lt;a href=&quot;https://plus.google.com/118041907032714528693/posts&quot;&gt;Pierre-Antoine
Grégoire&lt;/a&gt;.</description>
    
    
    
      </item>
    
  <item>
    <title>Code Retreat #1</title>
    <link>http://www.insideit.fr/post/2011/06/28/Code-Retreat-1</link>
    <guid isPermaLink="false">urn:md5:78a7bc62b760de57d7c3c0ac13f54430</guid>
    <pubDate>Tue, 28 Jun 2011 14:30:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>Code Retreat</category>    
    <description>    Ce 24 juin, j'ai assisté à un code retreat, organisé par &lt;a href=&quot;https://twitter.com/#!/morlhon&quot;&gt;Jean-Laurent de Morlhon&lt;/a&gt; et Simon Caplette,
chez Xebia.&lt;br /&gt;
Avant de m'inscrire, je n'en connaissais pas le principe. Je me réfère donc à
la définition donnée par les organisateurs :&lt;br /&gt;
&amp;quot;Le principe est le suivant: sur la journée coder en binôme sur plusieurs
sessions de 30-45 minutes chacune afin de résoudre un problème. A l’issue de
chaque session on change de binôme et tout le code produit est effacé.
Drastique mais efficace pour rester créatif. C’est aussi le lieu privilégié
pour tester de nouvelles techniques et algorithmes.&amp;quot;&lt;br /&gt;
C'est un concept de coding dojo que je n'avais essayé, d'où mon envie de
tester.&lt;br /&gt;
&lt;br /&gt;
Le temps que tout le monde soit là et installé, un traditionnel petit déjeuner
nous attendait.&lt;br /&gt;
Avant de commencer, l'organisation de la journée nous est présenté :&lt;br /&gt;
- Le but n'est pas de finir, mais de faire ce que l'on peut&lt;br /&gt;
- Par recommmencement on finit par s'améliorer, on cherche à améliorer la façon
de faire.&lt;br /&gt;
- Une session est composé de 40 min de développement en pair programming et 20
min de débriefing général.&lt;br /&gt;
- Ici c'est différent du boulot, on a le temps, inutile de rusher. Nous sommes
ici pour apprendre, tester d'autres façons de faire, essayer un autre langage
ou un autre ide, découvrir des plugins d'ide, ...&lt;br /&gt;
- Procéder par TDD et suivi les principes de &lt;a href=&quot;http://en.wikipedia.org/wiki/You_ain%27t_gonna_need_it&quot;&gt;YAGNI&lt;/a&gt;. Si ce sont
des pratiques que l'on ne fait pas au quotidien dans notre travail, c'est
justement l'occasion de s'y exercer&lt;br /&gt;
- Une session est composé d'une partie de développement de 40 min en pair
programming, suivi de 10-15 min de retrospective globale.&lt;br /&gt;
- Une retrospective globale en fin de journée&lt;br /&gt;
&lt;br /&gt;
Souvent le jeu de la vie est utilisé en code retreat, ici pour changer ce sera
TicTacToe dont les spécification nous sont fournis en 6 règles :&lt;br /&gt;
1/ Une partie est finie lorsque tous les champs sont pris.&lt;br /&gt;
2/ Une partie est finie lorsque une colonne est prise par un joueur.&lt;br /&gt;
3/ Une partie est finie lorsque une ligne est prise par un joueur.&lt;br /&gt;
4/ Une partie est finie lorsque une diagonale est prise par un joueur.&lt;br /&gt;
5/ Un joueur peut jouer lorsque un champ n'est pas pris.&lt;br /&gt;
6/ Les joueurs jouent à tour de role jusqu'à ce que la partie soit finie.&lt;br /&gt;
&lt;br /&gt;
Au total, sur la journée 5 sessions auront lieu.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Session 1&lt;/h1&gt;
&lt;br /&gt;
Au bilan de cette première session, certains remonte l'usage de plugins Eclipse
:&lt;br /&gt;
- &lt;a href=&quot;http://www.happyprog.com/pairhero/&quot;&gt;Pair Hero&lt;/a&gt; : duels en pair
programming où chacun code à tour de role jusqu'à ce qu'un test échoue. Des
points sont gagnés en fonction de refacto ou rapidité à faire passer le
clavier.&lt;br /&gt;
- &lt;a href=&quot;http://infinitest.github.com/&quot;&gt;Infinitest&lt;/a&gt; : lance les tests
unitaire à chaque enregistrement du code, économise ainsi des switch
test/code.&lt;br /&gt;
Beaucoup prennent les régles dans l'ordre, mais est ce bien utile ?&lt;br /&gt;
Quant à l'implémentation, le plateau est codé sous diverse forme : tableau à 2
dimensions, chaine simple, ...&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Session 2&lt;/h1&gt;
&lt;br /&gt;
Les noms de classes eux aussi sont variés : TicTacToe, Party, Board, ... tout
comme les méthodes de fin : checOver, isOver(), ....&lt;br /&gt;
Des questions sur le moment où refactorer se posent. Le mieux est quand on
veux, quand celà nous semble un moment logique, une étape. Et il ne faut pas
oublier que la refacto concerne aussi bien, le code métier que les tests.&lt;br /&gt;
Quelques personnes pense qu'ils ont introduit la notion de joueur trop tôt, ils
auraient pu refactorer lorsqu'ils en auraients eu besoine.&lt;br /&gt;
Profitant de l'occasion de pouvoir refactorer, certains ont changé leur design,
parfois avec regret. Mais y trouve tous l'avantage du recommencement, qu'ils ne
peuvent pas faire au boulot.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Session 3&lt;/h1&gt;
&lt;br /&gt;
Quelqu'uns trouvent un avantage dans l'implémentation de recherche interne,
pour une raison de facilité de recherche interne.&lt;br /&gt;
Pour la part, après 2 sessions orientée sur la détection de fin de partie, mon
code était plutôt orienté vers la le tour par tour des joueurs.&lt;br /&gt;
Une problématique courante remonte : placer le jeu dans un état précis pour
tester par exemple des configuration de plateau. Une solution possible serait
d'avoir une méthode d'initialisation.&lt;br /&gt;
Les animateurs remontent qu'ils entendent parler d'architecture, mais qu'il
s'agit là d'une notion bien poussée, car la seule voulue, c'est un simple
jeu.&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Pause repas&lt;/h1&gt;
&lt;br /&gt;
Après toutes ces aventures de la matinée, nous avons le droit à un repas geek :
pizza/coca !&lt;br /&gt;
Pour l'apres midi, pour ceux qui souhaitent, on monte le niveau avec des
objectifs :&lt;br /&gt;
- No Mouse : souris interdite, uniquement clavier.&lt;br /&gt;
- 5 min par personne : on alterne le clavier toutes les 5 minutes.&lt;br /&gt;
- &lt;a href=&quot;http://gojko.net/2009/02/27/thought-provoking-tdd-exercise-at-the-software-craftsmanship-conference/&quot;&gt;
Tdd as if you meant it&lt;/a&gt; : Tdd encore plus poussé avec des régles comme coder
son code métier dans la classe de test.&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Session 4&lt;/h1&gt;
&lt;br /&gt;
Pour cette session, 2 groupes ont testé un autre langage :&lt;br /&gt;
- JavaScript (&lt;a href=&quot;http://twitter.com/#!/MathildeLemee&quot;&gt;Mathilde Lemée&lt;/a&gt;
et &lt;a href=&quot;http://twitter.com/#!/ericlemerdy&quot;&gt;Eric Le Merdy&lt;/a&gt;) : Utilisation
de JQuery, structure de données portée par la page. QUnit ne semble pas super
pour tester du js.&lt;br /&gt;
- &lt;a href=&quot;http://ioke.org/&quot;&gt;Ioke&lt;/a&gt; (&lt;a href=&quot;http://twitter.com/#!/dgageot&quot;&gt;David Gageot&lt;/a&gt; et moi même) : Je ne
connaissais absolument pas ce langage, j'ai donc était volontaire pour le
découvrir. C'est un langage entre lisp, ruby et smalltalk qui tourne aussi bien
sur une VM java que .Net. Nos tests sont assez très lisible, au contraire du
code. En effet, de refacto en refacto et par jeu, nous avons réduit de façon
très importante le code en utilisant toute la puissance du langage. Si bien que
notre code pour les régles lignes et colonnes tient en 3 lignes.&lt;br /&gt;
Ceux qui avaient l'objectif, Tdd as if you meant it sont satisfaits, par le
fait d'avoir pu repousser le moment de décider où placer son code.&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Session 5&lt;/h1&gt;
&lt;br /&gt;
Le groupe JS a poursuivi ce qu'il avait commencé et nous montre leur
réalisation. Le js a permit de connecter facilement à une ihm html, la
structure de données est directement dans le dom plutôt que dans des objets
js.&lt;br /&gt;
David a continué en Ioke avec un autre volontaire pour découvrir le langage. De
nouvelles refacto ont eu lieu, et le code pour tester les 4 ères régles
tiennent sur environ 6 lignes.&lt;br /&gt;
Nos animateurs nous montrent un exemple de Tdd as if you meant qu'ils avaient
réalisé. Le retardement du choix du placement du code a fait qu'ils ont eu une
approche fonctionnelle, où le modèle est sans état.&lt;br /&gt;
Et pour finir, ils énumèrent quelques possibilité de challenge possible en code
retreat : No loop, No If, ...&lt;br /&gt;
Invonlontairement, ces 2 challenges ont été vaincus par David et son code en
Ioke.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Debriefing de la journée&lt;/h1&gt;
&lt;br /&gt;
Nous finissons la journée sur une rétrospective finale sur ce que nous avons
appris et ce qui sera pratiqué au retour au travail. Dans le désordre :&lt;br /&gt;
- Découverte du tdd et voir quelle limite dans l'approche du code nécessaire à
faire passer le test.&lt;br /&gt;
- Le tdd permet de penser plus au fonctionnel.&lt;br /&gt;
- Necessité de plus pousser le principe de code minimal afin d'affiner ses
tests.&lt;br /&gt;
- Réticence à Infinitest vaincu. Pour des tests volumineux, il est
paramétrable.&lt;br /&gt;
- Un autre langage qui faire penser différement.&lt;br /&gt;
- Pair Hero assez plaisant&lt;br /&gt;
- Parfois on pense avoir résolu de manière optimale un problème mais après
avoir recommencé avec une autre personne, on se rend compte que non.&lt;br /&gt;
- Progression dans les tests car parfois quasiment pas de tests dans les
projets au boulot.&lt;br /&gt;
- Nouvelle vision à chaque fois.&lt;br /&gt;
- Du test fait mais pas tdd, ce qui fait une nouvel outil à utiliser.&lt;br /&gt;
- Il peut être utile d'avoir une phase de réflexion avant de se lancer dans les
tests.&lt;br /&gt;
- Des discussions intéressantes.&lt;br /&gt;
- Passer plus de temps sur la refacto.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Un autre &lt;a href=&quot;http://fr.eventbrite.com/event/1832714699&quot;&gt;Code Retreat&lt;/a&gt;
aura lieu le 2 juillet, avec &lt;a href=&quot;http://twitter.com/#!/ojuncu&quot;&gt;Oana
Juncu&lt;/a&gt; de Sfeir comme animatrice.&lt;br /&gt;
A l'heure actuelle, il reste quelques places dépéchez si vous être intéressés.</description>
    
    
    
      </item>
    
  <item>
    <title>La marmite des Duchess</title>
    <link>http://www.insideit.fr/post/2011/06/23/La-marmite-des-Duchess</link>
    <guid isPermaLink="false">urn:md5:45afba07fa2a711c1c3ec871755c92ac</guid>
    <pubDate>Thu, 23 Jun 2011 00:49:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>Duchesse</category><category>Mockito</category><category>TDD</category>    
    <description>    La 1ère édition de la Marmite des Duchess a eu le 7 juin dernier. Nom de code
&amp;quot;Crumble&amp;quot;.&lt;br /&gt;
Ce nouvel évènement, proposait 2 sessions en parallèle, le choix se faisait à
l'inscription :&lt;br /&gt;
- Atelier Mockito, animé par Mathilde Lemée et David Gageot. (limité à 20
places)&lt;br /&gt;
- Open Space Technologique. (limité à 40 places)&lt;br /&gt;
Doit on y voir l'anologie du crumble dans ce découpage ? Je ne saurais répondre
à cette question.&lt;br /&gt;
&lt;br /&gt;
Au total, une trentaine de personnes (dont 6 Sfeirien(ne)s) étaient présentes
pour une durée d'un peu plus de 2 heures.&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Atelier Mockito&lt;/h1&gt;
&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;img src=&quot;http://farm3.static.flickr.com/2315/5811390860_88c392d717.jpg&quot; /&gt;&lt;/div&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
C'est la partie à laquelle j'ai assisté.&lt;br /&gt;
Cet atelier était basé sur le code de &lt;a href=&quot;https://github.com/jdubois/Tudu-Lists&quot;&gt;tudu-list&lt;/a&gt;. Le but était de, en peer
programming, compléter des tests et de les faire passer au vert. Pour palier
aux différentes connaissances et niveaux des participants, les tests étaient
répartis en 3 niveaux de difficulté.&lt;br /&gt;
Pour ma part, connaissant un peu Mockito, j'ai affronté le niveau 2. Nos
animateurs étaient bien sûr présent pour nos différentes questions sur la façon
de développer/organiser nos tests aussi bien sur Mockito mais aussi sur
FestAssert.&lt;br /&gt;
Ces exercices permettent d'avoir quelques bases sur Mockito en découvrant sa
syntaxe et ses particularités mais aussi si nous sommes rigoureux de se
familiariser avec le formalisme BDD,  conseillé pour bien se concentrer
sur une seule chose à tester par méthode de test.&lt;br /&gt;
&lt;br /&gt;
Si vous souhaitez tenter le défi, le code à compléter est &lt;a href=&quot;https://github.com/DuchessFrance/Tudu-Lists&quot;&gt;ici&lt;/a&gt; et la solution &lt;a href=&quot;https://github.com/MathildeLemee/Tudu-Lists&quot;&gt;là&lt;/a&gt;.&lt;br /&gt;
&lt;br /&gt;
&lt;h1&gt;Open Space Technologie&lt;/h1&gt;
&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;img src=&quot;http://farm3.static.flickr.com/2660/5810826773_0f9f63d050.jpg&quot; /&gt;&lt;/div&gt;
&lt;br /&gt;
&lt;br /&gt;
D'après ce que j'en ai compris, un open space technologie est assez semblable à
un bar camp, mis à part qu'il n'y a pas de sessions parallèles.&lt;br /&gt;
&lt;div&gt;N'ayant pas de don d'ubiquité, je n'étais pas présent à cette partie. Mais
heureusement, mon collègue &lt;a href=&quot;https://twitter.com/#!/CGriffoin&quot;&gt;Clément
Griffoin&lt;/a&gt; avait pris des notes.
&lt;div&gt;&lt;br /&gt;
&lt;br /&gt;
Différents sujets ont étés abordés dont :&lt;br /&gt;
- Women in java&lt;br /&gt;
- ForPlay où &lt;a href=&quot;https://twitter.com/#!/Piwai&quot;&gt;Pierre-Yves Ricau&lt;/a&gt; fera
une démonstration de sa &lt;a href=&quot;http://forplay-2h4u.appspot.com&quot;&gt;réalisation&lt;/a&gt;&lt;br /&gt;
- Déploiement continu&lt;br /&gt;
- Stubs vs Mock&lt;br /&gt;
- TDD/DDD/BDD&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Vous pourrez retrouver plus d'informations ce qui s'est dit dans cette partie
sur &lt;a href=&quot;http://jduchess.org/duchess-france/&quot;&gt;le blog des
Duchess&lt;/a&gt;.&lt;br /&gt;
&lt;br /&gt;
Et pour finir, c'est un autour d'un repas que les derniers motivés se sont
retrouvés.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Merci et félicitations pour cette première édition ! Et vivement la suite à la
rentrée.&lt;br /&gt;
&lt;br /&gt;
Des photos de cet article ainsi que toutes les photos la soirées sont
disponible sur l'&lt;a href=&quot;http://www.flickr.com//photos/jduchess/sets/72157626913389876&quot;&gt;espace Flickr
de Duchess France&lt;/a&gt;&lt;/div&gt;
&lt;/div&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Du Protobuf dans mon Jersey</title>
    <link>http://www.insideit.fr/post/2011/06/23/Du-Protobuf-dans-mon-Jersey</link>
    <guid isPermaLink="false">urn:md5:8265a6889396b10688b29e7a4bcb941c</guid>
    <pubDate>Thu, 23 Jun 2011 00:38:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>GAE</category><category>Guice</category><category>Jersey</category><category>Protobuf</category><category>Rest</category>    
    <description>    &lt;p&gt;J'avais déjà parlé, dans de précédents articles, de la génération de xml et
de json avec Jersey. Et si maintenant, on s'amusait à générer du
protobuf ?&lt;br /&gt;
On parle de protobuf pour Protocol Buffers, une techno Google pour encoder des
structures de données. Ce format de données compact est utilisé en interne chez
Google des échanges de données. Etant basé sur la déclaration d'une structure
de données dans un idl, protobuf possède plusieurs implémentation et est ainsi
utilisable dans plusieurs langage. En java, la génération du code cible se fait
avec ant. Mais bien sur reste utilisable avec maven par le plugin ant.&lt;br /&gt;
Nous allons reprendre notre Hello qui avait d'exemple. Voici sa structure
protobuf :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
package nfrancois.poc;

option java_package = &amp;quot;nfrancois.poc.protobuf.model&amp;quot;;
option java_outer_classname = &amp;quot;HelloProto&amp;quot;;

message Hello {
  required string name = 1;
  required string message = 2;
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La structure se comprend assez facilement. Attention par contre, au trompeur
package de 1ère ligne, qui n'est pas lié à la notion de package que nous avons
en java. Il sert comme espace de nommage et éviter des collisions de nom si
plusieurs objets protobuf portent le même nom. Puisque depuis cette idl, je
pourrai aussi bien générer en C++ ou un autre langage, le vrai nom de package
java est indiqué par l'option &amp;quot;java_package&amp;quot;, de la même façon pour le nom de
classe qui va tout encapsuler qui sera &amp;quot;java_outer_classname&amp;quot;&lt;br /&gt;
Pour plus d'information sur &lt;a href=&quot;http://code.google.com/p/protobuf&quot;&gt;protobuf&lt;/a&gt;, je vous invite à consulter sa
page google code.&lt;br /&gt;
Le générateur protobuf générera un fichier HelloProto.java, qui permettra de
manipuler les Hello : création via pattern builder, encodage/désencodage,
... Le &amp;quot;vrai&amp;quot; Hello sera encapuslé au sein de ce dernier. Comme je disais, je
génère le java par le ant plugin de maven :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
&amp;lt;plugin&amp;gt;
 &amp;lt;groupid&amp;gt;org.apache.maven.plugins&amp;lt;/groupId&amp;gt;
 &amp;lt;artifactid&amp;gt;maven-antrun-plugin&amp;lt;/artifactId&amp;gt;
 &amp;lt;version&amp;gt;1.6&amp;lt;/version&amp;gt;
 &amp;lt;executions&amp;gt;
  &amp;lt;execution&amp;gt;
   &amp;lt;id&amp;gt;generate-sources&amp;lt;/id&amp;gt;
   &amp;lt;phase&amp;gt;generate-sources&amp;lt;/phase&amp;gt;
   &amp;lt;configuration&amp;gt;
    &amp;lt;target&amp;gt;
     &amp;lt;exec executable='protoc'&amp;gt;
             &amp;lt;arg value='--java_out=src/main/java' /&amp;gt;
             &amp;lt;arg value='src/main/resources/Hello.proto' /&amp;gt;
             &amp;lt;/exec&amp;gt;
    &amp;lt;/target&amp;gt;
   &amp;lt;/configuration&amp;gt;
   &amp;lt;goals&amp;gt;
    &amp;lt;goal&amp;gt;run&amp;lt;/goal&amp;gt;
   &amp;lt;/goals&amp;gt;
  &amp;lt;/execution&amp;gt;     
 &amp;lt;/executions&amp;gt;
&amp;lt;/plugin&amp;gt;
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
et bien sûr des dépendances protobuf&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
&amp;lt;dependency&amp;gt;
    &amp;lt;groupid&amp;gt;com.google.protobuf&amp;lt;/groupId&amp;gt;
    &amp;lt;artifactid&amp;gt;protobuf-java&amp;lt;/artifactId&amp;gt;
    &amp;lt;version&amp;gt;2.4.0a&amp;lt;/version&amp;gt;
&amp;lt;/dependency&amp;gt;
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
Le contrat de test sera assez proche de se que nous avions dans les tests
précédents :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Test
public void shoulReplyHello(){
 // Given
 String message = &amp;quot;Hello&amp;quot;;
 String name =&amp;quot;Nicolas&amp;quot;;
 Hello hello = HelloProto.Hello.newBuilder().setName(name).setMessage(message).build();
 when(helloServiceMock.saysHelloToSomeone(&amp;quot;Nicolas&amp;quot;)).thenReturn(hello);
 // When
 ClientResponse response = resource().path(&amp;quot;hello&amp;quot;).path(name).get(ClientResponse.class);
 // Then
 verify(helloServiceMock).saysHelloToSomeone(name);
 assertThat(response.getClientResponseStatus()).isEqualTo(Status.OK);
 assertThat(response.getType().toString()).isEqualTo(&amp;quot;application/x-protobuf&amp;quot;);
 Hello entity = response.getEntity(Hello.class);
 assertThat(entity).isNotNull().isEqualTo(hello);
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La resource REST, elle aussi va peut évoluer :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Path(&amp;quot;hello&amp;quot;)
@Singleton
@Produces(&amp;quot;application/x-protobuf&amp;quot;)
public class HelloResource {
 
 @Inject
 private HelloService helloService;
 
 @GET
 @Path(&amp;quot;/{name}&amp;quot;)
 public Hello reply(@PathParam(&amp;quot;name&amp;quot;) String name){
  return helloService.saysHelloToSomeone(name);
 }
 
 public void setHelloService(HelloService helloService) {
  this.helloService = helloService;
 }
 
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La difficulté à laquelle il faut se confronter, c'est que Jersey ne permet pas
de gérer de base le protobuf… Pas grave, on va s'occuper de faire le lien entre
l'encodage/désencodage de protobuf et Jersey.&lt;br /&gt;
&lt;br /&gt;
Commençons par le reader qui s'occupe de désencoder le protobuff. Pour celà,
nous devons implémenter l'interface MessageBodyReader où nous aurons du code
technique protobuf.&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Provider
@Consumes(&amp;quot;application/x-protobuf&amp;quot;)
@Singleton
public class ProtobufMessageBodyReader implements MessageBodyReader&amp;lt;Message&amp;gt; {

 public boolean isReadable(Class&amp;lt;?&amp;gt; type, Type genericType, Annotation[] annotations,
                                                            MediaType mediaType) {
  return Message.class.isAssignableFrom(type);
 }

 public Message readFrom(Class&amp;lt;Message&amp;gt; type, Type genericType, Annotation[] annotations, 
    MediaType mediaType, MultivaluedMap&amp;lt;String, String&amp;gt; httpHeaders, InputStream entityStream)
    throws IOException, WebApplicationException {
  try {
   Method newBuilder = type.getMethod(&amp;quot;newBuilder&amp;quot;);
   GeneratedMessage.Builder builder = (GeneratedMessage.Builder) newBuilder.invoke(type);
   return builder.mergeFrom(entityStream).build();
  } catch (Exception e) {
   throw new WebApplicationException(e);
  }
 }

}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
&lt;br /&gt;
C'est par le content type &amp;quot;application/x-protobuf&amp;quot; que JAX-RS fera matcher le
type le reader/writer à l'entrée/sortie de la resource. Pour l'encodage, c'est
l'interface MessageBodyWriter qu'il faut implémenter.&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Provider
@Produces(&amp;quot;application/x-protobuf&amp;quot;)
@Singleton
public class ProtobufMessageBodyWriter implements MessageBodyWriter&amp;lt;Message&amp;gt; {
 public boolean isWriteable(Class&amp;lt;?&amp;gt; type, Type genericType, Annotation[] annotations,
                                                              MediaType mediaType) {
  return Message.class.isAssignableFrom(type);
 }

 private Map&amp;lt;Object, byte[]&amp;gt; buffer = new WeakHashMap&amp;lt;Object, byte[]&amp;gt;();

 public long getSize(Message m, Class&amp;lt;?&amp;gt; type, Type genericType, Annotation[] annotations, 
                                                                 MediaType mediaType) {
  ByteArrayOutputStream baos = new ByteArrayOutputStream();
  try {
   m.writeTo(baos);
  } catch (IOException e) {
   return -1;
  }
  byte[] bytes = baos.toByteArray();
  buffer.put(m, bytes);
  return bytes.length;
 }

 public void writeTo(Message m, Class type, Type genericType, Annotation[] annotations, 
                MediaType mediaType, MultivaluedMap httpHeaders, OutputStream entityStream)
                throws IOException, WebApplicationException {
  entityStream.write(buffer.remove(m));
 }
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La configuration de test, quant à elle sera un peu plus complexe, car il faut
que la partie cliente puisse désencoder toute seule le
protobuf :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
protected AppDescriptor configure() {
 ClientConfig clientConfig = new DefaultClientConfig();
 clientConfig.getClasses().add(ProtobufMessageBodyReader.class);
 clientConfig.getClasses().add(ProtobufMessageBodyWriter.class);
 injector = Guice.createInjector(new ServletModule() {
 @Override
 protected void configureServlets() {
  bind(ProtobufMessageBodyReader.class);
  bind(ProtobufMessageBodyWriter.class);
  bind(HelloResource.class);
  serve(&amp;quot;/*&amp;quot;).with(GuiceContainer.class);
  }
 }); 
 return new WebAppDescriptor.Builder()
          .contextListenerClass(GuiceTestConfig.class)
          .filterClass(GuiceFilter.class)
          .clientConfig(clientConfig)
          .servletPath(&amp;quot;/&amp;quot;)
          .build();
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
Le code complet est &lt;a href=&quot;https://github.com/nfrancois/PocJerseyProtobufGuiceAppEngine&quot;&gt;ici&lt;/a&gt;.&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Bilan Cloud Camp 1 chez Sfeir</title>
    <link>http://www.insideit.fr/post/2011/06/22/Bilan-Cloud-Camp-1-chez-Sfeir2</link>
    <guid isPermaLink="false">urn:md5:29c52279cb931dac010e4b26f35d170c</guid>
    <pubDate>Wed, 22 Jun 2011 22:11:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Conférence</category>
            
    <description>    C'est le 30 mai dernier qu'a été organisé le 1er Cloud Camp. Plus de 50
personnes étaient présentes au rendez vous. A l'arrivée, un accueil convivial
avec des cacahuètes et boisson attendaient les invités. La soirée commence avec
une présentation de Kohsuke Kawaguchi, sur le build en parallèle avec Jenkins.
&lt;div&gt;&lt;br /&gt;
 
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;a href=&quot;http://3.bp.blogspot.com/-_8ddy-9nTdE/TgJBAPq2zGI/AAAAAAAAAIE/Ia0AFM3se54/s1600/IMG_20110530_191233.jpg&quot; style=&quot;margin-left:1em; margin-right:1em&quot;&gt;&lt;img border=&quot;0&quot; height=&quot;300&quot; width=&quot;400&quot; src=&quot;http://3.bp.blogspot.com/-_8ddy-9nTdE/TgJBAPq2zGI/AAAAAAAAAIE/Ia0AFM3se54/s400/IMG_20110530_191233.jpg&quot; /&gt;&lt;/a&gt;&lt;/div&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Dans la foulée, Steven Noels lui aussi vient aussi nous parler de son
bébé : Lily&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;a href=&quot;http://3.bp.blogspot.com/-V_dCwQqZfaw/TgJBp53HYSI/AAAAAAAAAIM/MjU9VhwSdhw/s1600/IMG_20110530_194949.jpg&quot; style=&quot;margin-left:1em; margin-right:1em&quot;&gt;&lt;img border=&quot;0&quot; height=&quot;300&quot; width=&quot;400&quot; src=&quot;http://3.bp.blogspot.com/-V_dCwQqZfaw/TgJBp53HYSI/AAAAAAAAAIM/MjU9VhwSdhw/s400/IMG_20110530_194949.jpg&quot; /&gt;&lt;/a&gt;&lt;/div&gt;
&lt;/div&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;div&gt;C'est autour de pizza que nous nous remettons de nos émotions, ce qui est
aussi l'occasion de discuter entre différentes personnes présentes. C'est
après, s'être bien rempli l'estomac que la soirée, s'est poursuivies etlLes
sessions camp organisées furent :
&lt;ul&gt;
&lt;li&gt;Forplay : le framework de Google pour réaliser des jeux pour des
cibles Gwt/Android/Flex/Swing&lt;/li&gt;
&lt;li&gt;Retour d'expérience sur Appengine&lt;/li&gt;
&lt;li&gt;Mvp4g&lt;/li&gt;
&lt;li&gt;Démo de Lilly&lt;/li&gt;
&lt;li&gt;CloudBees&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Le Bilan que je fais de cloud camp est très positif et a plus au participant.
Nous avons vu défiler les tweets lors des présentation de nos guest start. Et
quelques sujets de blog de participants d'Exilys sur &lt;a href=&quot;http://labs.excilys.com/2011/05/31/lily-un-cms-nosql&quot;&gt;Lily&lt;/a&gt; et &lt;a href=&quot;http://labs.excilys.com/2011/05/31/forplay-le-write-once-run-everywhere-des-jeux-videos/&quot;&gt;
ForPlay&lt;/a&gt;. D'autres sessions, seront probablement organisée. Nous espérons
vous y voir.&lt;/div&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Agile France 2011</title>
    <link>http://www.insideit.fr/post/2011/06/08/Agile-France-2011</link>
    <guid isPermaLink="false">urn:md5:c57aac1036bef7d3a42427fa8b08d28d</guid>
    <pubDate>Wed, 08 Jun 2011 13:18:00 +0200</pubDate>
    <dc:creator>Francois Wauquier</dc:creator>
            
    <description>    &lt;div style=&quot;background-color: transparent; margin-top: 0; margin-left: 0; margin-bottom: 0; margin-right: 0;&quot;&gt;
&lt;h4 id=&quot;internal-source-marker_0.1955672891344875&quot;&gt;&lt;span class=&quot;Apple-style-span&quot; style=&quot;font-family: Arial; font-size: 15px; white-space: pre-wrap; font-weight: normal;&quot;&gt;
LA conférance annuelle de la communauté agile en france.&lt;/span&gt;&lt;/h4&gt;
&lt;a href=&quot;http://conf.agile-france.org/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;a href=&quot;http://agilemanifesto.org/iso/fr/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://agilemanifesto.org/iso/fr/&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;h4 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 12pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Jeudi 26 Mai&lt;/span&gt;&lt;/h4&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Jean Claude Grosjean - Dans la peau du manager agile&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d7758894ff6f7381500008e&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d7758894ff6f7381500008e&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Présentation montrant l’évolution de ce poste dans une structure agile: il
conserve une partie de ses attributions, mais change de posture vis à vis de
l’équipe de réalisation. Au lieu de plannifier, d’attribuer les tâche et de
suivre, il donne la vision, priorise, et challenge.&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://www.slideshare.net/jcgrosjean/grosjean-management-agileagile-france2011&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://www.slideshare.net/jcgrosjean/grosjean-management-agileagile-france2011&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Jean-Phillipe Caruana - Buildr : un outil de build moderne, puissant et
efficace&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d8ccbac4ff6f77395000d18&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d8ccbac4ff6f77395000d18&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Je n’ai vu que le début de cette session, car je me préparais pour ma session.
Mais cet outil est à suivre de près, car les promesses sont grandes: plus
performant et plus flexible que maven.&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://www.barreverte.fr/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://www.barreverte.fr/&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;a href=&quot;http://buildr.apache.org/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://buildr.apache.org/&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Francois Wauquier (votre serviteur) - Les frontières de l’équipe&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d94b7cb4ff6f7089b000094&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d94b7cb4ff6f7089b000094&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Je me suis amusé à comparer une équipe de réalisation avec un village
gaulois.&lt;/span&gt;&lt;br /&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Une fois que l’on a vu la frontière, il ne reste plus qu’à la
supprimer...&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://www.slideshare.net/wokier/agile-france-2011-les-frontieres-de-lequipe&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://www.slideshare.net/wokier/agile-france-2011-les-frontieres-de-lequipe&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Gery Derbier - Top Chef : le carpacio de code&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d9392344ff6f73c470000ae&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d9392344ff6f73c470000ae&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Une expérimentation de développement en petite équipe avec des stories
volontairement floues, afin de mettre en avant le fait que le développement
logiciel est avant tout un mécanisme de création de savoir. Une bonne
simulation que j’ai eu le plaisir de réaliser avec Etienne Charignon dans un
groupe de 3. Petit rappel sur la théorie des jeux coopératifs chère à&lt;/span&gt;
&lt;a href=&quot;http://www.amazon.com/Agile-Software-Development-Cooperative-Game/dp/0321482751/ref=pd_sim_b_9&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Alistair Cockburn&lt;/span&gt;&lt;/a&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;:
Pour bien jouer, il faut réussir le coup et préparer le coup
prochain.&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://twitter.com/#!/Gery7/status/73866830187466753&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://twitter.com/#!/Gery7/status/73866830187466753&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Eric Lefevre - Le Marsmallow Challenge&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d70b0974ff6f719b10005e4&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d70b0974ff6f719b10005e4&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Un petit jeu divertissant et instructif: fournir à un groupe un chamallow, des
spaghettis (non cuits), du scotch et de la ficelle, et leur demander de placer
le chamallow le plus haut possible.&lt;/span&gt;&lt;br /&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
J’ai retenu 3 leçons :&lt;/span&gt;&lt;br /&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
- Ne pas sous-estimer le poids du chammallow (ce que vous aller construire
devra porter...)&lt;/span&gt;&lt;br /&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
- Avancer par petits pas afin d’avoir toujours quelque chose à présenter sans
casser du spaghetti (ah oui, itératif et incrémental...)&lt;/span&gt;&lt;br /&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
- Les enfants s’organisent mieux que certains professionnels.&lt;/span&gt;&lt;br /&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Le groupe dans lequel j’ etais a gagné alors c’est encore plus
drôle.&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://marshmallowchallenge.com/Instructions.html&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://marshmallowchallenge.com/Instructions.html&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;a href=&quot;https://twitter.com/#!/wokier/status/74000767761137664&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
https://twitter.com/#!/wokier/status/74000767761137664&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;a href=&quot;http://www.ted.com/talks/tom_wujec_build_a_tower.html&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://www.ted.com/talks/tom_wujec_build_a_tower.html&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Etienne Charignon - Lire du code&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d8fa5704ff6f752660009f7&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d8fa5704ff6f752660009f7&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Des bonnes pratiques présentées avec un prezi, et des exercices pratique de
lecture du code. J’ai retrouvé plusieurs points de vue lus dans&lt;/span&gt; &lt;a href=&quot;http://www.amazon.fr/Clean-Code-Handbook-Software-Craftsmanship/dp/0132350882&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Clean Code&lt;/span&gt;&lt;/a&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;.
Il distingue plusieurs “causes” d’écriture d’une ligne:&lt;/span&gt;
&lt;ul style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Limitation de la machine&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Limitation du langage&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Limitations du programmeur&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Raisons Historiques&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Besoin/Spécifications (enfin)&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;Je
retiens la comparaison avec la partition de musique: Quel musicien écrirait do
ré mi en commentaire de sa partition?&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://etienne.charignon.free.fr/spip/spip.php?article106&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://etienne.charignon.free.fr/spip/spip.php?article106&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Damien Thouvenin - Centre de service Agile&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4da6001b4ff6f75e0000004e&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4da6001b4ff6f75e0000004e&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Retour d’ expérience d’un centre de service qui se rapproche plus de la TMA que
du forfait. Je ne pense pas que ce genre de structure soit le coeur de cible
des méthodes agiles, mais je retiens 2 bons principes: l’équipe unique et On ne
commence pas la story suivante tant que la précédente n’est pas
validée.&lt;/span&gt;&lt;br /&gt;
&lt;h4 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 12pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Vendredi 27 Mai&lt;/span&gt;&lt;/h4&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Mack Adams - Une carte agile de gestion de produits&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4da8bc6d4ff6f73fde000273&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4da8bc6d4ff6f73fde000273&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Mack distingue les rôles de&lt;/span&gt; &lt;a href=&quot;http://en.wikipedia.org/wiki/Product_owner#Core_Scrum_roles&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Product Owner&lt;/span&gt;&lt;/a&gt; &lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
et&lt;/span&gt; &lt;a href=&quot;http://en.wikipedia.org/wiki/Product_manager&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Product Manager&lt;/span&gt;&lt;/a&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;.
Le premier terme vient de Scrum, le second du marketing. Pour un produit de
petite taille, ces deux rôles peuvent être tenus par la même personne, mais
pour un produit plus complexe, avec beaucoup d’interlocuteurs et/ou une
dimension marketing forte, seul superman peut tenir ce rôle. Dans son
organisation d’éditeur de logiciel multi-continent, il y a même de nombreux
rôles intermédiaires. Son outil préféré pour construire la vision et le backlog
initial est le&lt;/span&gt; &lt;a href=&quot;http://www.agileproductdesign.com/blog/the_new_backlog.html&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
story Mapping&lt;/span&gt;&lt;/a&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;,
qu’il réalise sur des sessions de quelques jours.&lt;/span&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Jonathan Scher &amp;amp; Guillaume Duquesnay - Comment réussir un projet agile très
court&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d984fd94ff6f74ad10001ad&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d984fd94ff6f74ad10001ad&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Une session courte, comme les projets de quelques mois que Jonathan et
Guillaume ont réalisé récemment. C’est un délai si court que l’équipe ne peut
pas se stabiliser. Cela nécessite d’être encore plus discipliné. Ils
recommandent de s’engager sur un enjeu, de faire sauter le sprint
0.&lt;/span&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Pascal Van Cauwenberghe - Les bases des méthodes agiles Lean&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d961f234ff6f701570005e1&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d961f234ff6f701570005e1&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Une grande présentation avec des thèmes chers à Pascal, du rythme, de l’humour,
des anecdotes.&lt;/span&gt;
&lt;ul style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Théorie des contraintes&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Real Options&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Pilotage par la valeur metier&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Auto Organisation&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Excellence Technique&lt;/span&gt;&lt;/li&gt;
&lt;li style=&quot;list-style-type: disc; font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline;&quot;&gt;
&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Amélioration continue&lt;/span&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;a href=&quot;http://blog.nayima.be/2011/06/07/conf-agile-france-2011-les-bases-des-methodes-agiles-et-lean/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://blog.nayima.be/2011/06/07/conf-agile-france-2011-les-bases-des-methodes-agiles-et-lean/&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Christophe Addinquy - Quand mon produit est un système
d’information&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d96ec514ff6f7417600015d&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d96ec514ff6f7417600015d&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Retour d’ experience du Système d’ Iinformation Back de Vidal. J’ai retrouvé
beaucoup de similitudes avec les propos de Mack Adams. Ils se posent tous les
deux la question de prioriser des ensembles plus gros que la story ou l’epic,
que christophe appelle chantier, pour des produits de grande taille et
complexes. Et ils utilisent la même image de superman pour la personne qui
arriverait à définir la vision et suive dans le détail ce genre de
produit.&lt;/span&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Alexandre boutin - Lorsque Scrum ne marche pas&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4d837c064ff6f70c2d000054&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4d837c064ff6f70c2d000054&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Plusieurs sujets possibles, mais un temps limité? Alexandre propose de choisir
en utilisant la technique&lt;/span&gt; &lt;a href=&quot;http://innovationgames.com/buy-a-feature/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Buy a Feature&lt;/span&gt;&lt;/a&gt; &lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
. Le sujet est donc choisit en négociant, en criant et en courant. Le point
commun des sujets, c’est une difficulté rencontrée lors de la mise en place de
Scrum.&lt;/span&gt;&lt;br /&gt;
&lt;a href=&quot;http://www.agilex.fr/&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
http://www.agilex.fr/&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;
&lt;h3 style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 14pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: bold; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Lucian Précup - La revue de code&lt;/span&gt;&lt;/h3&gt;
&lt;a href=&quot;http://conf.agile-france.org/sessions/4da87ce64ff6f721eb000823&quot; style=&quot;font-family: 'Times New Roman'; font-size: medium;&quot;&gt;&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 153); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: underline; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;http://conf.agile-france.org/sessions/4da87ce64ff6f721eb000823&lt;/span&gt;&lt;/a&gt;&lt;br /&gt;

&lt;span style=&quot;font-size: 11pt; font-family: Arial; color: rgb(0, 0, 0); background-color: transparent; font-weight: normal; font-style: normal; text-decoration: none; vertical-align: baseline; white-space: pre-wrap;&quot;&gt;
Cette pratique utilisée par Google, Apache, Mozilla peut être outillée afin de
définir des flux de validation, revue, correction. Tout commit est considéré
comme un patch. Personnellement, je reste fan du binômage.&lt;/span&gt;&lt;/div&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Soirée JDuchess le 7 juin</title>
    <link>http://www.insideit.fr/post/2011/06/01/Soir%C3%A9e-JDuchess-le-7-juin</link>
    <guid isPermaLink="false">urn:md5:5853e242cf209f2be1678c87dd071643</guid>
    <pubDate>Wed, 01 Jun 2011 11:12:00 +0200</pubDate>
    <dc:creator>Audrey</dc:creator>
        <category>Conférence</category>
            
    <description>    &lt;p&gt;Ca y est ! &lt;a href=&quot;http://jduchess.org/duchess-france/blog/marmite-soiree-crumble-pour-la-premiere-edition/&quot;&gt;
La marmite&lt;/a&gt;, le rendez-vous régulier des JDuchess, est lancée. Le premier
opus aura lieu mardi 7 juin dans les locaux de SupInfo (23 rue du Château
Landon, 75010 Paris – à côté de gare du nord). Au programme, deux tracks en
parallèle : un atelier sur le framework de tests unitaires Mockito animé
par Mathilde et un open-space.&lt;/p&gt;
&lt;p&gt;Qu’est-ce qu’un open space ? C’est un peu comme un barCamp à part que
les sujets sont présentés au début et que l’on ne traite que les sujets les
plus populaires pendant un temps limité. Le but essentiel est de partager et de
débattre. Tous les sujets autour de Java et de l’IT sont les bienvenus. Pour
vous donner des idées, voici quelques pistes possibles :&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;une problématique technique que vous avez rencontrée&lt;/li&gt;
&lt;li&gt;un super outil qui a changé votre vie de développeur&lt;/li&gt;
&lt;li&gt;votre sujet de veille préféré&lt;/li&gt;
&lt;li&gt;ou une problématique relationnelle (ex: comment travailler avec une
personne au caractère difficile ?).&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;N'oubliez pas de vous &lt;a href=&quot;http://la-marmite-soiree-crumble.eventbrite.com/&quot;&gt;inscrire&lt;/a&gt;, les places
sont limitées !&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Le Scroll horizontal facile en Android</title>
    <link>http://www.insideit.fr/post/2011/05/26/Le-Scroll-horizontal-facile-en-Android</link>
    <guid isPermaLink="false">urn:md5:6eb01155f623e11aa84805dc4bd11518</guid>
    <pubDate>Thu, 26 May 2011 09:47:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Android</category>
        <category>Android</category>    
    <description>    &lt;p&gt;Dans un souci d'ergonomie, le scroll horizontal est bien appréciable, par
exemple pour passer à l'écran suivant. Même si la fonctionnalité est utilisé,
pour se déplacer entre les écrans du home, il n'existe pas de composants qui
gère cela. Comme bien, souvent, c'est dans l'open source que l'on trouve une
solution.&lt;br /&gt;
C'est sur github que j'ai trouvé &lt;a href=&quot;https://github.com/pakerfeldt/android-viewflow&quot;&gt;View Flow for Android&lt;/a&gt; qui
offre une solution simple à intégrer. En fin de compte, ce comportement de
scroll horizontal, c'est une sorte de ListView à défilement horizontal où une
cellule = un écran. C'est sur ce principe que se base cette api. Elle offre un
composant ViewFlow qui nécessite un BaseAdapter pour réaliser l'affichage de
chacun de ses écrans.&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
viewFlow = (ViewFlow) findViewById(R.id.viewflow);
viewFlow.setAdapter(new MonAdapter());
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
 &amp;lt;org.taptwo.android.widget.ViewFlow
                   android:id=&amp;quot;@+id/viewflow&amp;quot; 
                   android:layout_width=&amp;quot;fill_parent&amp;quot;
                   android:layout_height=&amp;quot;fill_parent&amp;quot; 
                   app:sidebuffer=&amp;quot;3&amp;quot;/&amp;gt;
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
Qu'est ce que ce sidebuffer ?&lt;br /&gt;
Il s'agit tout simplement du buffer des écrans chargés; ce qui permet de
fluidifier le scroll. Avec la valeur 3, j'aurai jusqu'à 3 écrans à droite, 3
écrans à gauche ainsi que mon écran actuel, soit 7 écrans, qui sont chargés et
en mémoire. Cette valeur, est à 3 par défaut.&lt;br /&gt;
&lt;br /&gt;
Et si j'ai besoin d'écouter le changement d'écran ?&lt;br /&gt;
Ca tombe bien, il existe un ViewSwitchListener&lt;br /&gt;
&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
viewFlow.setOnViewSwitchListener(new ViewSwitchListener() {
    public void onSwitched(View v, int position) {
        // Your code here
    }
});
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
Certains Home Android, affiche un indicateur de position afin de connaitre
celui sur lequel nous nous trouvons. View Flow for Android offre aussi cette
possibilité. A l'heure actuelle, il en existe 2&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Cercle&lt;/strong&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;pre&gt;
CircleFlowIndicator indic = (CircleFlowIndicator) findViewById(R.id.viewflowindic);
viewFlow.setFlowIndicator(indic);
&lt;/pre&gt;
&lt;p&gt;&lt;img src=&quot;http://1.bp.blogspot.com/-ufnDnKfkTgk/Td0QLOZBHDI/AAAAAAAAAG0/t7hhckjOww8/s320/flowCircle.png&quot; alt=&quot;&quot; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Texte&lt;/strong&gt;&lt;/li&gt;
&lt;/ul&gt;
&lt;pre&gt;
TitleFlowIndicator indicator = (TitleFlowIndicator) findViewById(R.id.viewflowindic);
indicator.setTitleProvider(myTitleProvider);
viewFlow.setFlowIndicator(indicator);
&lt;/pre&gt;
&lt;p&gt;&lt;img src=&quot;http://3.bp.blogspot.com/-vzA2vRQGlf4/Td0Qh8c4kRI/AAAAAAAAAG8/44Xe5m5789c/s320/flowTitle.png&quot; alt=&quot;&quot; /&gt;&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;
Je trouve cette api sympathique à utiliser, et espère y voir de nouvelles
fonctionnalités.&lt;br /&gt;
Comme beaucoup pour beaucoup de projet sur github, les contributions sont les
bienvenues, si vous avez des idées, n'hésitez pas.&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>CloudCamp chez Sfeir</title>
    <link>http://www.insideit.fr/post/2011/05/09/CloudCamp-chez-Sfeir</link>
    <guid isPermaLink="false">urn:md5:9d930f2bffdf35ee61c15ad8b4227dfa</guid>
    <pubDate>Mon, 09 May 2011 19:17:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Conférence</category>
        <category>BarCamp</category><category>cloud</category><category>cloudbees</category><category>jenkins</category>    
    <description>    &lt;p&gt;Hey, lecteur !&lt;br /&gt;
Qu'as tu de prévu à ton agenda ce 30 mai 2011 à partir de 18h30 ?&lt;br /&gt;
Si tu n'as rien, Sfeir te convie à un BarCamp spécial Cloud dans ses locaux à
Suresnes. Si tu n'es pas coutumier des barcamps, sache que c'est une &amp;quot;non
conférence ouverte&amp;quot;. C'est à dire qu'un ensemble personne toutes intéressées
par un même sujet s'isole dans un coin pour en discuter toutes ensemble.&lt;br /&gt;
Pour ce CloudCamp, nous aurons l'honneur d'avoir un invité de marque :
Kohsuke Kawaguchi. Et oui, lui le papa de Hudon/Jenkins qui travaille
actuellement chez Cloudbees sera là... Donc, une très bonne occasion,
d'échanger sur le cloud.&lt;br /&gt;
Comme à tout bon évènement geek, il y aura bien sûr des pizzas et des
boissons.&lt;br /&gt;
J'espère t'y voir.&lt;br /&gt;
Allez viens, les inscriptions, c'est par &lt;a href=&quot;http://barcamp.org/SFEIR-BarCamp&quot;&gt;ici&lt;/a&gt;&lt;br /&gt;&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Manipulation de la Remote Api GAE avec Guice/Objectify</title>
    <link>http://www.insideit.fr/post/2011/04/26/Manipulation-de-la-Remote-Api-GAE-avec-Guice/Objectify</link>
    <guid isPermaLink="false">urn:md5:f2bbc062a957c9b9d838aa5de0343ede</guid>
    <pubDate>Tue, 26 Apr 2011 10:09:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Cloud</category>
        <category>GAE</category><category>Guice</category><category>Objectify</category>    
    <description>    Avec la version 1.4.3 de app engine, arrive une api qui jusque là était
disponible seulement en python : la &lt;a href=&quot;http://code.google.com/intl/fr-FR/appengine/docs/java/tools/remoteapi.html&quot;&gt;remote
api&lt;/a&gt;. Celle çi permet de se connecter de façon sécurisée au datastore afin
d’y insérer des données par exemple.&lt;br /&gt;
La documentation, bien que courte, donne de bonnes explications sur la façon de
mettre en place. Mais, c’est le cas simple... Si au sein de mon application app
engine, j’ai mis en place Guice et &lt;a href=&quot;http://code.google.com/p/objectify-appengine/&quot;&gt;Objectify&lt;/a&gt;, je me retrouve
confronté à 2 problèmes :&lt;br /&gt;
1/ Pour fonctionner ma servlet doit être déclarée dans la configuration
Guice.&lt;br /&gt;
2/ Je manipule des objets métier géré par Objectify et non pas des
Entity.&lt;br /&gt;
&lt;br /&gt;
Imaginons je possède l'objet &amp;quot;métier&amp;quot; suivant :&lt;br /&gt;
&lt;br /&gt;
&lt;pre class=&quot;java&quot;&gt;
public class Hello {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
private String message;
private String name;
public Hello(){
}
public Hello(String message, String name) {
super();
this.message = message;
this.name = name;
}
// Getter &amp;amp; Setter/hascode/equals methods ...
}
&lt;/pre&gt;
&lt;br /&gt;
Je vais devoir modifier mon GuiceServletConfig pour la mapper avec la servlet.
Aussi une servlet déclarée doit Guice doit être un singleton.&lt;br /&gt;
&lt;br /&gt;
&lt;pre class=&quot;java&quot;&gt;
public class GuiceServletConfig extends GuiceServletContextListener {
@Override
protected Injector getInjector() {
return Guice.createInjector(new ServletModule() {
@Override
protected void configureServlets() {
bind(RemoteApiServlet.class).in(Singleton.class);
serve(&amp;quot;/remote_api&amp;quot;).with(RemoteApiServlet.class);
// D'autres bindings ou serve ...
}
});
}
}
&lt;/pre&gt;
&lt;br /&gt;
Le 1er problème est ainsi résolu.&lt;br /&gt;
Il ne me reste plus qu'à transformer mes Hello en Entity. Une petite ballade
dans le code source permet de trouver la solution.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;pre class=&quot;java&quot;&gt;
public static Entity helloToEntity(Hello hello) {
Objectify ofy = ObjectifyService.begin();
EntityMetadata&amp;lt;Hello&amp;gt; metadata = factory.getMetadataForEntity(hello);
return metadata.toEntity(hello, ofy);
}
&lt;/pre&gt;
&lt;br /&gt;
&lt;br /&gt;
Il ne reste plus qu'à écrire un petit batch d'alimentation :&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;pre class=&quot;java&quot;&gt;
public static void main(String[] args) throws IOException {
RemoteApiOptions options = new RemoteApiOptions()
.server(&amp;quot;maSuperApplication.appspot.com&amp;quot;, 443)
.credentials(&amp;quot;monEmailAMoi@gmail.com&amp;quot;, &amp;quot;monMotDePasse&amp;quot;);
RemoteApiInstaller installer = new RemoteApiInstaller();
installer.install(options);
List&amp;lt;Entity&amp;gt; hellos = Lists.newArrayList(helloToEntity(new Hello(&amp;quot;Hello&amp;quot;, &amp;quot;Nicolas&amp;quot;)),
helloToEntity(new Hello(&amp;quot;Bonjour&amp;quot;, &amp;quot;Vincent&amp;quot;)),
helloToEntity(new Hello(&amp;quot;Salut&amp;quot;, &amp;quot;Guillaume&amp;quot;)),
helloToEntity(new Hello(&amp;quot;Enchanté&amp;quot;, &amp;quot;M. Gendal&amp;quot;)));
try {
DatastoreService ds = DatastoreServiceFactory.getDatastoreService();
for (Entity hello : hellos) {
Key key = ds.put(hello);
System.out.println(&amp;quot;Hello key=&amp;quot; + key);
}
} finally {
installer.uninstall();
}
}
&lt;/pre&gt;
&lt;br /&gt;
&lt;br /&gt;
En console, nous obtiendrons :&lt;br /&gt;
&lt;pre&gt;
Hello key=Hello(3001)
Hello key=Hello(4001)
Hello key=Hello(1002)
Hello key=Hello(5001)
&lt;/pre&gt;
&lt;br /&gt;
Et dans l'interface web du datastore, nous voyons bien nos 4 Hellos :&lt;br /&gt;
&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;img border=&quot;0&quot; src=&quot;http://img23.imageshack.us/img23/7948/hellosao.png&quot; /&gt;&lt;/div&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Des rubis plein les nuages</title>
    <link>http://www.insideit.fr/post/2011/04/21/Des-rubis-plein-les-nuages</link>
    <guid isPermaLink="false">urn:md5:c92cb8134dbad0ea89a9c9dd17c0dd81</guid>
    <pubDate>Thu, 21 Apr 2011 10:09:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Cloud</category>
        <category>cloud</category><category>ruby</category><category>WMware</category>    
    <description>    Comme vous le savez certainement, WMware au travers de Cloud Foundry propose
son offre de cloud, mais pour le moment en bêta. Après une longue semaine
d'attente, j'ai enfin reçu mes crédentials.&lt;br /&gt;
C'est tourjours par un HelloWorld que commence bon nombre de tutoriaux, celui
que j'ai essayé n'échappe pas à cette règle.&lt;br /&gt;
Je vais vous faire part de ce petit essai que je trouve intéressant.&lt;br /&gt;
&lt;br /&gt;
En fait, il s'agit de la version Ruby que j'ai essayé. Je n'y connais rien en
Ruby, mais qu'à celà ne tienne, Hello c'est pas très compliqué.&lt;br /&gt;
Il faut tout d'abord s'assurer de ses version de Ruby et de gem :&lt;br /&gt;
&lt;pre&gt;
bash$ ruby -v
&lt;/pre&gt;
&lt;pre&gt;
bash$ gem -v
&lt;/pre&gt;
Ils doivent être respectivement en version 1.8.7 et 1.7.2. Il est possible que
gem ne soit pas à jour, dans ce cas, la commande suivante est à passer :&lt;br /&gt;
&lt;pre&gt;
bash$ sudo gem update --system
&lt;/pre&gt;
Vous pourrez ainsi installer la gem vmc :&lt;br /&gt;
&lt;pre&gt;
bash$ sudo gem install vmc
&lt;/pre&gt;
Ce qui permettra dans un premier temps de se connecter à son compte :&lt;br /&gt;
&lt;pre&gt;
bash$ vmc target api.cloudfoundry.com
Succesfully targeted to [http://api.cloudfoundry.com]
bash$ vmc login
Email: moiMail@mo.i
Password: ***********
Successfully logged into [http://api.cloudfoundry.com]
&lt;/pre&gt;
On a passé le coté configuration et prêt à déchainer la fureur du code.&lt;br /&gt;
&lt;pre&gt;
bash$ mkdir hello
bash$ cd hello/
bash$ nano hello.rb
&lt;/pre&gt;
&lt;br /&gt;
Chose promise, chose dûe, un hello tout simple :&lt;br /&gt;
&lt;br /&gt;
&lt;pre class=&quot;ruby&quot;&gt;
require &amp;quot;sinatra&amp;quot;
get '/' do
&amp;quot;Coucou les gens&amp;quot;
end
&lt;/pre&gt;
&lt;br /&gt;
Et voilà, on a fini la v1, il ne reste plus qu'à déployer, en répondant à
quelques questions :&lt;br /&gt;
&lt;pre&gt;
bash$ vmc push
Would you like to deploy from the current directory? [Yn]: Y
Application Name: nfrancois
Application Deployed URL: 'nfrancois.cloudfoundry.com'? y
Detected a Sinatra Application, is this correct? [Yn]: y
Memory Reservation [Default:128M] (64M, 128M, 256M, 512M, 1G or 2G)
Creating Application: OK
Would you like to bind any services to 'nfrancois'? [yN]:
Uploading Application:
Checking for available resources: OK
Packing application: OK
Uploading (0K): OK
Push Status: OK
Staging Application: OK
Starting Application: OK
&lt;/pre&gt;
&lt;br /&gt;
Aussitôt, dégainage du navigateur à l'url, et c'est déjà accessible :&lt;br /&gt;
&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;img src=&quot;http://img706.imageshack.us/img706/2580/hello1o.png&quot; /&gt;&lt;/div&gt;
&lt;br /&gt;
Mince j'ai oublié des gens importants :&lt;br /&gt;
&lt;br /&gt;
&lt;pre class=&quot;ruby&quot;&gt;
require &amp;quot;sinatra&amp;quot;
get '/' do
&amp;quot;Coucou les gens, surtout toi lecteur&amp;quot;
end
&lt;/pre&gt;
&lt;br /&gt;
Prêt à déployer ce correctif :&lt;br /&gt;
&lt;pre&gt;
bash$ vmc update nfrancois
Uploading Application:
Checking for available resources: OK
Packing application: OK
Uploading (0K): OK
Push Status: OK
Stopping Application: OK
Staging Application: OK
Starting Application: OK
&lt;/pre&gt;
&lt;br /&gt;
Un F5 suffit à vérifier :&lt;br /&gt;
&lt;br /&gt;
&lt;div class=&quot;separator&quot; style=&quot;clear: both; text-align: center;&quot;&gt;&lt;img src=&quot;http://img851.imageshack.us/img851/5669/hello2r.png&quot; /&gt;&lt;/div&gt;
&lt;br /&gt;
C'est ainsi que s'est déroulé mon premier essai de déploiement Cloud Foundry et
j'ai apprécié sa simplicité. C'est donc un bon point qui donne envie de
continuer à s'y intéresser car bien sûr pour s'en faire une bonne idée, il
reste de nombreuses choses à tester.&lt;br /&gt;
Dans le monde du Ruby dans le cloud, il existe aussi Heroku, assez apprécié me
semble t-il dans le monde ruby. Mais mes connaissances rubyste s'arrête là, je
ne saurais faire un comparatif des 2 offres.</description>
    
    
    
      </item>
    
  <item>
    <title>Ma journée à Mix It</title>
    <link>http://www.insideit.fr/post/2011/04/17/Ma-journ%C3%A9e-%C3%A0-Mix-It</link>
    <guid isPermaLink="false">urn:md5:dc95f923105088cac0370ae28bfd97f7</guid>
    <pubDate>Sun, 17 Apr 2011 03:05:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Conférence</category>
        <category>Mix-it</category>    
    <description>    Ce 5 avril 2011, s'est tenu le mix-it, conférence autour de java et de ses
pratiques, organisée par le Lyon JUG et Kara. Celle çi était articulée de 5
thèmes : Techy, Agility, Tendy, Mixy, Gamy.&lt;br /&gt;
Soit 25 sessions au total. J'étais parmis les 250 personnes qui s'y sont rendu.
Je vais vous faire une petite rétrospective de quelques sessions auxquelles
j'ai assisté au cours de cette belle journée.&lt;br /&gt;
&lt;br /&gt;
Nous étions quelques Parisiens, habitués du Paris JG, à s'être déplacé, dont
certains en temps que Speaker.&lt;br /&gt;
Et c'est justement par Nicolas Martignole que commence la traditionnelle
keynote, après une courte présentation de Objet Direct, principal sponsor de
d'évènement.&lt;br /&gt;
&lt;br /&gt;
&lt;span class=&quot;Apple-style-span&quot; style=&quot;font-size: large;&quot;&gt;Keynote&lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
Nicolas commence par une question, « Qui est fier ce qu'il a
réalisé ? ». Peu de monde, dans l'assistance lève la main. Cette question
a pour but d'amener au constant suivant : le plus important, ce n'est pas le
résultat mais le processus.&lt;br /&gt;
Il y a quelques années, on ne parlait pas de TDD, agilité, ni aucun terme
tendance auquel nous sommes aujourd'hui habitués. A la place, on parlait
d'architecture, d'UML, …&lt;br /&gt;
Nous n'avons plus la même façon de construire une application qu'autrefois (si
j'ose dire) : nous livrons régulièrement par exemple. Nicolas aime assez
la vision du craftmanship et nous expose 12 points du métier de développeur
aujourd'hui.&lt;br /&gt;
1/ Pattern de l'iceberg : le client ne voit que ¼ de ce qui se passe, il
est donc normal qu'il ne comprenne pas qu'une tache ait pris plus de temps que
ce qu'il n'imaiginait.&lt;br /&gt;
2/ Comprendre ce qui va changer à la fin : Imaginons que vous naviger dans
un bateau, vous préférez un point de rendez vous que vous recalculer chaque
jour en fonction des contraintes ou un point de rendez vous cap 180° et on se
revoit dans 10 jours ?&lt;br /&gt;
3/ Simplicité. Nous autre développeurs java, sommes de passionnés de technique
et inventons régulièrement de nouveaux frameworks. Mais tant de complexité et
elle nécessaire ?&lt;br /&gt;
4/ Itérer et avancer. Tout comme un musicien qui s'entraine, nous devons savoir
jeter du code, le mouvement est important.&lt;br /&gt;
5/ Vision du jardinier, savoir pensez long terme.&lt;br /&gt;
6/ Mouvement permanent. Il ne faut pas attendre mais savoir bouger, en faisant
de la veille par exemple.&lt;br /&gt;
7/ On ne dit pas de « Je fais de l'architecture » mais du « je
fais du code propre ». C'est implicite dans la réalisation
logicielle.&lt;br /&gt;
8/ Avoir le temps de se planter. C'est un avantage de l'agilité. Si au bout de
15 jours vous vous rendez compte ça passe. Mais si un cycle en V fait que vous
vous en rendez compte, les conséquence auprès du client de sont pas les
mêmes.&lt;br /&gt;
9/ Soyez sans pitié. Le code pourri ou en commentaire, il file tout droit à la
poubelle.&lt;br /&gt;
10/ Le client est roi (mais on est pas non plus sa mère). Avec lui, on ne parle
de qu'il connait : le métier, mais pas de techno. A l'inverse, ce n'est
pas à lui, d'imaginer la solution technique. Lorsque vous prenez l'avion,
donnez vous de conseils au pilote ?&lt;br /&gt;
11/ Gérer son manager. C'est en quelque sorte le ministre des affaires
étrangère, c'est lui gère les relations entre l'équipe et le monde extérieur.
S'il passe trop de temps à gérer l'équipe en elle même, c'est qu'il y a un
soucis.&lt;br /&gt;
12/ Nous sommes des développeurs. Nous ne voulons pas être chef, amusez
vous.&lt;br /&gt;
&lt;br /&gt;
&lt;span class=&quot;Apple-style-span&quot; style=&quot;font-size: large;&quot;&gt;Spock, les tests du
futur&lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
Mathilde Lemée, habituée du Paris JUG mais aussi une des fondatrices des
Duchess France, vient nous parler de Spock. Ce dernier, n'est pas qu'un
personnage de la série Star Trek, c'est aussi framework de test venu de la
galaxie Groovy.&lt;br /&gt;
Lorsque l'on écrit des tests, on a tendance à oublier leur partie
critique : la maintenance.&lt;br /&gt;
Spock se veut de rendre les tests lisibles, ce qui facilite grandement de
travail lorsque l'on refactore.&lt;br /&gt;
L'approche setup/expect/where ou given/when/then, facilitée par les labels,
permet de tester une seule chose à la fois. La première syntaxe est adaptée à
des cas de test simple type action/vérification du résultat. La seconde, elle
est plus adaptée à des cas complexe où par exemple, je vais devoir faire appel
à des éléments externes.&lt;br /&gt;
Il est important de différencier les mocks des stubs, ils n'ont pas les même
rôles. Le stub est un bouchon stupide. Il sert simplement à tester l'état, mais
n'a pas vocation à faire échouer le test. Au contraire, le mock peut faire
échouer le test, car on teste son comportement.&lt;br /&gt;
En terme de code, la différence est assez simple : sois je vérifie si mon
appel est bien effectué, soit je ne le fais pas.&lt;br /&gt;
Le problème posé par la sur utilisation des mocks, c'est que les tests casse au
moindre refactor et consomme du temps pour les réparer.&lt;br /&gt;
Martin Fowler apporte plus de précisions dans son &lt;a href=&quot;http://martinfowler.com/articles/mocksArentStubs.html&quot;&gt;article sur le
sujet&lt;/a&gt;.&lt;br /&gt;
Ce qu'apporte principal Spock aux tests, c'est une syntaxe plus souple.&lt;br /&gt;
&lt;br /&gt;
&lt;pre&gt;
def &amp;quot;account activation mail sent to user&amp;quot;(){
setup:
UserService userService = new UserService()
def emailService = Mock(EmailService)
emailService.sendMail(_,_,_,_) &amp;gt;&amp;gt; true
userService.emailService = emailService
User user = new User(email : &amp;quot;testUser@gmail&amp;quot;)
when:
boolean success = userService.sendActivationMail(user)
then:
1*.emailService.sendMail(&amp;quot;testUser@gmail&amp;quot;,&amp;quot;admin@admin.com&amp;quot;,&lt;br /&gt;       &amp;quot;Your account is activated&amp;quot;, &amp;quot;Congratulation now you can login&amp;quot;)
success == true
}
&lt;/pre&gt;
&lt;br /&gt;
Ce que l'on note :&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;Nom de méthode expressif et lisible&lt;/li&gt;
&lt;li&gt;Configuration simple du résultat de la méthode du mock grace à
&amp;gt;&amp;gt;&lt;/li&gt;
&lt;li&gt;Configuration simple de la vérification de l'appel du mock 1* …&lt;/li&gt;
&lt;li&gt;Pas d'assert sur le résultat, il est implicite&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
De façon globale, la syntaxe est assouplie grace aux bloc given/when/then qui
permettent d'éviter l'utilisation de mots clés, ce qui au final donne une
lecture plus naturelle des instructions.&lt;br /&gt;
&lt;br /&gt;
Cette lisibilité est accru dans le cadre de tests avec jeu de
données :&lt;br /&gt;
&lt;br /&gt;
&lt;pre&gt;
def &amp;quot;String param should correspond to numeric spockInfoDay&amp;quot;() {
setup:
def spockResource = new SpockResource(new CalendarDaoStatic())
expect:
spockResource.findCalendarByDay(day).day == dayNumeric
where:
day | dayNumeric
&amp;quot;1&amp;quot; | 1
&amp;quot;2&amp;quot; | 2
&amp;quot;3&amp;quot; | 3
}
&lt;/pre&gt;
&lt;br /&gt;
N'est ce pas plus plaisant à lire ?&lt;br /&gt;
&lt;br /&gt;
&lt;span class=&quot;Apple-style-span&quot; style=&quot;font-size: large;&quot;&gt;Intelligence
collective avec Apache Mahout&lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
Je suis allé sur ce sujet que je ne connais absolu pas, par curiosité. C'est
Michael Figuière qui nous a présenté à ce framework.&lt;br /&gt;
L'intelligence collective est supérieure à l'intelligence du plus intelligent.
Wikipedia est un exemple, il contient beaucoup plus de connaissance que
quiconque.&lt;br /&gt;
Aujourd'hui, internet permet d'agréger tout un tas de données. Page Rank agrège
par exemple l'intelligence collective des sites web. Ainsi, par de nombreux
liens, le site officiel de mix-it est la première réponse à la recherche
« mit it ».&lt;br /&gt;
Le machine learning est un concept clé de Apache Mahout. Il s'agit d'un sous
ensemble de l'intelligence artificielle. Les applications en sont par
exemple :&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;Recommandation à d'un livre à un client en fonction de ce qu'il a déjà
acheté ou de ce que les autres ont achetés en même temps.&lt;/li&gt;
&lt;li&gt;Classification automatique de mails en fonction de qui a déjà été
classé.&lt;/li&gt;
&lt;li&gt;Conseil de fonctionnalité : si un utilisateur ne s'en sert pas, peut
être qu'il ne la connait pas.&lt;/li&gt;
&lt;li&gt;Adapter filtrage en fonctionnalité du profil : quand je cherche un
livre sur java, faut il favoriser l'informatique ou les livres sur
l'ile ?&lt;/li&gt;
&lt;li&gt;Filtrage du spam&lt;/li&gt;
&lt;li&gt;Agreger un flux actualité en fonction des tendances.&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Pour nous, dans le domaine de l'informatique de gestion, ces concepts ne nous
sont pas familliés. C'est justement là qu'intervient Apache Mahout en
fournissant un implémentation java des algorithmes dernières ces concepts,
facilitant ainsi leur intégration dans nos applications. Un bonne partie de
cette implémentation est faite en Map/Reduce. Le framework est encore jeune
mais connait une croissance rapide.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;span class=&quot;Apple-style-span&quot; style=&quot;font-size: large;&quot;&gt;Pimp my
app&lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
Pour finir en épanadiplose, je finis ma journée par la présentation de Nicolas
Martignole sur Play.&lt;br /&gt;
Quelques éléments pour moderniser une dans un navigateur web tout en
s'amusant :&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;Html5/css3/jquery&lt;/li&gt;
&lt;li&gt;Play&lt;/li&gt;
&lt;li&gt;Huile de coude&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Play! est développé à la base par Guillaume Bord, une personne du monde du web
et de Ruby, et donc qui pas connu les joies des EJB 2. Devant la complexité du
développement web en java, il a voulu réconcilier les 2 mondes en récréant ce
qu'il connaissait avec Rails.&lt;br /&gt;
Tout d'abord, Play! n'utilise pas l'api servlet, est sans état sur le serveur.
Choses banale dans d'autres technos utilisés pour faire du web. C'est justement
sur Rails, Django et Grails que vient sont inspiration.&lt;br /&gt;
Avec Play! devient facile de développer rapidement une idée, ainsi moins de
scrupules à jeter du code si l'on est pas satisfait. Un des aspect qui permette
sa simplicité, c'est son absence de session coté serveur et qui va en
adéquation avec les principes de REST.&lt;br /&gt;
C'est un framework fullstack, je fais tous avec lui : écriture de code,
compilation, test et déploiement. Tous ça au sein de son environnement. Pour
éviter d'être prisonnier de son serveur, on peut même packager en war et
déployer sur un serveur d'application, bien que l'esprit de soit un peu perdu
dans ce cas.&lt;br /&gt;
Nicolas nous explique que la question de se poser l'utilisation chez le client
et la même que celle qui se posait il a 5 ans, à savoir si on peut utiliser
Play.&lt;br /&gt;
Et bientôt, avec la version 1.2 on pourra piocher des dépendances avec modules
Ivy.&lt;br /&gt;
Pour le moment, un ses points faibles c'est l'industrialisation des
développements.&lt;br /&gt;
&lt;br /&gt;
Un projet Play à la même structure qu'un projet Ruby :&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;src : les sources aussi bien java que html&lt;/li&gt;
&lt;li&gt;test&lt;/li&gt;
&lt;li&gt;conf : la configuration telle que le routage ou les propriétés&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Nous avons le droit à une live démo :&lt;br /&gt;
&lt;ul&gt;
&lt;li&gt;La classe de base qui est un point d'entrée du controller.&lt;/li&gt;
&lt;li&gt;La page htlml, est du script groovy&lt;/li&gt;
&lt;li&gt;Oh mais on pas recompilé et ça marche.&lt;/li&gt;
&lt;li&gt;En mode dev, Play surveille les fichiers et recompile quand il faut, on
laisse ainsi tourner le serveur tout en codant&lt;/li&gt;
&lt;li&gt;La trace d'erreur est lisible, ça fait gagner beaucoup de temps.&lt;/li&gt;
&lt;li&gt;Utilisation d'un cookie pour gérer l'état conversationnel avec des
cookies.&lt;/li&gt;
&lt;li&gt;Pas de session sur le serveur&lt;/li&gt;
&lt;/ul&gt;
&lt;br /&gt;
Les 2 derniers points nous pousse à avoir une architecture différente.&lt;br /&gt;
&lt;br /&gt;
Niveau graphique, un inconvéniant, c'est qu'il n'y a rien, il faut retourner
aux bases : grande utilisation du css et js.&lt;br /&gt;
Cela dit, sur ces 2 domaines en cas de problèmes ont peut toujours trouver de
l'aide, venant même d'autre communautés comme php et rails.&lt;br /&gt;
Pas un peu de code css3, Nicolas nous montre comment embellir sa partie web en
ayant par exemple un bouton full-css, de l'ombrage, ….&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Cette conférence a été une belle réussite. Aussi, j'ai ouïe dire qu'elle avait
été organisées en très peu de temps. Je profite donc de ce billet pour
féliciter donc les responsables de celle ci et espère une prochaine édition
l'année prochaine. Il est plaisant de voir que les communautés dans toutes la
France se bougent pour nous monter de beaux événements à bas coût. Le prochain
rendez vous sera le Breizh camp.</description>
    
    
    
      </item>
    
  <item>
    <title>Du Jersey, du Guice et de l'App Engine 3/3</title>
    <link>http://www.insideit.fr/post/2011/04/16/Du-Jersey%2C-du-Guice-et-de-l-App-Engine-3/3</link>
    <guid isPermaLink="false">urn:md5:15807fcf734b9bcdee201ff6b9875315</guid>
    <pubDate>Sat, 16 Apr 2011 14:50:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>GAE</category><category>Guice</category><category>Jersey</category><category>REST</category>    
    <description>    &lt;p&gt;Et pour finir cette série d'article, nous allons nous intéresser à la
génération de JSon avec Jersey et bien sûr à sa testabilité.&lt;/p&gt;
&lt;p&gt;Le xml, c'est bien gentil, mais dans des échanges REST ça peut être un peu
lourd, surtout si le consommateur est un appareil mobile. La génération JSon
avec Jersey peut s'appuyer sur JAX-B. Et oui, c'est justement pour cela que
l'on s'en est occupé dans le précédant article. Le mapping, lui, ne change
pas.&lt;/p&gt;
&lt;p&gt;La resource ne nécessite qu'un petit changement :&lt;/p&gt;
&lt;pre&gt;
 @GET
 @Path(&amp;quot;{name}&amp;quot;)
 @Produces({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML}) 
 public Hello reply(@PathParam(&amp;quot;name&amp;quot;) String name){
  return helloService.saysHelloToSomeone(name);
 }
&lt;/pre&gt;
&lt;p&gt;Comme on est sympa, on permet de renvoyer soit du Json, soit du Xml, c'est
le consommateur qui décide. Par défaut, c'est le 1er format qui est choisit,
soit le JSon.&lt;/p&gt;
&lt;p&gt;La génération JSon va nécessiter un peu de configuration, principalement à
cause du &lt;a href=&quot;http://jersey.java.net/nonav/documentation/latest/json.html#d4e948&quot;&gt;type de
JSon généré&lt;/a&gt;. C'est le &lt;em&gt;ContextResolver&lt;/em&gt; qui va s'occuper de
ça :&lt;/p&gt;
&lt;pre&gt;
@Provider
@Singleton
public class JAXBContextResolver implements ContextResolver&amp;lt;JAXBContext&amp;gt; {

 /** Package that contains object that can be mapped */
 private static final String JAXB_OBJECT_PACKAGE = Hello.class.getPackage().getName();

 private final JAXBContext context;

 public JAXBContextResolver() throws Exception {
  this.context = new JSONJAXBContext(JSONConfiguration.natural().build(), 
                                     JAXB_OBJECT_PACKAGE);
 }

 @Override
 public JAXBContext getContext(Class&amp;lt;?&amp;gt; objectType) {
  if(objectType.getPackage().getName().equals(JAXB_OBJECT_PACKAGE)){
   return context;
         }
  return null;
 }
}
&lt;/pre&gt;
&lt;p&gt;Ici le type de JSon souhaité est le &lt;em&gt;natural&lt;/em&gt;. Cet objet doit être
passés dans le même package que les resources, il profitera ainsi lui aussi de
la découverte automatique au démarrage de Guice. Ce resolver n'est pas
obligatoire, sans lui, le JSon généré est par défaut en mode mapped.&lt;/p&gt;
&lt;p&gt;La configuration des tests, va devoir évoluer un peu pour prendre en compte
notre génération en ode natural. La méthode &lt;em&gt;configure()&lt;/em&gt;
devient :&lt;/p&gt;
&lt;pre&gt;
@Override
 protected AppDescriptor configure() {
  ClientConfig clientConfig = new DefaultClientConfig();
  clientConfig.getClasses().add(JAXBContextResolver.class);
  injector = Guice.createInjector(new ServletModule() {
   @Override
   protected void configureServlets() {
    bind(getTestingResourceClass());
    bind(JAXBContextResolver.class);
    serve(&amp;quot;/*&amp;quot;).with(GuiceContainer.class);
   }
  }); 
  return new WebAppDescriptor.Builder()
           .contextListenerClass(GuiceTestConfig.class)
           .filterClass(GuiceFilter.class)
           .clientConfig(clientConfig)
           .servletPath(&amp;quot;/&amp;quot;)
           .build();
 }
&lt;/pre&gt;
&lt;p&gt;Ainsi du coté serveur comme du coté client, les échanges seront dans le même
format. Nos tests deviendront :&lt;/p&gt;
&lt;pre&gt;
@Test
 public void shoulReplyHelloInXml(){
  doShoulReplyHello(MediaType.APPLICATION_XML_TYPE);
 }
 
 @Test
 public void shoulReplyHelloInJson(){
  doShoulReplyHello(MediaType.APPLICATION_JSON_TYPE);
 } 
 
 private void doShoulReplyHello(MediaType type){
  String message = &amp;quot;Hello&amp;quot;;
  String name =&amp;quot;Nicolas&amp;quot;;
  Hello hello = new Hello(message, name);
  when(helloServiceMock.saysHelloToSomeone(&amp;quot;Nicolas&amp;quot;)).thenReturn(hello);
  
  ClientResponse response = resource().path(&amp;quot;hello&amp;quot;).path(name)
                                      .accept(type).get(ClientResponse.class);
  
  verify(helloServiceMock).saysHelloToSomeone(name);
  assertThat(response.getClientResponseStatus()).isEqualTo(Status.OK);
  assertThat(response.getType()).isEqualTo(type);
  Hello entity = response.getEntity(Hello.class);
  assertThat(entity).isNotNull().isEqualTo(hello);  
  
 } 
&lt;/pre&gt;
&lt;p&gt;Une des différenciation entre les types de JSon générés se fait sur la façon
dont sont écrites les listes. En mode natural, nous avons par exemple :
&lt;a href=&quot;http://www.insideit.fr/post/2011/04/16/Du-Jersey%2C-du-Guice-et-de-l-App-Engine-3/objet1,%20objet2,%20...&quot; title=&quot;objet1, objet2, ...&quot;&gt;objet1, objet2,
...&lt;/a&gt; avec des objet {&amp;quot;attributA&amp;quot;:&amp;quot;valeurA&amp;quot;, ....}&lt;/p&gt;
&lt;p&gt;Imaginons que nous avons une autre ressource qui par grande politesse
retourne 2 Hellos :&lt;/p&gt;
&lt;pre&gt;
@Path(&amp;quot;doublehello&amp;quot;)
@Singleton
@Produces({MediaType.APPLICATION_JSON, MediaType.APPLICATION_XML})
public class DoubleHelloResource {
 
 @Inject
 private HelloService helloService;
 
 @GET
 @Path(&amp;quot;/{name}&amp;quot;)
 public List&amp;lt;Hello&amp;gt; reply(@PathParam(&amp;quot;name&amp;quot;) String name){
  List&amp;lt;Hello&amp;gt; hellos = new ArrayList&amp;lt;Hello&amp;gt;();
  hellos.add(helloService.saysHelloToSomeone(name));
  hellos.add(helloService.saysHelloToSomeone(name));
  return hellos;
 }
 
}
&lt;/pre&gt;
&lt;p&gt;Pour vérifier sa bonne génération, nous aurions le test suivant :&lt;/p&gt;
&lt;pre&gt;
@Test
 public void shoudHaveTwoHello(){
  String message = &amp;quot;Hello&amp;quot;;
  String name =&amp;quot;Nicolas&amp;quot;;
  when(helloServiceMock.saysHelloToSomeone(&amp;quot;Nicolas&amp;quot;))
                        .thenReturn(new Hello(message, name)); 
  ClientResponse response = resource().path(&amp;quot;doublehello&amp;quot;).path(name)
                                      .get(ClientResponse.class);
  assertThat(response.getStatus()).isEqualTo(Status.OK.getStatusCode());
  assertThat(response.getType()).isEqualTo(MediaType.APPLICATION_JSON_TYPE);
  List&amp;lt;hello&amp;gt; hellos = response.getEntity(new GenericType&amp;lt;List&amp;lt;Hello&amp;gt;&amp;gt;(){});
  assertThat(hellos).isNotNull().hasSize(2);
 }
 
 @Test
 public void shoudBeInNaturalJson(){
  String message = &amp;quot;Hello&amp;quot;;
  String name =&amp;quot;Nicolas&amp;quot;;
  when(helloServiceMock.saysHelloToSomeone(&amp;quot;Nicolas&amp;quot;))
                                .thenReturn(new Hello(message, name)); 
  ClientResponse response = resource().path(&amp;quot;doublehello&amp;quot;).path(name)
                                      .get(ClientResponse.class);
  assertThat(response.getStatus()).isEqualTo(Status.OK.getStatusCode());
  assertThat(response.getType()).isEqualTo(MediaType.APPLICATION_JSON_TYPE);
  String hellos = response.getEntity(String.class);
  assertThat(hellos).isEqualTo(naturalHelloJSon(message, name));
 }
 
 public String naturalHelloJSon(String message, String name){
  StringBuilder sb = new StringBuilder();
  sb.append(&amp;quot;[{\&amp;quot;message\&amp;quot;:\&amp;quot;&amp;quot;).append(message)
    .append(&amp;quot;\&amp;quot;,\&amp;quot;name\&amp;quot;:\&amp;quot;&amp;quot;).append(name).append(&amp;quot;\&amp;quot;},&amp;quot;);
  sb.append(&amp;quot;{\&amp;quot;message\&amp;quot;:\&amp;quot;&amp;quot;).append(message)
    .append(&amp;quot;\&amp;quot;,\&amp;quot;name\&amp;quot;:\&amp;quot;&amp;quot;).append(name).append(&amp;quot;\&amp;quot;}]&amp;quot;);
  return sb.toString();
 }
&lt;/pre&gt;
&lt;p&gt;Même s'il est un format intéressant, le JSon souffre d'un problème lié au
javascript : celui du cross-domain qui fait que l'on ne peut pas
interroger un autre domain que celui de la page web. &amp;lt;a
href=&amp;quot;http://en.wikipedia.org/wiki/JSONP&amp;quot;&amp;gt;JSonP&amp;lt;/a&amp;gt; permet d'évincer
cette contrainte.&lt;/p&gt;
&lt;p&gt;Jersey permet aussi de générer ce type de réponse mais un peu moins
facilement. Nous allons créer une nouvelle méthode pour ce type de
réponse :&lt;/p&gt;
&lt;pre&gt;
 @GET
 @Path(&amp;quot;{name}.jsonp&amp;quot;)
 @Produces(&amp;quot;application/x-javascript&amp;quot;)
 public JSONWithPadding replyWithJsonP(@PathParam(&amp;quot;name&amp;quot;) String name,
           @QueryParam(&amp;quot;callback&amp;quot;) @DefaultValue(CALLBACK_DEFAULT_NAME) String callback){
  Hello hello = helloService.saysHelloToSomeone(name);
  return new JSONWithPadding(hello, callback);
 } 
&lt;/pre&gt;
&lt;p&gt;Son test reste dans l'optique des précédents :&lt;/p&gt;
&lt;pre&gt;
@Test
 public void shoudBeJsonpWithCallbackNameParam(){
  String message = &amp;quot;Hello&amp;quot;;
  String name =&amp;quot;Nicolas&amp;quot;;
  when(helloServiceMock.saysHelloToSomeone(&amp;quot;Nicolas&amp;quot;)).thenReturn(new Hello(message, name));
  String callbackName = &amp;quot;monCallback&amp;quot;;
  
  ClientResponse response = resource().path(&amp;quot;hello&amp;quot;).path(name+&amp;quot;.jsonp&amp;quot;)
                                      .queryParam(&amp;quot;callback&amp;quot;, callbackName)
                                        .get(ClientResponse.class);
  assertThat(response.getStatus()).isEqualTo(Status.OK.getStatusCode());
  assertThat(response.getType().toString()).isEqualTo(&amp;quot;application/x-javascript&amp;quot;);
  assertThat(response.getEntity(String.class)).isNotNull().startsWith(callbackName);
 }
&lt;/pre&gt;
&lt;p&gt;Je n'ai pas malheureusement pas trouvé comment unmarshmaller ce message.&lt;/p&gt;
&lt;p&gt;Et voilà, ce tour d'horizon est fini, amusez vous bien avec ces quelques
technos. Comme à chaque fois, le code source est &lt;a href=&quot;https://github.com/nfrancois/PocJerseyJaxBJsonGuiceAppEngine&quot;&gt;disponible&lt;/a&gt;&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>1er anniversaire des Duchess France</title>
    <link>http://www.insideit.fr/post/2011/04/15/1er-anniversaire-des-Duchesses-France</link>
    <guid isPermaLink="false">urn:md5:20e6328b8d59e123862eafc283071445</guid>
    <pubDate>Fri, 15 Apr 2011 02:05:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Duchesse</category><category>Java</category>    
    <description>    &lt;p&gt;C'est ce 14 avril que s'est tenu le 1er anniversaire des Duchess
France.&lt;br /&gt;
Pour ceux qui n'ont pas suivi, non la noblesse n'a pas été rétablie en France.
Il s'agit d'un groupe principalement composé de filles et qui oeuvre pour
donner plus de visibilité aux femmes dans le milieu informatique; et bien sûr
pas en gestion de projet, mais dans la technique.&lt;br /&gt;
&lt;br /&gt;
A l'arrivée, nous recevons notre badge ainsi qu'un classique petit
questionnaire : comment avez vous connu les Duchesses ? Quelle thèmes
souhaiteriez voir traité .... A remettre dans une urne, car il pourra faire
gagner l'un des lots offerts par les Sponsors. Tout les badges sont marqués
d'une petite forme colorée. Quelle est sa signification ? C'est en
rentrant dans l'amphithéâtre que la question trouve sa réponse : Nous
sommes placés d'après la couleur de gommette. Et c'est ainsi que sont faites
les équipes du Trivial Java, ainsi pas de jaloux dans la formation de ces
dernières.&lt;br /&gt;
La soirée commence par une traditionnelle présentation, ce sont elles/qui elles
ne sont pas, quel est le but ?, .... On connaissait déjà les avant-JUG, les
groupes de préparation à la certification et bientôt s'annonce un nouvel
événement : la marmite ! Mais qu'est ce donc ? Il s'agira d'une
rencontre type coding dojo &amp;quot;main dans le code&amp;quot; (ou plutôt dans la
marmite).&lt;br /&gt;
Après quelques remaniement de certaines couleurs en sous effectif, le jeu peu
vraiment commencer. Les règles sont assez simples, chaque équipe envoi un
représentant répondre à une série de question sur un thème comme le code java,
la veille techno, les frameworks et même l'histoire geeko-javaïste. Des
questions bien tordue, notamment sur le code java.&lt;br /&gt;
C'est après quelques séries de questions qu'a lieu la pause buffet bien méritée
après ces efforts. Celle-çi est l'occasion de discuter avec les diverses
connaissances présentes.&lt;br /&gt;
Au retour ce celui ci a lieu le tant attendu tirage au sort permettant de
gagner les cadeaux offerts par les sponsors (dont Sfeir fait bien sûr parti).
Parmi ces lots : un ipad2 (d'ailleurs remporté par une Sferienne :
&lt;a href=&quot;http://twitter.com/yasaite&quot;&gt;Yasmine Aite&lt;/a&gt;), des formations, des
pass parleys, .... ainsi qu'un &amp;quot;cadeau surprise&amp;quot; qui se révélât être la fameuse
Barbie informaticienne qui avait fait le buzz l'année dernière, remportée par
&lt;a href=&quot;http://twitter.com/bargenson&quot;&gt;Brice Argenson&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;&lt;img src=&quot;http://www.insideit.fr/public/AnniversaireDuchesses/.BriceEtBarbie_m.jpg&quot; alt=&quot;BriceEtBarbie.jpg&quot; title=&quot;BriceEtBarbie.jpg, avr. 2011&quot; /&gt;&lt;/p&gt;
&lt;p&gt;La seconde parti reprend sur la lancée de la 1ère partie. Pour ce terminer,
sur une égalité entre les verts foncés et les ciels. Pour les départager, c'est
un duel entre &lt;a href=&quot;http://twitter.com/JulienDubois&quot;&gt;Julien Dubois&lt;/a&gt; et
&lt;a href=&quot;http://twitter.com/cbe317&quot;&gt;Cédric Beurtheret&lt;/a&gt; sur une question de
rapidité qui tranchera. C'est Spock (le framework de test) qui emmènera les
verts foncés à la victoire par la réponse de Cédric. Leur équipe s'est vue
remettre un mug aux couleurs des Duchess.&lt;br /&gt;&lt;/p&gt;
&lt;p&gt;&lt;img src=&quot;http://www.insideit.fr/public/AnniversaireDuchesses/.vainqueur_m.jpg&quot; alt=&quot;vainqueur.jpg&quot; title=&quot;vainqueur.jpg, avr. 2011&quot; /&gt;&lt;/p&gt;
&lt;p&gt;Pour les plus chevronnés, la soirée se termine par une traditionnelle 3ème
mi-temps autour d'une pizza.&lt;br /&gt;&lt;/p&gt;
&lt;p&gt;Félicitations aux duchesses pour cette belle soirée avec une très bonne
animation. En attendant le prochain anniversaire, nous espérons de bonnes
marmites pleines de bonnes technos auxquelles nous voulons tous gouter.&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Du Jersey, du Guice et de l'App Engine 2/3</title>
    <link>http://www.insideit.fr/post/2011/04/08/Du-Jersey%2C-du-Guice-et-de-l-App-Engine-2/3</link>
    <guid isPermaLink="false">urn:md5:a19f50f92ad85a6bf2cfde3c0a3dc4e8</guid>
    <pubDate>Sun, 10 Apr 2011 12:39:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>app engine</category><category>Jersey</category><category>REST</category><category>Test</category>    
    <description>    &lt;p&gt;Dans le dernier article, nous disposions d'un service Hello World qui
renvoyait du texte brut. Cette fois, nous allons lui ajouter la capacité à
répondre du xml en sérialisant le message avec JAX-B.&lt;/p&gt;
&lt;p&gt;Tout d'abord, notre nouvelle réponse sera faite par l'objet
suivant :&lt;/p&gt;
&lt;pre&gt;
XmlRootElement
@XmlAccessorType(XmlAccessType.FIELD)
public class Hello {
 
 private String message;
 private String name;
 
 public Hello(){
 }
 
 public Hello(String message, String name) {
  super();
  this.message = message;
  this.name = name;
 }
 
 public String getMessage() {
  return message;
 }
 
 public void setMessage(String message) {
  this.message = message;
 }
 
 public String getName() {
  return name;
 }
 
 public void setName(String name) {
  this.name = name;
 }
 
 @Override
 public int hashCode() {
  return Objects.hashCode(message, name);
 }
 
 @Override
 public boolean equals(Object obj) {
     if(obj instanceof Hello){
         final Hello other = (Hello) obj;
         return Objects.equal(message, other.message)
             &amp;amp;&amp;amp; Objects.equal(name, other.name);
     } else{
         return false;
     }
 }
}
&lt;/pre&gt;
&lt;p&gt;La ressource exposée évolue peu :&lt;/p&gt;
&lt;pre&gt;
Path(&amp;quot;hello&amp;quot;)
@Singleton
@Produces(MediaType.APPLICATION_XML)
public class HelloResource {
 
 @Context 
 UriInfo uriInfo; 
 
 @Inject
 private HelloService helloService;
 
 @GET
 @Path(&amp;quot;/{name}&amp;quot;)
 public Hello reply(@PathParam(&amp;quot;name&amp;quot;) String name){
  return helloService.saysHelloToSomeone(name);
 }

 @POST
 public Response send(String name){
  Hello hello = helloService.sendHello(name);
  URI uri = uriInfo.getAbsolutePathBuilder().build();
  return Response.created(uri).entity(hello).build();
 }  
 
 
 public void setHelloService(HelloService helloService) {
  this.helloService = helloService;
 }
 
}
&lt;/pre&gt;
&lt;p&gt;Les opérations de marshall/unmarshall sont opérées directement par Jersey
lui même.&lt;/p&gt;
&lt;p&gt;De même, les tests vont peu évoluer, seul le type de données attendu va
changer. Nous aurons par exemple :&lt;/p&gt;
&lt;pre&gt;
@Test
 public void shoulReplyHello(){
  String name =&amp;quot;Nicolas&amp;quot;;
  String hello = &amp;quot;Hello &amp;quot;+name;
  when(helloServiceMock.saysHelloToSomeone(name)).thenReturn(hello);
  
  ClientResponse response = resource().path(&amp;quot;hello&amp;quot;).path(name).get(ClientResponse.class);
  
  verify(helloServiceMock).saysHelloToSomeone(name);
  assertThat(response.getClientResponseStatus()).isEqualTo(Status.OK);
  assertThat(response.getType()).isEqualTo(MediaType.TEXT_PLAIN_TYPE);
  assertThat(response.getEntity(String.class)).isEqualTo(&amp;quot;Hello Nicolas&amp;quot;);
  
 }
&lt;/pre&gt;
&lt;p&gt;Et c'est tout, pour aujourd'hui ...&lt;/p&gt;
&lt;p&gt;Bon ok, je reconnais, c'est un peu l'arnaque cet article, il y a peu de
choses à faire. Mais n'est ce pas justement ça qui est intéressant,
non ?&lt;/p&gt;
&lt;p&gt;La prochaine fois, nous terminerons cette ballade autour de Jersey en
générant du JSon.&lt;/p&gt;
&lt;p&gt;Le code est disponible &lt;a href=&quot;http://github.com/nfrancois/PocJerseyJaxBGuiceAppEngine&quot;&gt;ici&lt;/a&gt;.&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Intégration du SDK Facebook dans une application Android</title>
    <link>http://www.insideit.fr/post/2011/04/05/Int%C3%A9gration-du-SDK-Facebook-dans-une-application-Android</link>
    <guid isPermaLink="false">urn:md5:756efc2e8e57f967eff0ec3848029ec5</guid>
    <pubDate>Tue, 05 Apr 2011 17:28:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Android</category>
        <category>Android</category><category>BOF</category><category>Facebook</category>    
    <description>    &lt;p&gt;Cet article est une version écrite de la &lt;a href=&quot;http://docs.google.com/present/view?id=0AX5OB7HMRFTQZDR3czVwal8xNThkendteHBtNQ&quot;&gt;
présentation&lt;/a&gt; que j'ai pu faire au BOF dernier de Sfeir.&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Pourquoi ?&lt;/h2&gt;
&lt;p&gt;Faire connaitre son application est une problématique courante auquel est
confronté le développeur Android. Donner un aspect &amp;quot;social&amp;quot; à son application
peut être une solution. Facebook est aujourd'hui une référence absolue en
matière de réseau social et peut donc contribuer à répondre à cette
problématique grace aux services qu'ils expose pour les développeurs. Voici
quelles fonctionnalités qui pourrait donner la dimension sociale
voulue :&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Publier sur son mur : exprimer son avis.&lt;/li&gt;
&lt;li&gt;Organisation d'évènements et inviter des amis à y participer&lt;/li&gt;
&lt;li&gt;Checkins : marquer sa position&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Néanmoins l'intégration de Facebook dans une application Android peut
susciter une certaine crainte de la part des utilisateurs :&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Si je dois m'authentifier au travers de l'application, n'y a t-il pas un
risque qu'on me vole mes identifiants ? De plus, le fait de devoir me
rentrer mes identifiants va certainement freiner l'envie de l'utilisateur de
s'exprimer&lt;/li&gt;
&lt;li&gt;Cette application ne risque t-elle pas de d'acceder à mes informations pour
les renvendre et ma boite mail va être innondées de spam ?&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Quoi ?&lt;/h2&gt;
&lt;p&gt;Le SDK Facebook constitue une solution pour le développeur Android. En
s'appuyant sur l'application officielle, la connexion est ainsi quasiment
invisible. Celle çi fait seulement valider à l'application les droits dont
dispose l'application sur le compte de l'utilisateur.&lt;/p&gt;
&lt;p&gt;Ce SDK n'est qu'un simple adaptateur entre du code en java et la &lt;a href=&quot;http://developers.facebook.com/docs/reference/api&quot;&gt;Graph API&lt;/a&gt;. Né dans
l'esprit de Mark Zuckerberg, elle permet d'accéder et d'interagir avec les
données Facebook. En terme plus courant, c'est simplement un ensemble de
services REST produisant du JSon.&lt;/p&gt;
&lt;p&gt;Imaginons que je souhaite publier sur mon mur, la documentation nous
donne :&lt;/p&gt;
&lt;p&gt;&lt;img src=&quot;http://img823.imageshack.us/img823/5508/feedme.png&quot; alt=&quot;&quot; /&gt;&lt;/p&gt;
&lt;p&gt;La requête à adresser sera : &lt;em&gt;me/feed&lt;/em&gt; Et nécessitera
l'autorisation de publication de flux.&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Comment ?&lt;/h2&gt;
&lt;p&gt;Tout d'abord, il faut télécharger le &lt;a href=&quot;http://github.com/facebook/facebook-android-sdk&quot;&gt;SDK&lt;/a&gt;. Celui fonctionnant
sur le principe d'une &lt;a href=&quot;http://developer.android.com/guide/developing/projects/projects-eclipse.html&quot;&gt;library
android&lt;/a&gt;, il suffit d'ajouter la dépendance nécessaire. Le SDK est fourni
avec quelques exemples de manipulation de l'api. Il faudra aussi enregistrer
son application sur Facebook. Déclarez vous en tant que développeur en donnant
votre numéro de téléphone si cela n'est pas déjà le cas. La déclaration de
l'application permettra permettra d'obtenir un identifiant d'application. Celui
ci sera utilisé dans le code Android. Et pour finir la dernière étape : la
création de la clé d'après le certificat qui signe l'apk :&lt;/p&gt;
&lt;pre&gt;
keytool -exportcert -alias monApplication -keystore ~/.android/monApplication.keystore | openssl sha1 -binary | openssl base64
&lt;/pre&gt;
&lt;p&gt;Pour les utilisateurs de Windows, il est recommandé de passer par un outil
comme cygwin pour éviter des problèmes de génération avec openssl.&lt;/p&gt;
&lt;p&gt;Sans cette clé configuré, il sera impossible à l'application d'accéder aux
services Facebook. L'avantage est que même si le code Android est décompilé, il
sera impossible d'utiliser le compte de l'application. L'inconvénient est que
pour tester le bon fonctionnement, il faudra générer un apk signé à chaque fois
que ce soit pour un téléphone, ou sur l'émulateur.&lt;/p&gt;
&lt;p&gt;Il ne reste plus qu'à coder&lt;/p&gt;
&lt;p&gt;Si votre application ne possède pas le droit d'accès à internet, n'oublier
pas de le rajouter dans le fichier &lt;em&gt;AndroidManifest&lt;/em&gt;.&lt;/p&gt;
&lt;pre&gt;
&amp;lt;uses-permission android:name=&amp;quot;android.permission.INTERNET&amp;quot;/&amp;gt;
&lt;/pre&gt;
&lt;p&gt;La majeure partie du SDK est rassemblée dans l'objet &lt;em&gt;Facebook&lt;/em&gt; Pour
instancier cet objet, il suffit de lui passer en paramètre l'identifiant de
l'application.&lt;/p&gt;
&lt;pre&gt;
private static final Facebook mFacebook = new Facebook(FACEBOOK_APP_ID);
&lt;/pre&gt;
&lt;p&gt;Un aspect primordial dans une application Android est la gestion asynchrone
des tâches dès lors que l'on execute.&lt;/p&gt;
&lt;pre&gt;
private static final AsyncFacebookRunner mAsyncFacebookRunner = 
                                         new AsyncFacebookRunner(mFacebook);
&lt;/pre&gt;
&lt;p&gt;Lors sa tentative de connexion, le SDK envoie un intent à l'application
officielle Facebook. Il est donc important de spécifier le code retour que
devra avoir de cette activité, surtout si la votre utilise aussi ce
mécanisme.&lt;/p&gt;
&lt;pre&gt;
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
   if(requestCode == FACEBOOK_REQUEST_CODE){// Retour de login facebook
      FacebookFunctions.handleLoginResult(resultCode, data);      
   }
}
&lt;/pre&gt;
&lt;p&gt;C'est lors de la demande de connexion que sera passé ce code retour. Cette
demande doit aussi spécifier quelles sont les permissions requises par
l'application.&lt;/p&gt;
&lt;pre&gt;
private static final String PUBLISH_PERMISSION = &amp;quot;publish_stream&amp;quot;;
private static final String[] PERMISSIONS = new String[] { PUBLISH_PERMISSION };
mFacebook.authorize(activity, PERMISSIONS, facebookRequestCode, new LoginDialogListener());
&lt;/pre&gt;
&lt;p&gt;Quant à l'action de publication sur le mur, c'est une simple wrapping de
requête web :&lt;/p&gt;
&lt;pre&gt;
public static void publishCommentOnWall(String comment, PocRequestListener requestListener){
   final Bundle parameters = new Bundle();
   parameters.putString(GP_LINK_PARAM_FEED, ANDROID_URL);
   parameters.putString(GP_NAME_PARAM_FEED, &amp;quot;Android&amp;quot;);
   parameters.putString(GP_PICTURE_PARAM_FEED, ANDROID_IMAGE_URL); 
   parameters.putString(GP_DESCRIPTION_PARAM_FEED, comment);  
   mAsyncFacebookRunner.request(GP_ME_FEED_URI, 
                parameters, GP_POST_REQUEST, requestListener, null); 
}
&lt;/pre&gt;
&lt;p&gt;Les paramètres de la méthode &lt;em&gt;request&lt;/em&gt; sont :&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;La requête à effectuée, soit notre &lt;em&gt;me/feed&lt;/em&gt;&lt;/li&gt;
&lt;li&gt;Les paramètre de cette requête.&lt;/li&gt;
&lt;li&gt;Le type de requête, soit du &lt;em&gt;POST&lt;/em&gt;&lt;/li&gt;
&lt;li&gt;Un callback de réponse.&lt;/li&gt;
&lt;li&gt;Un objet quelconque de synchronisation qui sert à identifier les appels
lorsqu'on en fait plusieurs en même temps. Il est facultatif.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;J'ai moi même réalisé l'intégration de Facebook au sein de &lt;a href=&quot;http://www.blogger.com/www.keolitv.com&quot;&gt;Keoli TV&lt;/a&gt;, une application Android
permettant de donner le programme TV en temps réel, projet personnel sur lequel
je travail avec quelques amis.&lt;/p&gt;
&lt;p&gt;Le code complet est disponible &lt;a href=&quot;http://github.com/nfrancois/PocFacebookAndroid&quot;&gt;ici&lt;/a&gt;&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Git &amp; Geeks</title>
    <link>http://www.insideit.fr/post/2011/04/02/Git-Geeks</link>
    <guid isPermaLink="false">urn:md5:d9d51e1af467208729f84c5c78b56315</guid>
    <pubDate>Tue, 05 Apr 2011 17:19:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>git</category><category>sfeir</category>    
    <description>    &lt;p&gt;Tout commence par quelques tweets qui fusent, pour un besoin projet,
quelques Sferiens demandent à 2 autres Sferiens Git lovers, une petite
présentation pour les aider à appréhender l'outil. C'est par quelques autres
tweets que le cercle des personnes intéressées s'élargit et finit par donner
lieu à 2 ateliers Git d'une heure et demi organisés en fin de journée.&lt;/p&gt;
&lt;p&gt;Bien que ces 2 soirées de présentation débutant n'ont pas eu les même
présentateurs, elles étaient complémentaire.&lt;/p&gt;
&lt;p&gt;Lors de la 1ère, &lt;a href=&quot;http://twitter.com/fsznajderman&quot;&gt;@fsznajderman&lt;/a&gt;
nous a exposé les commandes de base et nous nous sommes amusés à cloner un
simple répertoire contenant un fichier qu'il avait mis à notre disposition sous
Assembla. Cela, nous a permis de nous familiariser avec quelques commande de
base, mais aussi à voir comment gérer des conflits. Et oui, si on s'amuse à
modifier la même ligne, il est tout de même perdu...&lt;/p&gt;
&lt;p&gt;Pour la 2ème, &lt;a href=&quot;http://twitter.com/fsznajderman&quot;&gt;@ptit_fred&lt;/a&gt; nous
a plongé dans la dimension du graphes des commits de Git et nous a appris à
mettre un projet sous git, de manier les branches et de les merger.
Personnellement, ces 2 séances m'ont donné l'envie d'étendre mes connaissances
et d'après l'avis des participant(e)s, je ne suis pas le seul.&lt;/p&gt;
&lt;p&gt;Devant cet enthousiasme, une suite devrait avoir lieu. Sfeir, c'est ça
aussi, une bande de geeks qui aime échanger sur divers sujets.&lt;/p&gt;
&lt;p&gt;&lt;a href=&quot;http://www.insideit.fr/public/sfeir/soireeGit1.jpg&quot;&gt;&lt;img src=&quot;http://www.insideit.fr/public/sfeir/.soireeGit1_m.jpg&quot; alt=&quot;Soirée Git1&quot; style=&quot;display:block; margin:0 auto;&quot; title=&quot;Soirée Git1, avr. 2011&quot; /&gt;&lt;/a&gt;&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Du Jersey, du Guice et de l'App Engine 1/3</title>
    <link>http://www.insideit.fr/post/2011/04/02/Du-Jersey%2C-du-Guice-et-de-l-App-Engine-1/3</link>
    <guid isPermaLink="false">urn:md5:194728205297d9046777c83c34eff805</guid>
    <pubDate>Sat, 02 Apr 2011 18:28:00 +0200</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>JAX-RS</category><category>Jersey</category><category>REST</category><category>Test</category>    
    <description>    &lt;p&gt;J'avais déjà parlé, dans de précédents articles, de la génération de xml et
de json avec Jersey. Et si maintenant, on s'amusait à générer du
protobuf ?&lt;br /&gt;
On parle de protobuf pour Protocol Buffers, une techno Google pour encoder des
structures de données. Ce format de données compact est utilisé en interne chez
Google des échanges de données. Etant basé sur la déclaration d'une structure
de données dans un idl, protobuf possède plusieurs implémentation et est ainsi
utilisable dans plusieurs langage. En java, la génération du code cible se fait
avec ant. Mais bien sur reste utilisable avec maven par le plugin ant.&lt;br /&gt;
Nous allons reprendre notre Hello qui avait d'exemple. Voici sa structure
protobuf :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
package nfrancois.poc;

option java_package = &amp;quot;nfrancois.poc.protobuf.model&amp;quot;;
option java_outer_classname = &amp;quot;HelloProto&amp;quot;;

message Hello {
  required string name = 1;
  required string message = 2;
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La structure se comprend assez facilement. Attention par contre, au trompeur
package de 1ère ligne, qui n'est pas lié à la notion de package que nous avons
en java. Il sert comme espace de nommage et éviter des collisions de nom si
plusieurs objets protobuf portent le même nom. Puisque depuis cette idl, je
pourrai aussi bien générer en C++ ou un autre langage, le vrai nom de package
java est indiqué par l'option &amp;quot;java_package&amp;quot;, de la même façon pour le nom de
classe qui va tout encapsuler qui sera &amp;quot;java_outer_classname&amp;quot;&lt;br /&gt;
Pour plus d'information sur &lt;a href=&quot;http://code.google.com/p/protobuf&quot;&gt;protobuf&lt;/a&gt;, je vous invite à consulter sa
page google code.&lt;br /&gt;
Le générateur protobuf générera un fichier HelloProto.java, qui permettra de
manipuler les Hello : création via pattern builder, encodage/désencodage,
... Le &amp;quot;vrai&amp;quot; Hello sera encapuslé au sein de ce dernier. Comme je disais, je
génère le java par le ant plugin de maven :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
&amp;lt;plugin&amp;gt;
 &amp;lt;groupid&amp;gt;org.apache.maven.plugins&amp;lt;/groupId&amp;gt;
 &amp;lt;artifactid&amp;gt;maven-antrun-plugin&amp;lt;/artifactId&amp;gt;
 &amp;lt;version&amp;gt;1.6&amp;lt;/version&amp;gt;
 &amp;lt;executions&amp;gt;
  &amp;lt;execution&amp;gt;
   &amp;lt;id&amp;gt;generate-sources&amp;lt;/id&amp;gt;
   &amp;lt;phase&amp;gt;generate-sources&amp;lt;/phase&amp;gt;
   &amp;lt;configuration&amp;gt;
    &amp;lt;target&amp;gt;
     &amp;lt;exec executable='protoc'&amp;gt;
             &amp;lt;arg value='--java_out=src/main/java' /&amp;gt;
             &amp;lt;arg value='src/main/resources/Hello.proto' /&amp;gt;
             &amp;lt;/exec&amp;gt;
    &amp;lt;/target&amp;gt;
   &amp;lt;/configuration&amp;gt;
   &amp;lt;goals&amp;gt;
    &amp;lt;goal&amp;gt;run&amp;lt;/goal&amp;gt;
   &amp;lt;/goals&amp;gt;
  &amp;lt;/execution&amp;gt;     
 &amp;lt;/executions&amp;gt;
&amp;lt;/plugin&amp;gt;
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
et bien sûr des dépendances protobuf&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
&amp;lt;dependency&amp;gt;
    &amp;lt;groupid&amp;gt;com.google.protobuf&amp;lt;/groupId&amp;gt;
    &amp;lt;artifactid&amp;gt;protobuf-java&amp;lt;/artifactId&amp;gt;
    &amp;lt;version&amp;gt;2.4.0a&amp;lt;/version&amp;gt;
&amp;lt;/dependency&amp;gt;
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
Le contrat de test sera assez proche de se que nous avions dans les tests
précédents :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Test
public void shoulReplyHello(){
 // Given
 String message = &amp;quot;Hello&amp;quot;;
 String name =&amp;quot;Nicolas&amp;quot;;
 Hello hello = HelloProto.Hello.newBuilder().setName(name).setMessage(message).build();
 when(helloServiceMock.saysHelloToSomeone(&amp;quot;Nicolas&amp;quot;)).thenReturn(hello);
 // When
 ClientResponse response = resource().path(&amp;quot;hello&amp;quot;).path(name).get(ClientResponse.class);
 // Then
 verify(helloServiceMock).saysHelloToSomeone(name);
 assertThat(response.getClientResponseStatus()).isEqualTo(Status.OK);
 assertThat(response.getType().toString()).isEqualTo(&amp;quot;application/x-protobuf&amp;quot;);
 Hello entity = response.getEntity(Hello.class);
 assertThat(entity).isNotNull().isEqualTo(hello);
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La resource REST, elle aussi va peut évoluer :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Path(&amp;quot;hello&amp;quot;)
@Singleton
@Produces(&amp;quot;application/x-protobuf&amp;quot;)
public class HelloResource {
 
 @Inject
 private HelloService helloService;
 
 @GET
 @Path(&amp;quot;/{name}&amp;quot;)
 public Hello reply(@PathParam(&amp;quot;name&amp;quot;) String name){
  return helloService.saysHelloToSomeone(name);
 }
 
 public void setHelloService(HelloService helloService) {
  this.helloService = helloService;
 }
 
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La difficulté à laquelle il faut se confronter, c'est que Jersey ne permet pas
de gérer de base le protobuf… Pas grave, on va s'occuper de faire le lien entre
l'encodage/désencodage de protobuf et Jersey.&lt;br /&gt;
&lt;br /&gt;
Commençons par le reader qui s'occupe de désencoder le protobuff. Pour celà,
nous devons implémenter l'interface MessageBodyReader où nous aurons du code
technique protobuf.&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Provider
@Consumes(&amp;quot;application/x-protobuf&amp;quot;)
@Singleton
public class ProtobufMessageBodyReader implements MessageBodyReader&amp;lt;Message&amp;gt; {

 public boolean isReadable(Class&amp;lt;?&amp;gt; type, Type genericType, Annotation[] annotations,
                                                            MediaType mediaType) {
  return Message.class.isAssignableFrom(type);
 }

 public Message readFrom(Class&amp;lt;Message&amp;gt; type, Type genericType, Annotation[] annotations, 
    MediaType mediaType, MultivaluedMap&amp;lt;String, String&amp;gt; httpHeaders, InputStream entityStream)
    throws IOException, WebApplicationException {
  try {
   Method newBuilder = type.getMethod(&amp;quot;newBuilder&amp;quot;);
   GeneratedMessage.Builder builder = (GeneratedMessage.Builder) newBuilder.invoke(type);
   return builder.mergeFrom(entityStream).build();
  } catch (Exception e) {
   throw new WebApplicationException(e);
  }
 }

}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
&lt;br /&gt;
C'est par le content type &amp;quot;application/x-protobuf&amp;quot; que JAX-RS fera matcher le
type le reader/writer à l'entrée/sortie de la resource. Pour l'encodage, c'est
l'interface MessageBodyWriter qu'il faut implémenter.&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
@Provider
@Produces(&amp;quot;application/x-protobuf&amp;quot;)
@Singleton
public class ProtobufMessageBodyWriter implements MessageBodyWriter&amp;lt;Message&amp;gt; {
 public boolean isWriteable(Class&amp;lt;?&amp;gt; type, Type genericType, Annotation[] annotations,
                                                              MediaType mediaType) {
  return Message.class.isAssignableFrom(type);
 }

 private Map&amp;lt;Object, byte[]&amp;gt; buffer = new WeakHashMap&amp;lt;Object, byte[]&amp;gt;();

 public long getSize(Message m, Class&amp;lt;?&amp;gt; type, Type genericType, Annotation[] annotations, 
                                                                 MediaType mediaType) {
  ByteArrayOutputStream baos = new ByteArrayOutputStream();
  try {
   m.writeTo(baos);
  } catch (IOException e) {
   return -1;
  }
  byte[] bytes = baos.toByteArray();
  buffer.put(m, bytes);
  return bytes.length;
 }

 public void writeTo(Message m, Class type, Type genericType, Annotation[] annotations, 
                MediaType mediaType, MultivaluedMap httpHeaders, OutputStream entityStream)
                throws IOException, WebApplicationException {
  entityStream.write(buffer.remove(m));
 }
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
La configuration de test, quant à elle sera un peu plus complexe, car il faut
que la partie cliente puisse désencoder toute seule le
protobuf :&lt;br /&gt;&lt;/p&gt;
&lt;pre&gt;
protected AppDescriptor configure() {
 ClientConfig clientConfig = new DefaultClientConfig();
 clientConfig.getClasses().add(ProtobufMessageBodyReader.class);
 clientConfig.getClasses().add(ProtobufMessageBodyWriter.class);
 injector = Guice.createInjector(new ServletModule() {
 @Override
 protected void configureServlets() {
  bind(ProtobufMessageBodyReader.class);
  bind(ProtobufMessageBodyWriter.class);
  bind(HelloResource.class);
  serve(&amp;quot;/*&amp;quot;).with(GuiceContainer.class);
  }
 }); 
 return new WebAppDescriptor.Builder()
          .contextListenerClass(GuiceTestConfig.class)
          .filterClass(GuiceFilter.class)
          .clientConfig(clientConfig)
          .servletPath(&amp;quot;/&amp;quot;)
          .build();
}
&lt;/pre&gt;
&lt;p&gt;&lt;br /&gt;
Le code complet est &lt;a href=&quot;https://github.com/nfrancois/PocJerseyProtobufGuiceAppEngine&quot;&gt;ici&lt;/a&gt;.&lt;/p&gt;</description>
    
    
    
      </item>
    
  <item>
    <title>Etendre les assertions de Fest Assert</title>
    <link>http://www.insideit.fr/post/2011/03/26/Etendre-les-assertions-de-Fest-Assert</link>
    <guid isPermaLink="false">urn:md5:27724594050a2f9409381e98fdc4ed88</guid>
    <pubDate>Sat, 26 Mar 2011 17:08:00 +0100</pubDate>
    <dc:creator>Nicolas FRANCOIS</dc:creator>
        <category>Java</category>
        <category>TDD</category><category>Test</category>    
    <description>    &lt;p&gt;C'est lors de la présentation de David Gageot sur les test au Paris JUG du
mois de janvier que j'ai découvert Fest-Assert. J'ai rapidement été
enthousiaste sur son utilisation. En plus de sa syntaxe proche d'un langage
naturel, il permet d'étendre ses assertions en fonction de ses besoins. Voici 2
façons d'utiliser ce mécanisme :&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Utilisation d'une Condition.&lt;/h2&gt;
&lt;p&gt;Ce cas de figure est à utiliser lorsque l'objet que je souhaite vérifier
possède déjà son objet d'assertion (StringAssert, FileAsset, ... ) ou si celle
ci est simple. Il faut pour cela étendre la classe Condition&amp;lt;T&amp;gt; et
implémenter la méthode public boolean matches(&amp;lt;T&amp;gt; value). Imaginons pas
exemple que je souhaite vérifier que ma liste contienne un nombre impair
d'éléments. Je vais écrire la conditions suivantes :&lt;/p&gt;
&lt;pre&gt;
private class IsListeTailleImpaireCondition extends Condition&amp;lt;List&amp;lt;?&amp;gt;&amp;gt; { 

 
     @Override 
     public boolean matches(List value) { 
          if(value == null){ 
               return false; 
          } else { 
               return value.size()%2==1; 
          } 
     } 

} 
&lt;/pre&gt;
&lt;p&gt;Son utilisation s'avère très simplement :&lt;/p&gt;
&lt;pre&gt;
assertThat(maListe).is(new IsListeTailleImpaireCondition()); 
&lt;/pre&gt;
&lt;p&gt;ou :&lt;/p&gt;
&lt;pre&gt;
assertThat(maListe).satifies(new IsListeTailleImpaireCondition()); 
&lt;/pre&gt;
&lt;p&gt;La différente entre les 2, n'est qu'au niveau sémantique, la validation est
équivalente. Et si on veut vérifier le contraire alors ? Rassurez vous,
pas besoin d'écrire une condition inverse, Fest-Assert possède des méthodes
pour ça : .isNot(...) ou .doesNotSatisfy(...)&lt;/p&gt;
&lt;p&gt;&lt;br /&gt;&lt;/p&gt;
&lt;h2&gt;Créer son objet d'assertion.&lt;/h2&gt;
&lt;p&gt;Ce cas de figure est adapté aux cas où mon objet ne possède pas son objet
d'assertions. Là, depuis la version 1.4 qui date d'il y a peu, c'est devenu
beaucoup plus simple. : il suffit d'étendre la classe GenericAssert et
d'implémenter les méthodes que je souhaite, sans oublier bien sûr de retourner
une instance de l'objet d'assertion afin de pouvoir chaîner les méthodes.
Imaginons que je souhaite développer mes assertions sur DateTime de
jodatime :&lt;/p&gt;
&lt;pre&gt;
import static org.fest.assertions.Formatting.inBrackets; 

import static org.fest.util.Strings.concat; 
import org.fest.assertions.GenericAssert; 
import org.joda.time.DateTime; 

/**
 * Assertions for &amp;lt;code&amp;gt;{@link org.joda.time.DateTime}&amp;lt;/code&amp;gt;.
 */ 
public class DateTimeAssert extends GenericAssert&amp;lt;DateTimeAssert, DateTime&amp;gt;  { 

/**
 * Creates a new {@link org.joda.time.DateTimeAssert}.
 * @param actual the target to verify.
 */  

 public DateTimeAssert(DateTime actual) { 
     super(DateTimeAssert.class, actual); 
 } 

 /**
  * Vérifie que le {@code org.joda.time.DateTimeAssert} est avant celui passé en paramètre.
  * @param Le {@code org.joda.time.DateTimeAssert} avec lequel on compare.
  * @return L'objet d'assertion.
  */ 

 public DateTimeAssert isBefore(DateTime expected){ 
     isNotNull();   
     if(actual.isBefore(expected)) { 
      return this; 
     } 
     failIfCustomMessageIsSet(); 
     throw failure(concat(actual(), &amp;quot; should be before to :&amp;quot;, inBrackets(expected))); 
 } 

 /**
  * Vérifie que le {@code org.joda.time.DateTimeAssert} est avant ou égale à celui 
  *  passé en paramètre.
  * @param Le {@code org.joda.time.DateTimeAssert} avec lequel on compare.
  * @return L'objet d'assertion.
  */ 
 public DateTimeAssert isBeforeOrEquals(DateTime expected){ 
     isNotNull();   
     if(actual.compareTo(expected) &amp;lt;= 0) { 
      return this; 
     } 
     failIfCustomMessageIsSet(); 
     throw failure(concat(actual(), &amp;quot; should be before to :&amp;quot;, inBrackets(expected))); 
 }  

 /**
  * Vérifie que le {@code org.joda.time.DateTimeAssert} est après
  * celui passé en paramètre.
  * @param Le {@code org.joda.time.DateTimeAssert} avec lequel on compare.
  * @return L'objet d'assertion.
  */  

 public DateTimeAssert isAfter(DateTime expected){ 
     isNotNull();   
     if(actual.isAfter(expected)) { 
      return this; 
     } 
     failIfCustomMessageIsSet(); 
     throw failure(concat(actual(), &amp;quot; should be after to :&amp;quot;, inBrackets(expected))); 
 } 

 /**
  * Vérifie que le {@code org.joda.time.DateTimeAssert} est après ou égale à celui 
  * passé en paramètre.
  * @param Le {@code org.joda.time.DateTimeAssert} avec lequel on compare.
  * @return L'objet d'assertion.
  */  
 public DateTimeAssert isAfterOrEquals(DateTime expected){ 
     isNotNull();   
     if(actual.compareTo(expected) &amp;gt;= 0) { 
      return this; 
     } 
     failIfCustomMessageIsSet(); 
     throw failure(concat(actual(), &amp;quot; should be after to :&amp;quot;, inBrackets(expected))); 
 }  

 /**
  * Vérifie que le {@code org.joda.time.DateTimeAssert} est compris dans l'intervale de
  * ceux passés en paramètre.
  * @param Le {@code org.joda.time.DateTimeAssert} de début d'intervallle
  * @param Le {@code org.joda.time.DateTimeAssert} de fin d'intervallle
  * @return L'objet d'assertion.
  */ 
 public DateTimeAssert isBetween(DateTime begin, DateTime end){ 
     isNotNull(); 
     if(actual.compareTo(begin) &amp;gt;= 0 &amp;amp;&amp;amp; actual.compareTo(end) &amp;lt;= 0) { 
         return this; 
     } 
     throw failure(concat(actual(), &amp;quot; should be between :&amp;quot;, 
                  inBrackets(begin), &amp;quot; and &amp;quot;, inBrackets(end)));   
 } 

 private String actual() { 
     return inBrackets(actual); 
 } 

} 
&lt;/pre&gt;
&lt;p&gt;Pour m'en servir, je dois le rattacher à un point d'entrée, comme Assertions
classe de base de Fest-Assert.&lt;/p&gt;
&lt;pre&gt;
public class MyAssertions { 

 public static DateTimeAssert assertThat(DateTime actual) { 
     return new DateTimeAssert(actual); 
 } 

} 
&lt;/pre&gt;
&lt;p&gt;Et pour finir, je n'aurais plus qu'à faire par exemple :&lt;/p&gt;
&lt;pre&gt;
MyAssertions.assertThat(maDate).isBeetwen(debutPeriode,finPeriode); 
&lt;/pre&gt;</description>
    
    
    
      </item>
    
</channel>
</rss>
