<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Ze Technology &#187; Bonnes Pratiques</title>
	<atom:link href="http://www.ze-technology.com/category/bonnes-pratiques/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.ze-technology.com</link>
	<description>Ze Blog qui parle de Ze Technology. Univers du libre, programmation, société, business...</description>
	<lastBuildDate>Sat, 17 Dec 2011 08:35:59 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3</generator>
		<item>
		<title>Optimisation de ses applications PHP : complément</title>
		<link>http://www.ze-technology.com/2009/09/21/optimisation-de-ses-applications-php-complement/</link>
		<comments>http://www.ze-technology.com/2009/09/21/optimisation-de-ses-applications-php-complement/#comments</comments>
		<pubDate>Mon, 21 Sep 2009 06:00:56 +0000</pubDate>
		<dc:creator>Adrien Mogenet</dc:creator>
				<category><![CDATA[Bonnes Pratiques]]></category>
		<category><![CDATA[Développement]]></category>
		<category><![CDATA[Mysql]]></category>
		<category><![CDATA[Php]]></category>

		<guid isPermaLink="false">http://www.ze-technology.com/?p=292</guid>
		<description><![CDATA[Ce billet fait suite à l&#8217;article &#171;&#160;Comment je teste #2&#8243;, qui se finissait par quelques conseils sur le profiling et l&#8217;amélioration de son code. Je vous propose de consulter une présentation réalisée par un certain George S, présentation qui fait le tour d&#8217;un large panel de possibilité pour développer du code dit &#171;&#160;scalable&#160;&#187; en passant [...]]]></description>
			<content:encoded><![CDATA[<p>Ce billet fait suite à l&#8217;article &laquo;&nbsp;Comment je teste #2&#8243;, qui se finissait par quelques conseils sur le <em>profiling</em> et l&#8217;amélioration de son code. Je vous propose de consulter une présentation réalisée par un certain George S, présentation qui fait le tour d&#8217;un large panel de possibilité pour développer du code dit &laquo;&nbsp;<em>scalable</em>&nbsp;&raquo; en passant donc par la configuration du serveur, l&#8217;analyse des soucis et les bonnes pratiques à adopter.</p>
<div style="width:425px;text-align:center; margin: auto;" id="__ss_241691"><a style="font:14px Helvetica,Arial,Sans-serif;display:block;margin:12px 0 3px 0;text-decoration:underline;" href="http://www.slideshare.net/techdude/building-scalable-php-applications" title="Building Scalable php applications">Building Scalable php applications</a><object style="margin:0px" width="425" height="355"><param name="movie" value="http://static.slidesharecdn.com/swf/ssplayer2.swf?doc=building-scalable-php-applications-1201306771494170-3&#038;rel=0&#038;stripped_title=building-scalable-php-applications" /><param name="allowFullScreen" value="true"/><param name="allowScriptAccess" value="always"/><embed src="http://static.slidesharecdn.com/swf/ssplayer2.swf?doc=building-scalable-php-applications-1201306771494170-3&#038;rel=0&#038;stripped_title=building-scalable-php-applications" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="425" height="355"></embed></object>
<div style="font-size:11px;font-family:tahoma,arial;height:26px;padding-top:2px;">View more <a style="text-decoration:underline;" href="http://www.slideshare.net/">documents</a> from <a style="text-decoration:underline;" href="http://www.slideshare.net/techdude">techdude</a>.</div>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.ze-technology.com/2009/09/21/optimisation-de-ses-applications-php-complement/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Comment je teste #2 : Connexion, connexions !</title>
		<link>http://www.ze-technology.com/2009/09/14/comment-je-teste-2-connexion-connexions/</link>
		<comments>http://www.ze-technology.com/2009/09/14/comment-je-teste-2-connexion-connexions/#comments</comments>
		<pubDate>Mon, 14 Sep 2009 06:00:20 +0000</pubDate>
		<dc:creator>Adrien Mogenet</dc:creator>
				<category><![CDATA[Bonnes Pratiques]]></category>
		<category><![CDATA[Méthode]]></category>
		<category><![CDATA[Outil]]></category>

		<guid isPermaLink="false">http://www.ze-technology.com/?p=259</guid>
		<description><![CDATA[Pour rappel, dans la première partie de cette série d&#8217;articles, vous avez pu découvrir la manière dont je testais Piwam grâce à la virtualisation. Nous allons maintenant soumettre notre application à des premiers tests&#8230; de performance. Bien que certaines applications soient faîtes pour une utilisation mono utilisateur, la plupart sont destinées à accueillir des centaines, [...]]]></description>
			<content:encoded><![CDATA[<p>Pour rappel, dans la première partie de cette série d&#8217;articles, vous avez pu découvrir la manière dont je testais <em><a href="http://www.piwam.org">Piwam</a></em> grâce à la virtualisation. Nous allons maintenant soumettre notre application à des premiers tests&#8230; <strong>de performance</strong>.</p>
<p>Bien que certaines applications soient faîtes pour une utilisation mono utilisateur, la plupart sont destinées à accueillir des centaines, des milliers d&#8217;utilisateurs simultanément, utilisateurs qui eux même ont la possibilité de réaliser des milliers d&#8217;interactions différentes. Comment alors tester le comportement de son application dans les pires situations, sans attendre que le chaos ne vienne s&#8217;imposer de lui même une fois l&#8217;application mise en production ? C&#8217;est le sujet de ce billet. Ce qui est présenté ci-dessous interessera les développeurs PHP mais aussi tous ceux qui utilisent une autre technologie web.</p>
<h3>Apache AB</h3>
<p>Commençons par faire stresser un petit peu notre application&#8230;  AB, pour <em>Apache HTTP server Benchmarking tool</em>, permet de simuler des accès au serveur web, en exécutant le nombre de requêtes souhaité par le biais d&#8217;un certain nombre de connexions concourantes, elles aussi contrôlées.  AB permet sans soucis de passer des serveurs proxy, simuler les requêtes GET comme POST, gérer l&#8217;authentification HTTP&#8230; La commande que j&#8217;utilise le plus souvent est la suivante :</p>
<pre>&gt; ab -e output.csv -n 10000 -c 100 http://docbook:80</pre>
<p>Quelques explications sur les options utilisées ici :</p>
<ul>
<li><strong>-e </strong>: spécifie un fichier CSV de sortie</li>
<li><strong>-c</strong> : nombre de connexions concourantes</li>
<li><strong>-n</strong> : nombre de requêtes à exécuter (réparties entre les différentes connexions)</li>
</ul>
<p>Je vous invite à lire la très claire <a href="http://httpd.apache.org/docs/2.0/programs/ab.html">page de documentation</a> pour découvrir toutes les options disponibles. Une fois exécutée, cette commande nous livre la sortie suivante :</p>
<pre>This is ApacheBench, Version 2.3 &lt;$Revision: 655654 $&gt;
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking docbook (be patient).....done

Server Software:        Apache/2.2.9
Server Hostname:        docbook
Server Port:            80

Document Path:          /
Document Length:        4427 bytes

Concurrency Level:      100
Time taken for tests:   5.569 seconds
Complete requests:      10000
Failed requests:        0
Write errors:           0
Total transferred:      472500 bytes
HTML transferred:       442700 bytes
<span class="highlight">Requests per second:    17.96 [#/sec] (mean)</span>
Time per request:       556.946 [ms] (mean)
Time per request:       55.695 [ms] (mean, across all concurrent requests)
Transfer rate:          82.85 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.2      0       1
Processing:   246  548 110.6    539    1150
Waiting:      246  547 109.9    538    1147
Total:        247  548 110.6    539    1150

Percentage of the requests served within a certain time (ms)
  50%    539
  66%    564
  75%    578
  80%    591
  90%    633
  95%    673
  98%   1101
  99%   1150
 100%   1150 (longest request)</pre>
<p>La ligne sur-lignée est à mon avis celle qui donne le plus de sens aux résultats. Le nombre de requêtes par secondes est en effet un bon indicateur de la santé de votre application (et de votre serveur). Quant au fichier CSV généré, dont on a un aperçu avec les pourcentages donnés à la fin de la sortie ci-dessus, vous pourrez y retrouver la répartition des <em>timings</em> dans lesquels ont été satisfaites les requêtes. Ajoutez à cela des taux de transferts, des erreurs détectées potentielles, et vous obtenez ici un bon outil de <em>benchmarking</em>.</p>
<h4>Comment simuler l&#8217;envoi de données ?</h4>
<p>Comme indiqué dans sa présentation, il est possible de simuler la soumission de formulaires via l&#8217;option <span style="font-family: courier">-p POSTFILE</span>. Une question très récurrente revient souvent : à quoi ressemble ce fichier POSTFILE ? En fonction de la version utilisée, la documentation d&#8217;Apache peut ne pas être très bavarde. Ce fichier comprend la liste des arguments de la manière suivante : <strong>nom=valeur&amp;nom2=autrevaleur</strong>, avec l&#8217;encodage spécial utilisé pour les URL.</p>
<h3>Pylot</h3>
<div class="wp-caption aligncenter" style="width: 650px"><img class=" " title="Graphique Pylot" src="http://www.pylot.org/samples/results/response_time_graph.png" alt="Graphique généré par Pylot" width="640" height="240" /><p class="wp-caption-text"> Graphique généré par Pylot : temps de réponse en fonction du temps écoulé</p></div>
<p><span style="background-color: #ffffff;">Écrit en Python, Pylot possède a 2 plusieurs pour séduire : la capacité de générer des graphiques, la présence d&#8217;un GUI pour les allergiques au mode console, interfaçage XML-RPC&#8230; Pylot fonctionne par le biais de scénarios, des <em>test-cases</em>, écrits au sein de fichiers XML pas trop compliqués. Ce mode de fonctionnement permet de personnaliser assez facilement les scénarios et de passer tous ces test-cases automatiquement. Découvrez Pylot sur <a href="http://www.pylot.org/">http://www.pylot.org/</a>. </span></p>
<h3><span style="background-color: #ffffff;">C&#8217;est trop long !</span></h3>
<p><span style="background-color: #ffffff;">Ces tests vous ont permis de vous apercevoir d&#8217;une chose : votre application met systématiquement un minimum de 400 ms à répondre, et facilement jusqu&#8217;à 900 ms dès que plusieurs utilisateurs effectuent des recherches. Des temps qui rapidement risquent d&#8217;énerver vos utilisateurs. Comment alors réduire autant que possible ces <em>timings</em> fous ?</span></p>
<p><span style="background-color: #ffffff;">Premièrement, l&#8217;utilisation d&#8217;un accélérateur PHP peut être tout a fait adaptée (tout du moins, pour les développeurs PHP). <a href="http://fr.php.net/apc">APC</a>, <a href="http://eaccelerator.net/">eAccelerator</a> et consorts devraient vous intéresser. Laissez vous guider par les tests et comparatifs (un lien : <a href="http://www.ipersec.com/index.php/2006/05/30/benchmarking-php-accelerators/">iPerSec</a>). Ces accélérateurs donneront un coup de boost magique à votre projet PHP. </span></p>
<p><span style="background-color: #ffffff;">Des &laquo;&nbsp;erreurs&nbsp;&raquo;, ou lourdeurs de développement, peuvent être à l&#8217;origine de la lenteur de l&#8217;application. Ré-écrire et optimiser son code peut s&#8217;avérer extrêmement long. Avant ça, un petit tour vers une étape de <em><strong>profiling</strong></em> est indispensable. Pour ceux qui ne savent pas de quoi je parle, jetez un oeil sur mon <a href="http://www.ze-technology.com/2009/09/03/developper-plus-efficacement-avec-xdebug/">article</a> dédié à <em><a href="http://www.xdebug.org/">XDebug</a></em>. Cette étape de <em>profiling</em> vous permettra de détecter une éventuelle partie de code <strong>particulièrement et anormalement consommatrice</strong> de temps.</span></p>
<p><span style="background-color: #ffffff;">Et finalement, si c&#8217;est encore possible, prenez le temps nécessaire pour analyser la source de la lenteur, la corriger, pratiquer le refactoring de code, installer des serveur proxy, refaire des tests plus précis, modifier la configuration PHP, etc. Un prochain article sera l&#8217;occasion d&#8217;aborder ces même tests dédiés à MySQL. Et si vous n&#8217;avez plus le temps pour corriger tout ça, et bien c&#8217;est le moment de prendre de bonnes résolutions et de mettre en place toutes les bonnes pratiques de <strong>ZeTechnology</strong> pour votre prochain projet !</span></p>
]]></content:encoded>
			<wfw:commentRss>http://www.ze-technology.com/2009/09/14/comment-je-teste-2-connexion-connexions/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Comment je teste #1 : L&#8217;indispensable virtualisation</title>
		<link>http://www.ze-technology.com/2009/09/10/comment-je-teste-1/</link>
		<comments>http://www.ze-technology.com/2009/09/10/comment-je-teste-1/#comments</comments>
		<pubDate>Thu, 10 Sep 2009 06:00:50 +0000</pubDate>
		<dc:creator>Adrien Mogenet</dc:creator>
				<category><![CDATA[Bonnes Pratiques]]></category>
		<category><![CDATA[Développement]]></category>
		<category><![CDATA[Méthode]]></category>

		<guid isPermaLink="false">http://www.ze-technology.com/?p=220</guid>
		<description><![CDATA[Et c&#8217;est partie pour le premier article de la série. Après une entrée en matière, voici l&#8217;heure pour moi d&#8217;écrire, et pour vous de lire, l&#8217;épisode #1 de la série. Il n&#8217;y a pas d&#8217;ordre particulier, les sujets seront abordés assez indépendamment. En revanche, les articles seront illustrés d&#8217;un cas d&#8217;utilisation réel : Piwam. Aujourd&#8217;hui, [...]]]></description>
			<content:encoded><![CDATA[<p>Et c&#8217;est partie pour le premier article de la série. Après une <a href="http://www.ze-technology.com/2009/08/18/comment-je-teste-nouvelle-serie-darticles/">entrée en matière</a>, voici l&#8217;heure pour moi d&#8217;écrire, et pour vous de lire, l&#8217;épisode #1 de la série. Il n&#8217;y a pas d&#8217;ordre particulier, les sujets seront abordés assez indépendamment. En revanche, les articles seront illustrés d&#8217;un cas d&#8217;utilisation réel : <em><a href="http://www.piwam.org">Piwam</a></em>.</p>
<p>Aujourd&#8217;hui, je vous propose, et vous n&#8217;avez pas vraiment le choix, de découvrir la manière dont je teste le déploiement de l&#8217;application. Quels sont les pièges, les méthodes, bref, tout.</p>
<h3>Virtualiser, c&#8217;est la mode.</h3>
<p>Je ne possède pas de serveur de test. Et de toute manière, si j&#8217;en possédais un, je me servirais tout de même d&#8217;un système virtualisé, afin d&#8217;éviter d&#8217;utiliser inutilement le vrai serveur. Voilà donc le premier point : le déploiement est testé <strong>en conditions réelles</strong> au sein d&#8217;une machine virtuelle. Le système virtualisé est le plus proche possible de celui qui tourne en production : OS, noyau, mémoire disponible, swap, version de PHP, MySQL, fichiers de configuration&#8230;</p>
<p><img class="aligncenter size-full wp-image-240" title="VirtualBox" src="http://www.ze-technology.com/wp-content/uploads/2009/09/VirtualBox.png" alt="VirtualBox" width="600" height="358" /></p>
<p style="text-align: center;">Serveur Debian virtualisé, lancé depuis WindowsXP</p>
<p>Cette précaution permet de s&#8217;affranchir au maximum des mauvaises surprises liées à l&#8217;environnement. Imaginez un peu, votre système sur lequel vous développez possède le paramètre <a href="http://www.php.net/manual/fr/ini.core.php"><span style="font-family: courier">memory_limit</span></a> fixé à <span style="font-family: courier">128M</span>. Tout fonctionne parfaitement. Sans passer par le scénario de test de déploiement présenté ici, vous décidez de mettre tout de suite à jour la version en production. Tout fonctionne parfaitement. Erreur. Tout <strong>semble</strong> fonctionner parfaitement. C&#8217;était sans compter cet utilisateur qui, voulant lister 100 résultats de recherche par page, obtient une magnifique erreur d&#8217;explosion de la mémoire allouée, dont le maximum était fixé à <span style="font-family: courier">64M</span> sur le serveur de production.</p>
<h3>Quelle solution choisir ?</h3>
<p>Les solutions de virtualisation ont le vent en poupe actuellement. Citons <a href="http://www.vmware.com/fr/">VM Ware</a>, <a href="http://www.virtualbox.org/">VirtualBox</a>, <a href="http://www.parallels.com/fr/">Parallels</a> (MacOSX)&#8230; Pour laquelle opter ? Après un essai des différentes solutions, je ne peux que vous conseiller la solution de Sun (Oracle&#8230;) : <a href="http://www.virtualbox.org/">VirtualBox</a>. Disponible sous toutes les plate-formes, gratuite, libre, cette box magique satisfaira toute nos exigences. Une fois installée, installez votre système virtualisé (dans mon cas : Debian 5.0), installez / configurez vos applications (ici : Apache 2, PHP 5.3 + modules, MySQL 5.1, <a href="http://symfony-project.com">symfony</a> 1.2).</p>
<div class="note">
<h4>Note :</h4>
<p>Votre serveur virtualisé possède un accés à votre réseau local, et après un petit peu de configuration, il est également accéssible au sein de celui-ci (configuration de la carte réseau en mode <em>bridge</em>) à l&#8217;instar d&#8217;un véritable serveur.</div>
<h3>Envoyer ses fichiers au serveur</h3>
<p>C&#8217;est bien joli d&#8217;avoir maintenant une réplique de son serveur de production, mais comment y tester son application ? Plusieurs solutions :</p>
<ol>
<li><span style="text-decoration: line-through;">Vous recodez intégralement votre projet au sein de votre serveur virtualisé </span>(&#8230;)</li>
<li>Vous avez pris la bonne habitude d&#8217;utiliser un serveur <span style="text-decoration: line-through;">CVS,</span> <a href="http://subversion.tigris.org/">SVN</a> ou <a href="http://git-scm.com/">Git</a>. Dans cas là, un <em>commit</em> d&#8217;un côté et un <em>update</em> de l&#8217;autre fera très bien l&#8217;affaire.</li>
<li>Vous avez configuré un répertoire partagé sous VirtualBox, accessible aussi bien sous votre système hôte que depuis votre serveur. Placez donc juste l&#8217;archive du projet à tester dans ce répertoire.</li>
</ol>
<div class="warning">
<h4>Piège à éviter :</h4>
<p>Alors que je découvrais VirtualBox, la solution me paraissait si puissante que j&#8217;avais décidé d&#8217;en faire directement mon serveur de développement, via un répertoire partagé entre le système hôte (alors un Windows XP) et virtualisé (la Debian). Je continuais à développer sous Windows, mais le code était directement interprété par le serveur virtualisé. &laquo;&nbsp;<em>Chouette, je peux tester en temps réel en conditions réelles !</em>&laquo;&nbsp;. MAIS, un problème d&#8217;implémentation du &laquo;&nbsp;pilote&nbsp;&raquo; permettant le partage de répertoires rendait l&#8217;exécution d&#8217;un projet <a href="http://symfony-project.com">symfony</a> complexe extrêmement lente (plus de 30 secondes par page).</div>
<h3>Et maintenant, je fais quoi ?</h3>
<p>Pour résumer, vous possédez maintenant une version à jour de votre application, disponible sur un serveur (virtualisé), réplique parfaite (normalement) du serveur qui l&#8217;accueillera. Et bien, rappelez vous pourquoi vous venez de faire toutes ces manipulations : <strong>pour tester</strong> ! Suivez donc la procédure de déploiement de votre application que vous avez pu décrire au sein de votre documentation. Pour certains projets, il n&#8217;y a rien à faire de particulier, le projet est directement fonctionnel, mais pour d&#8217;autres, c&#8217;est le moment de vérifier que votre documentation, bêtement suivie à la lettre, permet d&#8217;arriver à une application qui fonctionne ; quelques exemples en vrac :</p>
<ul>
<li>Configuration de l&#8217;accès au SGBDR</li>
<li>Droits en lecture/écriture de certains répertoires</li>
<li>Mises à jour de fichiers</li>
<li>Exécution de requêtes pré-requises</li>
</ul>
<p>Si, une fois, les instructions de la documentation suivies, votre application ne fonctionne pas, c&#8217;est qu&#8217;il y a bien un <strong>problème</strong>, lié à la documentation ou à l&#8217;application.</p>
<h3>Youpi ! Ça fonctionne !</h3>
<p>Allons allons, calmons nous. Le déploiement du projet (ou de la mise à jour) fonctionne. Nous ne sommes pas encore en mesure de savoir si le projet fonctionne à 100% comme il devrait. Il vous faut maintenant torturer votre application dans tous les sens afin de déceler les <em>bugs</em> éventuels. Ou alors, et je vais peut-être créer une certaine frustration en m&#8217;arrêtant ici, c&#8217;est le moment de lancer vos 2000 tests unitaires et fonctionnels, qui vérifieront <strong>automatiquement</strong> le bon fonctionnement de votre application sur le système courant.</p>
<h3>Virtualiser, encore +</h3>
<p><img class="alignleft size-full wp-image-227" title="VServer" src="http://www.ze-technology.com/wp-content/uploads/2009/09/Image-10.png" alt="VServer" width="280" height="179" />Il est fort possible que votre application ne soit pas destinée à une plate-forme en particulier mais  à être déployée sur un grand nombre de serveurs très différents, aux versions et configurations de PHP différentes. Vous pouvez alors virtualiser d&#8217;autres OS, aux configurations différentes. Ou vous pouvez pousser la virtualisation encore plus loin en optant pour <a href="http://fr.wikipedia.org/wiki/Linux-VServer">VServer</a>. Une fois VServer installé sur votre serveur de test, vous serez en mesure d&#8217;isoler parfaitement différents &laquo;&nbsp;sous-environnements&nbsp;&raquo; différents et de <em>switcher</em> d&#8217;une configuration à une autre extrêmement facilement, rapidement, et de manière très fiable, sécurisée parfaitement isolée.</p>
<h3>En bref :</h3>
<ol>
<li>Installez VirtualBox</li>
<li>Virtualisez l&#8217;OS de votre choix</li>
<li>Configurez cet OS virtualisé</li>
<li>Testez, lancez vos tests</li>
</ol>
]]></content:encoded>
			<wfw:commentRss>http://www.ze-technology.com/2009/09/10/comment-je-teste-1/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Comment je teste : nouvelle série d&#8217;articles</title>
		<link>http://www.ze-technology.com/2009/08/18/comment-je-teste-nouvelle-serie-darticles/</link>
		<comments>http://www.ze-technology.com/2009/08/18/comment-je-teste-nouvelle-serie-darticles/#comments</comments>
		<pubDate>Tue, 18 Aug 2009 06:00:03 +0000</pubDate>
		<dc:creator>Adrien Mogenet</dc:creator>
				<category><![CDATA[Bonnes Pratiques]]></category>
		<category><![CDATA[Développement]]></category>
		<category><![CDATA[Méthode]]></category>

		<guid isPermaLink="false">http://www.ze-technology.com/?p=145</guid>
		<description><![CDATA[On regrette très vite de ne pas tester son application. Pendant les différentes phases du développement, il est on ne peut plus utile d&#8217;avoir un aperçu fidèle à la réalité de la qualité du produit qu&#8217;on s&#8217;apprête à délivrer. Tests unitaires, tests fonctionnels. tests de déploiement, tests de non-régression&#8230; la batterie n&#8217;est pas mince, et [...]]]></description>
			<content:encoded><![CDATA[<p><img class="aligncenter size-full wp-image-161" title="Tester" src="http://www.ze-technology.com/wp-content/uploads/2009/08/tester.gif" alt="Tester" width="280" height="220" /></p>
<p>On regrette très vite de ne pas tester son application. Pendant les différentes phases du développement, il est on ne peut plus utile d&#8217;avoir un aperçu fidèle à la réalité de la qualité du produit qu&#8217;on s&#8217;apprête à délivrer.</p>
<p>Tests unitaires, tests fonctionnels. tests de déploiement, tests de non-régression&#8230; la batterie n&#8217;est pas mince, et automatiser un maximum de tâche s&#8217;avère payant.</p>
<p>La raison d&#8217;exister de cette nouvelle série d&#8217;article ne vas pas être de vous présenter une énième fois des cours théoriques sur les méthodologies de tests, mais de faire le point sur certaines problématiques, et d&#8217;apporter un élément de réponse parmi tant d&#8217;autres : le mien.</p>
<p>Vous retrouverez donc dès la rentrée une série d&#8217;articles sur cette passionnante thématique, permettant à chacun d&#8217;améliorer :</p>
<ul>
<li>sa productivité</li>
<li>la qualité de son travail</li>
<li>ses habitudes de développement</li>
</ul>
<p>Le premier article est prévu pour la fin du mois, avec un case-study sur la manière dont je teste le déploiement de <a href="http://www.ze-technology.com/category/piwam/"><a href="http://www.piwam.org">Piwam</a></a>.</p>
<p><strong>PS </strong>: Vous noterez les images très très drôles qui accompagneront dorénavant les articles dans la mesure du possible.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.ze-technology.com/2009/08/18/comment-je-teste-nouvelle-serie-darticles/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Aujourd&#8217;hui, je connais le mot de passe de&#8230;</title>
		<link>http://www.ze-technology.com/2009/07/30/aujourdhui-je-connais-le-mot-de-passe-de/</link>
		<comments>http://www.ze-technology.com/2009/07/30/aujourdhui-je-connais-le-mot-de-passe-de/#comments</comments>
		<pubDate>Thu, 30 Jul 2009 21:20:59 +0000</pubDate>
		<dc:creator>Adrien Mogenet</dc:creator>
				<category><![CDATA[Bonnes Pratiques]]></category>

		<guid isPermaLink="false">http://www.ze-technology.com/?p=136</guid>
		<description><![CDATA[La gestion des mots de passe pour un particulier comme pour une entreprise est une discipline à part entière. Complexe, mais pas trop. Unique, ou différent à chaque fois. Une discipline pleine de failles et de lacunes. Aujourd&#8217;hui, je connais le mot de passe d&#8217;une caisse&#8230; d&#8217;UPS ! La personne à l&#8217;accueil l&#8217;a tout simplement [...]]]></description>
			<content:encoded><![CDATA[<p>La gestion des mots de passe pour un particulier comme pour une entreprise est une discipline à part entière. Complexe, mais pas trop. Unique, ou différent à chaque fois. Une discipline pleine de failles et de lacunes.</p>
<p>Aujourd&#8217;hui, je connais le mot de passe d&#8217;une caisse&#8230; d&#8217;<strong>UPS</strong> ! La personne à l&#8217;accueil l&#8217;a tout simplement dicté à une collègue à pleine voix, alors que je passais chercher un colis.</p>
<p>Une caisse plutôt isolée, bah oui, &laquo;&nbsp;<em>y a un mot de passe</em>&nbsp;&raquo; (il paraît)&#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.ze-technology.com/2009/07/30/aujourdhui-je-connais-le-mot-de-passe-de/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>L&#8217;utilité des tests fonctionnels&#8230;</title>
		<link>http://www.ze-technology.com/2009/05/08/lutilite-des-tests-fonctionnels/</link>
		<comments>http://www.ze-technology.com/2009/05/08/lutilite-des-tests-fonctionnels/#comments</comments>
		<pubDate>Fri, 08 May 2009 21:57:00 +0000</pubDate>
		<dc:creator>Adrien Mogenet</dc:creator>
				<category><![CDATA[Bonnes Pratiques]]></category>
		<category><![CDATA[Projet]]></category>
		<category><![CDATA[Symfony]]></category>

		<guid isPermaLink="false">http://adrien.frenchcomp.net/blog/?p=26</guid>
		<description><![CDATA[Pour ceux qui en douteraient, ça sert. Plutôt seul dans le développement de Piwam, j&#8217;ai décidé de fournir des batteries de tests &#171;&#160;plus tard&#160;&#187;, pas avant la version beta. Or, entre plusieurs versions alpha, il se trouve qu&#8217;en corrigeant certains bugs, j&#8217;en ai inséré d&#8217;autres &#8211; le genre bug critique, tant qu&#8217;à faire. Évidemment, l&#8217;insertion [...]]]></description>
			<content:encoded><![CDATA[<p>Pour ceux qui en douteraient, ça sert. Plutôt seul dans le développement de <a href="http://ze-technology.blogspot.com/search/label/piwam"><a href="http://www.piwam.org">Piwam</a></a>, j&#8217;ai décidé de fournir des batteries de tests &laquo;&nbsp;plus tard&nbsp;&raquo;, pas avant la version <span style="font-weight: bold;">beta</span>.<br />
Or, entre plusieurs versions <span style="font-weight: bold;">alpha</span>, il se trouve qu&#8217;en corrigeant certains <span style="font-style: italic;">bugs</span>, j&#8217;en ai inséré d&#8217;autres &#8211; le genre <span style="font-style: italic;">bug </span>critique, tant qu&#8217;à faire.  Évidemment, l&#8217;insertion d&#8217;un <span style="font-style: italic;">bug </span>est rarement volontaire, et chez moi les causes identifiées sont plutôt :</p>
<ul>
<li>Etourderies, comme un léger refactoring de code dans lequel on inverse une condition (!)
</li>
<li>Fatigue au moment de la correction</li>
<li>Fautes de frappes stupides</li>
</ul>
<p>Je ne vous cache pas la honte qui montait en moi lorsque j&#8217;ai découvert que j&#8217;étais en train de distribuer une version avec un <span style="font-style: italic;">bug </span>empêchant la création même d&#8217;une association&#8230; Bon, c&#8217;était une version <span style="font-weight: bold;">alpha</span>, mais quand même, Un simple petit coup de</p>
<pre>> <a href="http://symfony-project.com">symfony</a> test:functional front</pre>
<p>aurait permis de s&#8217;apercevoir que ça ne marchait plus. Promis, les prochaines releases seront testées <span style="font-size:78%;">peut être</span>&#8230; <a href="http://www.symfony-project.org/book/1_2/15-Unit-and-Functional-Testing">Les tests fonctionnels avec Symfony</a>
<div class="blogger-post-footer"><img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/1394095790770446638-5084280822072913403?l=ze-technology.blogspot.com'/></div>
]]></content:encoded>
			<wfw:commentRss>http://www.ze-technology.com/2009/05/08/lutilite-des-tests-fonctionnels/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

