<?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>Léo Hackin 0.2c &#187; simpletest</title>
	<atom:link href="http://www.leohackin.com.br/tag/simpletest/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.leohackin.com.br</link>
	<description>Eternamente beta, geralmente funcional</description>
	<lastBuildDate>Wed, 21 Jul 2010 00:34:43 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>Mock Objects no SimpleTest</title>
		<link>http://www.leohackin.com.br/2009/12/mock-objects-no-simpletest/</link>
		<comments>http://www.leohackin.com.br/2009/12/mock-objects-no-simpletest/#comments</comments>
		<pubDate>Fri, 04 Dec 2009 15:51:34 +0000</pubDate>
		<dc:creator>Léo Hackin</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[tdd]]></category>
		<category><![CDATA[mockobjects]]></category>
		<category><![CDATA[simpletest]]></category>

		<guid isPermaLink="false">http://www.leohackin.com.br/?p=253</guid>
		<description><![CDATA[Olá pessoal, Continuando nossa sequência de artigos sobre o SimpleTest, já aprendemos como fazer testes unitários e agrupa-los para facilitar a execução em lote: agora vamos falar um pouco sobre mock objects. Até agora, nossos testes unitários se resumiram a testar métodos e funcionalidades que envolviam apenas uma classe como nossa calculadora: tínhamos um método chamado [...]]]></description>
			<content:encoded><![CDATA[
<div class="topsy_widget_data topsy_theme_jade" style="float: right;margin-left: 0.75em;"><script type="text/javascript" src="http://button.topsy.com/widget/retweet-small?url=http://www.leohackin.com.br/2009/12/mock-objects-no-simpletest/&amp;title=Mock+Objects+no+SimpleTest&amp;theme=jade&amp;order=count,retweet,badge&amp;txt_tweet=tuit&amp;txt_retweet=retuit"></script></div><p>Olá pessoal,</p>
<p>Continuando nossa sequência de artigos sobre o <a href="http://www.simpletest.org" target="_blank">SimpleTest</a>, já aprendemos <a href="http://www.leohackin.com.br/2009/07/iniciando-com-o-simpletest/" target="_blank">como fazer testes unitários</a> e <a href="http://www.leohackin.com.br/2009/07/agrupando-casos-de-teste-no-simpletest/" target="_blank">agrupa-los</a> para facilitar a execução em lote: agora vamos falar um pouco sobre <strong>mock objects</strong>.</p>
<p>Até agora, nossos testes unitários se resumiram a <strong>testar métodos e funcionalidades que envolviam apenas uma classe</strong> como nossa calculadora: tínhamos um método chamado &#8220;somar&#8221; que fazia parte da própria classe e recebia como parametro de entrada apenas dois inteiros.</p>
<p>A idéia do <strong>teste unitário</strong> (ou de unidade), como o próprio nome diz, é <strong>isolar e testar apenas aquele ponto e funcionalidade</strong> do software: então é imprescindível que possamos isolar da melhor maneira apenas a classe/métodos que desejamos testar para que, caso apresente falha, possamos <strong>identificar exatamente onde a falha ocorreu</strong>.</p>
<p>Mas e quando nossa classe depende de outra(s) classe(s) para fazer um método funcionar ?</p>
<p><span id="more-253"></span></p>
<h2><span style="font-weight: normal;">Conceituando o problema</span></h2>
<p>Então, vamos imaginar a seguinte situação: estamos desenvolvendo um software de e-commerce e em dado momento precisamos validar se um usuário existe em nosso banco de dados. Apesar das possibilidades abrangentes de um sistema de validação/autenticação, vamos nos preocupar com o básico e implementá-lo de uma forma simples como abaixo:</p>
<div id="attachment_264" class="wp-caption aligncenter" style="width: 568px"><img class="size-full wp-image-264" title="As classes usadas no validador" src="http://www.leohackin.com.br/wp-content/uploads/2009/12/diagrama_validator.gif" alt="As classes usadas no validador" width="558" height="181" /><p class="wp-caption-text">As classes usadas no validador</p></div>
<p>Vamos criar uma classe chamada <em><span style="text-decoration: underline;">Validator</span></em>, que receberá o login do usuário, verificará no banco de dados se ele existe ou não e validará seu acesso. Para tanto, nossa classe de validação terá um método chamado <em>validate</em>, que receberá um parâmetro <em>string</em> representando o nome do usuário a ser validado.</p>
<p>Para conectar-se ao banco de dados, nossa classe receberá em sua criação um objeto referente à classe <em><span style="text-decoration: underline;">Conexao</span></em>, que disponibilizará um método chamado <em><span style="text-decoration: underline;">query</span></em>, que consulta o banco e retorna uma array de resultados.</p>
<p><strong><span style="color: #000080;">classe validator.php</span></strong></p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br />13<br />14<br />15<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> Validator <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">var</span> <span style="color: #000088;">$conexao</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">conexao</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$conexao</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> validate<span style="color: #009900;">&#40;</span><span style="color: #000088;">$nome</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #666666; font-style: italic;">// aqui vai a lógica para verificar se o usuário existe ou não e que vamos testar</span><br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p><span style="color: #000080;"><strong><span style="color: #333399;">classe conexao.php</span></strong></span></p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> Conexao <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #000088;">$config</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #666666; font-style: italic;">// configura o acesso ao banco de dados</span><br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> query<span style="color: #009900;">&#40;</span><span style="color: #000088;">$query</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #666666; font-style: italic;">// retorna um array com os resultados da consulta</span><br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Para que tudo fique mais claro, podemos dar uma olhada em como ficaria nosso código final da aplicação:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000088;">$config</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Config<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> <span style="color: #000088;">$Conexao</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$config</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$validator</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Validator<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000088;">$usuario</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">'Léo'</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><span style="color: #000088;">$validator</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$usuario</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #666666; font-style: italic;">// redireciona para a página restrita</span><br />
<span style="color: #009900;">&#125;</span> <span style="color: #b1b100;">else</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #666666; font-style: italic;">// retorna uma alerta falando que o usuário não existe</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Como aprendemos em nosso primeiro artigo sobre TDD, <strong>primeiro fazemos os testes e depois fazemos nossa aplicação passar nos neles</strong>, implementando a lógica de negócio válida. Nosso objetivo nesse momento é <strong>testar o método validate</strong>: fazendo um pouco de nossa flexão mental chegamos a dois comportamentos válidos para o método:</p>
<ul>
<li>Se o usuário existir, ele retornará true;</li>
<li>Se o usuário não existir, ele retornará false;</li>
</ul>
<h2><span style="font-weight: normal;">O problema </span></h2>
<p>Então, pensamos &#8220;<em>Bacana! Então vou fazer um caso de teste chamado ValidatorTestCase e um teste chamado testValidarSeUsuarioExistir que irá validar se um usuário foi validado se ele existir!</em>&#8220;.</p>
<p>Partimos para o código então:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> ValidatorTestCase <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> testValidarSeUsuarioExistir<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000088;">$config</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Config<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Conexao<span style="color: #009900;">&#40;</span><span style="color: #000088;">$config</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$validator</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Validator<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertEqual</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$validator</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">validate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p><strong>Tudo ok ?</strong> <span style="color: #800000;"><strong><span style="color: #ff0000;">NADA OK!</span></strong></span> O código acima pode funcionar mas temos alguns problemas:</p>
<ul>
<li>Como garantir que nosso banco de dados vai estar disponível na hora do teste ?</li>
<li>Como vamos saber se existe o usuário que queremos testar está no banco, para testarmos se a validação realmente vai passar no teste e se comportar como queremos ?</li>
<li>E se ocorrer um erro de conexão ao banco no meio do teste ?</li>
<li>E se a conexão banco for demorada e nosso caso de teste ter 50 testes acessando o banco? oO</li>
<li>Como saber se as configurações estão exatas para a conexão no banco? Aliás, eu nem sei nada sobre config até agora!</li>
<li>E principalmente: e se ocorrer um problema na pesquisa da query que não tenha nada haver exatamente com nosso validador, já que nosso objetivo é testar unicamente se &#8220;ao receber um usuário, verificar se ele existe no banco e validar em caso afirmativo&#8221;.</li>
</ul>
<p><strong>Haja coisa né ?</strong></p>
<h2><span style="font-weight: normal;">Mock Objects (nosso boneco de testes)</span></h2>
<p>Pensando nesse problema, foram criados os <strong>Mock objects</strong>. Um mock object (vou usar o termo em inglês pois a esmagadora maioria das referências TDD estão assim) nada mais é que <strong>um objeto que simula e imita o comportamento de um objeto real</strong>.</p>
<p>Imagine os <strong>bonecos de teste de batidas de carro</strong>: os engenheiros os constroem com peso, altura, juntas e vários aspectos que <strong>imitam o corpo de um ser humano para poderem fazer seus testes</strong>. Eles colocam esses bonecos nas mais variadas situações e posições possíveis para testarem a segurança de um carro entre outras coisas, sem precisar matar ninguém para isso. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_razz.gif' alt=':P' class='wp-smiley' /> </p>
<p>No nosso caso, nossos <strong>mock objects são representações de classes reais onde podemos simular e forçar qualquer comportamento que desejamos para testarmos certas situações</strong> que talvez não seriam possíveis de serem alcançadas &#8220;explicitamente&#8221; sem gambiarra-las ou mesmo que sejam de dificil configuração.</p>
<p>Em resumo, usamos um mock quando nossa classe real (<span style="color: #c0c0c0;">colado do wikipedia &#8211; thank&#8217;s god</span>):</p>
<ul>
<li>gera resultados não deterministicos (e.g. a hora ou temperatura atual);</li>
<li>tem estados que são difíceis de criar ou reproduzir (e.g. erro de comunicação da rede);</li>
<li>é lento (e.g. um banco de dados completo que precisa ser inicializado antes do teste);</li>
<li>ainda não existe ou pode ter comportamento alterado;</li>
<li>teriam que adicionar informações e métodos exclusivamente para os testes (e não para sua função real).</li>
</ul>
<p>Analisando nosso problema anterior, podemos constatar que nossa classe <em><span style="text-decoration: underline;">Conexao</span></em> é forte candidata à ser &#8220;mockeada&#8221;: assim nos livramos de todos aqueles problemas de conexão, de existência de registros e tudo mais que não tem nada haver com nosso teste unitário em si, que diz respeito pura e diretamente à nossa classe <em><span style="text-decoration: underline;">Validator</span></em>.</p>
<p>Ou seja, <strong>ao invés de usar a classe Conexao real, vamos usar uma &#8220;imitação&#8221; dela, muito mais simples e fácil de manipular</strong> para chegarmos de forma mais simples ao nosso resultado esperado no teste unitário. Vamos utilizar esse mock pois não faz sentido testar a conexão nem nenhum método dessa classe e sim utilizar o comportamento referente ao código que vamos utilizar no nosso teste.</p>
<h2><span style="font-weight: normal;">Codando!</span></h2>
<p>Como vimos, nossa classe <em><span style="text-decoration: underline;">Conexao</span></em> não tem nada implementado ainda. Mas isso não nos interessa pois vamos fazer um mock da classe, para podermos simular o que precisamos: o retorno dos resultados que desejamos para testar o método <em><span style="text-decoration: underline;">validate</span></em> do <em><span style="text-decoration: underline;">Validator</span></em>.</p>
<p><strong>Para criar um mock de nossa classe</strong>, simplesmente fazemos o include dessa classe em nosso teste e &#8220;geramos&#8221; esse mock com o método <em><span style="text-decoration: underline;">generate</span></em> da classe <em><span style="text-decoration: underline;">Mock</span></em> (que é importada automaticamente no nosso include do autorun.php do Simpletest).</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'conexao.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'validator.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
Mock<span style="color: #339933;">::</span><span style="color: #004000;">generate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Conexao'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></div></td></tr></tbody></table></div>
<p>Com isso, vamos gerar um clone mockeado da classe <span style="text-decoration: underline;"><em>Conexao</em></span> para podermos usa-la em nossos testes.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br />13<br />14<br />15<br />16<br />17<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'conexao.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'validator.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
Mock<span style="color: #339933;">::</span><span style="color: #004000;">generate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Conexao'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> ValidatorTestCase <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> testValidarSeUsuarioExistir<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> MockConexao<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #339933;">...</span><br />
<span style="color: #339933;">...</span><br />
<br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Fácil né ?</p>
<h2><span style="font-weight: normal;">Mocks como atores</span></h2>
<p>Agora que sabemos como criar um mock, <strong>vamos aprender a &#8220;imitar&#8221; o que a classe original faz afim de &#8220;simular&#8221; os resultados</strong> que queremos ter para fazer nossos testes passarem.</p>
<p>Os Mocks podem se comportar de duas maneiras:</p>
<ul>
<li>como <strong>Atores (Actors)</strong>, onde o Mock é usado para simular o retorno de propriedades e métodos (e o que vamos usar aqui).</li>
<li>como <strong>Críticos (Critics)</strong>, onde o Mock é usado para guardar e verificar as interações entre os objetos num teste.</li>
</ul>
<blockquote><p>Quando trabalhamos com o Mock apenas como Ator, apenas simulando o retorno de propriedades e métodos, ele é considerado um &#8220;server stub&#8221;, que nada mais é que um objeto que simula um comportamento. Existe uma grande discussão existe em torno disso, mas por enquanto vamos deixar pra lá pois vamos falar sobre os Mocks como uma ferramenta para testes baseados em interação no próximo post e isso vai ficar mais claro.</p></blockquote>
<p>Se analisarmos a classe <em><span style="text-decoration: underline;">Conexao</span></em> novamente, vamos chegar à conclusão que o método que vai ser utilizado em nosso teste será apenas o <em><span style="text-decoration: underline;">query</span></em>: vamos fazer uma consulta à base dados buscando todos os usuários cujo nome seja igual ao parametro que enviarmos ao método <em><span style="text-decoration: underline;">validate</span></em>.</p>
<p><strong>Nosso mock da </strong><em><span style="text-decoration: underline;"><strong>Conexao</strong></span></em><strong> ainda não sabe fazer nada, mas podemos instrui-lo a retornar o que a quisermos</strong>. Por exemplo, em nosso teste chamado <strong>testValidarSeUsuarioExistir</strong> vamos ter que dizer ao mock para retornar sempre um resultado que satisfaça nosso teste. Ou seja, como no exemplo da implementação, se eu envio &#8220;Léo&#8221; ele tem que me devolver um resultado onde &#8220;Léo&#8221; esteja presente, pois queremos testar o comportamento do <em><span style="text-decoration: underline;">validate</span></em> e não o retorno de valor da conexão.</p>
<p>Então, <strong>vamos fazer nosso mock devolver sempre um resultado onde exista o usuário &#8220;Léo&#8221; no resultado</strong>.</p>
<p>Como vimos, nosso método <em><span style="text-decoration: underline;">query</span></em> retorna uma array com os resultados da consulta. Vamos então instruir o mock a retornar sempre um array quando o método query for chamado. Quando o objeto é mockeado, ele ganha vários métodos, entre eles o <strong>s</strong><strong>etReturnValue: esse método diz ao mock &#8220;retorne sempre X resultado quando tal método for chamado&#8221;</strong>.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> MockConexao<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$conexao</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">setReturnValue</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'query'</span><span style="color: #339933;">,</span><a href="http://www.php.net/array"><span style="color: #990000;">array</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'1'</span><span style="color: #339933;">,</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></div></td></tr></tbody></table></div>
<p>Pronto! Agora podemos testar nosso validate:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br />13<br />14<br />15<br />16<br />17<br />18<br />19<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'conexao.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'validator.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
Mock<span style="color: #339933;">::</span><span style="color: #004000;">generate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Conexao'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> ValidatorTestCase <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> testValidarSeUsuarioExistir<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> MockConexao<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$conexao</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">setReturnValue</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'query'</span><span style="color: #339933;">,</span><a href="http://www.php.net/array"><span style="color: #990000;">array</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'1'</span><span style="color: #339933;">,</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000088;">$validator</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Validator<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertEqual</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$validator</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">validate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>O que aconteceu em nosso teste:</p>
<ul>
<li>Criamos um mock do nossa classe Conexao</li>
<li>Instanciamos esse mock em nosso teste</li>
<li>Instruimos ao mock para que ele devolvesse sempre um array com o usuário Léo quando o método query fosse chamado</li>
<li>Instanciamos nosso validator, passando como parâmetro nossa conexao mockeada</li>
<li>fizemos o teste para verificar se a validação deu certo</li>
</ul>
<p>Fui roda-lo e &#8230;.</p>
<div id="attachment_310" class="wp-caption aligncenter" style="width: 624px"><img class="size-full wp-image-310" title="Opsss! Falhou! :D" src="http://www.leohackin.com.br/wp-content/uploads/2009/12/Captura-de-tela-2009-12-04-às-19.31.10.png" alt="Opsss! Falhou! :D" width="614" height="298" /><p class="wp-caption-text">Opsss! Falhou! <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_biggrin.gif' alt=':D' class='wp-smiley' /> </p></div>
<p>Temos nosso resultado esperado, afinal <strong>não implementamos ainda nosso método <em><span style="text-decoration: underline;">validate</span></em></strong>. Então, vamos resolver isso:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br />13<br />14<br />15<br />16<br />17<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> Validator <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">var</span> <span style="color: #000088;">$conexao</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> __construct<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">conexao</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$conexao</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">public</span> <span style="color: #000000; font-weight: bold;">function</span> validate<span style="color: #009900;">&#40;</span><span style="color: #000088;">$nome</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #000088;">$resultados</span> <span style="color: #339933;">=</span> <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">conexao</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">query</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;select id, nome from users where nome = '<span style="color: #006699; font-weight: bold;">{$nome}</span>'&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/array_search"><span style="color: #990000;">array_search</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$nome</span><span style="color: #339933;">,</span><span style="color: #000088;">$resultados</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span><br />
<span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">false</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Implementamos uma lógica onde fazemos uma pesquisa ao banco pedindo para selecionar o id e o nome da tabela users onde o nome seja igual ao parâmetro enviado. <strong>A mágica acontece finalmente</strong>: nossa &#8221; falsa conexao&#8221; foi instruída a retornar sempre um array com uma posição apenas, onde o resultado sempre é Léo. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Agora quando rodamos o teste:</p>
<div id="attachment_315" class="wp-caption aligncenter" style="width: 521px"><img class="size-full wp-image-315" title="Teste do validator agora com a implementação" src="http://www.leohackin.com.br/wp-content/uploads/2009/12/Captura-de-tela-2009-12-05-às-10.25.05.png" alt="Teste do validator agora com a implementação" width="511" height="281" /><p class="wp-caption-text">Teste do validator agora com a implementação</p></div>
<p><strong>Bingo! Nosso teste passou!</strong></p>
<p>Para comprovarmos que o funcionamento do <em><span style="text-decoration: underline;">validate</span></em> está correto, vamos complementar nosso caso de teste adicionando um teste pra verificar se informarmos um usuário que não existe, ele retornar false.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;height:350px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br />13<br />14<br />15<br />16<br />17<br />18<br />19<br />20<br />21<br />22<br />23<br />24<br />25<br />26<br />27<br />28<br />29<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'conexao.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'validator.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
Mock<span style="color: #339933;">::</span><span style="color: #004000;">generate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Conexao'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> ValidatorTestCase <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> testValidarSeUsuarioExistir<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> MockConexao<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$conexao</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">setReturnValue</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'query'</span><span style="color: #339933;">,</span><a href="http://www.php.net/array"><span style="color: #990000;">array</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'1'</span><span style="color: #339933;">,</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000088;">$validator</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Validator<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertEqual</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$validator</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">validate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #009900; font-weight: bold;">true</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> testNaoValidarSeUsuarioNaoExistir<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000088;">$conexao</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> MockConexao<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$conexao</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">setReturnValue</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'query'</span><span style="color: #339933;">,</span><a href="http://www.php.net/array"><span style="color: #990000;">array</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'1'</span><span style="color: #339933;">,</span><span style="color: #0000ff;">'Léo'</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000088;">$validator</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Validator<span style="color: #009900;">&#40;</span><span style="color: #000088;">$conexao</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertEqual</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$validator</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">validate</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Jeveaux'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #009900; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Vamos testar denovo e &#8230;</p>
<div id="attachment_322" class="wp-caption aligncenter" style="width: 523px"><img class="size-full wp-image-322" title="Fazendo dois testes" src="http://www.leohackin.com.br/wp-content/uploads/2009/12/Captura-de-tela-2009-12-05-às-12.42.23.png" alt="Fazendo dois testes" width="513" height="281" /><p class="wp-caption-text">Fazendo dois testes</p></div>
<p>Mantemos o nosso mock retornando apenas &#8220;Léo&#8221; nos resultados, mas dessa vez passamos o nome &#8220;Jeveaux&#8221; para procurar e como esperado, ele retornou false, dado que o usuário &#8220;Jeveaux&#8221; não existe. <strong>Show!</strong></p>
<h2><span style="font-weight: normal;">Ufa! Vamos resumir o testamento</span></h2>
<p>O aprendizado de mock objects é um pouco abstrato inicialmente mas com alguma prática se revela uma técnica perfeita e viável para fazemos nossos testes unitários funcionarem de forma correta e independente. A utilização do Mock Object apenas como ator (ou server stub como você lerá muito por ai) é apenas uma parte do poder real de um mock.</p>
<p>Dentro de nosso entendimento, podemos resumir que um<strong><em> mock object é uma imitação de nosso objeto real que podemos manipular de forma fácil e simples para que ele faça exatamente o que quisermos, facilitando assim a implementação de nossos testes unitários e isolando nossas classes</em></strong>.</p>
<p>Algumas leituras legais melhorar o entendimento dos Mock Objects:</p>
<ul>
<li><a href="http://www.simpletest.org/en/mock_objects_documentation.html" target="_blank">Mock Objects no SimpleTest [ doc oficial do SimpleTest ]</a></li>
<li><a href="http://www.improveit.com.br/xp/praticas/tdd/mock_objects" target="_blank">Testes de unidade com mock objects [ ImproveIt ]</a></li>
<li><a href="http://codebetter.com/blogs/jeremy.miller/archive/2005/12/19/135757.aspx" target="_blank">Mock Objects and Stubs: The Bottle Brush of TD</a>D</li>
<li><a href="http://pt.wikipedia.org/wiki/Mock_Object" target="_blank">Mock Objects [ Wikipedia]</a></li>
</ul>
<p>Outra referência bem bacana é o <a href="http://www.jeveaux.com" target="_blank">blog do Jeveaux</a>, meu revisor TDD oficial e grande conhecer de causa. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>No próximo post vamos ver como trabalhar com nosso Mock Object em sua forma mais plena e com um exemplo um pouco mais complexo para partir também para o modo Critic. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Simbora.</p>

]]></content:encoded>
			<wfw:commentRss>http://www.leohackin.com.br/2009/12/mock-objects-no-simpletest/feed/</wfw:commentRss>
		<slash:comments>16</slash:comments>
		</item>
		<item>
		<title>Agrupando casos de teste no SimpleTest</title>
		<link>http://www.leohackin.com.br/2009/07/agrupando-casos-de-teste-no-simpletest/</link>
		<comments>http://www.leohackin.com.br/2009/07/agrupando-casos-de-teste-no-simpletest/#comments</comments>
		<pubDate>Mon, 27 Jul 2009 02:33:13 +0000</pubDate>
		<dc:creator>Léo Hackin</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[tdd]]></category>
		<category><![CDATA[simpletest]]></category>

		<guid isPermaLink="false">http://leohackin.com.br/blog/?p=162</guid>
		<description><![CDATA[Aloha, Primeiramente, obrigado ao pessoal pelas belas palavras de incentivo e tudo mais: é esse tipo de coisa que nos empolga pra continuar trabalhando e estudando duro. Em nosso post de iniciação no SimpleTest, criamos um caso de teste completo de uma calculadora. Relembrando nossa telinha bonita do caso de teste&#8230; Agora vejamos &#8230; e [...]]]></description>
			<content:encoded><![CDATA[
<div class="topsy_widget_data topsy_theme_jade" style="float: right;margin-left: 0.75em;"><script type="text/javascript" src="http://button.topsy.com/widget/retweet-small?url=http://www.leohackin.com.br/2009/07/agrupando-casos-de-teste-no-simpletest/&amp;shorturl=http://bit.ly/aDSGQe&amp;title=Agrupando+casos+de+teste+no+SimpleTest&amp;theme=jade&amp;order=count,retweet,badge&amp;txt_tweet=tuit&amp;txt_retweet=retuit"></script></div><p>Aloha,</p>
<p>Primeiramente, obrigado ao pessoal pelas belas palavras de incentivo e tudo mais: é esse tipo de coisa que nos empolga pra continuar trabalhando e estudando duro.</p>
<p>Em nosso post de iniciação no <a href="http://www.simpletest.org" target="_blank">SimpleTest</a>, criamos um caso de teste completo de uma calculadora. Relembrando nossa telinha bonita do caso de teste&#8230;</p>
<p><img class="alignnone size-medium wp-image-164" title="ishot-1" src="http://leohackin.com.br/wp-content/uploads/2009/07/ishot-1-300x155.jpg" alt="ishot-1" width="300" height="155" /></p>
<p>Agora vejamos &#8230; e se por exemplo, tivéssemos <strong>não apenas uma calculadora</strong> em nossa aplicação, mas também uma agenda de compromissos, uma agenda de contatos, um wiki, um mural de recados e &#8230; enfim, se nossa <strong>aplicação fosse composta por N classes</strong> como faríamos para rodar os casos de teste unitários de TODAS AS CLASSES ?</p>
<p>Na TDD, como vimos antes, escrevemos todos os testes antes de começarmos a implementar nossa aplicação em si: quando pensamos &#8220;rodar os testes&#8221; isso se aplica à todas as classes e funcionalidades que possam gerar erros em nossa aplicação.</p>
<p>Ai você: <em>&#8220;Rapaz, vou ter que acessar teste por teste  como fiz com a calculadora? Mamãe, eu tenho 253 casos de uso!!!!&#8221;</em></p>
<p>Imagina só se você executar, URL por URL ou comando por comando, 253 casos de uso. =/</p>
<p>Pensando nisso, a SimpleTest disponibiliza um <strong>recurso de agrupamento </strong>de casos de teste chamado de <strong>Test Suite</strong>. Esse recurso permite agrupar vários casos de testes numa só classe, facilitando e permitindo a execução desses testes com uma só chamada.</p>
<p>Seria como um script de checagem, onde cada item seria um caso de teste:</p>
<p>Checagem do carro</p>
<ol>
<li>Checar Óleo</li>
<li>Checar Rodas</li>
<li>Checar Água Carburador</li>
<li>Checar itens de segurança</li>
</ol>
<p>A test suite funciona exatamente assim, executando cada caso de teste na ordem que você desejar: o &#8220;check list&#8221; roda e no final você tem todos as falhas que ocorreram, separadas por caso de test e método. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<h2>Codando!</h2>
<p>Bom, vamos supor que vamos ter uma aplicação composta por 5 classes: ClasseA, ClasseB, ClasseC, ClasseD e ClasseE. Cada uma delas tem suas próprias implementações e vamos ter que fazer casos de testes que testem elas individualmente.</p>
<p>Para ilustrar o funcionamento, vamos escrever um método para todas as classes chamado <span style="text-decoration: underline;"><em>Dizer</em></span>: esse método deverá receber a uma string e retornar &#8220;Estou dizendo &#8221; concatenado com o que você passou como parâmetro. Exemplificando</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000088;">$obj</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">Dizer</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Muito Bacana'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span> <span style="color: #666666; font-style: italic;">// Estou Dizendo Muito Bacana</span></div></td></tr></tbody></table></div>
<p>Vamos botar esse método em todas as classes apenas para simularmos as passagens e não passagens de teste delas. hehhehe</p>
<p>Bom, partindo do pressuposto que você esteja com o SimpleTest instalado e com nossa estrutura de arquivos do artigo de iniciação à ele, vamos escrever o caso de teste da ClasseA que será salvo dentro da nossa pasta <em>tests</em> e terá o nome de <strong>classe_a_test.php</strong>.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'../classes/classe_a.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;&lt;/</span>code<span style="color: #339933;">&gt;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> TestOfClasseA <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<br />
&nbsp; <span style="color: #000000; font-weight: bold;">function</span> testDizer<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$classea</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> ClasseA<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertIdentical</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$classea</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">dizer</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'Muito Bacana'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'Estou dizendo Muito Bacana'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; <span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Relembrando um pouco:</p>
<ul>
<li>Fazemos o include do arquito <em>autorun.php</em> para automatizar nossos testes;</li>
<li>Fazemos o include da classe que vai ser testada</li>
<li>Implementamos a classe de teste iniciando por &#8220;Test&#8221; afim de que a SimpleTest execute-a automaticamente;</li>
<li>Criamos o método <em>testDizer</em> para testar o método dizer da nossa <em>ClasseA</em>;</li>
<li>Fazemos um <em>assertIdentical</em> que executará nosso método dizer passando &#8220;Muito Bacana&#8221; e esperará como resultado algo IDENTICO à &#8220;Estou dizendo Muito Bacana&#8221;;</li>
</ul>
<p>Beleza, agora vamos rodar nosso teste &#8230;</p>
<p style="text-align: center;"><img class="aligncenter size-full wp-image-170" title="Imagem14" src="http://leohackin.com.br/wp-content/uploads/2009/07/Imagem14.png" alt="Imagem14" width="560" height="341" /></p>
<p>Como era esperado (espero) nosso teste deu pau porque não escrevemos nossa ClasseA ainda em arquivo algum. Então, vamos escrevê-la e salva-la dentro da pasta <em>classes</em> com o nome de <strong>classe_a.php</strong>:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> ClasseA <span style="color: #009900;">&#123;</span><br />
&nbsp; <span style="color: #000000; font-weight: bold;">function</span> dizer<span style="color: #009900;">&#40;</span><span style="color: #000088;">$frase</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
&nbsp; &nbsp; <span style="color: #b1b100;">return</span> <span style="color: #0000ff;">'Estou dizendo '</span> <span style="color: #339933;">.</span> <span style="color: #000088;">$frase</span><span style="color: #339933;">;</span><br />
&nbsp; <span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Agora, vamos rodar novamente nosso teste:</p>
<p style="text-align: center;"><img class="aligncenter size-full wp-image-171" title="Imagem15" src="http://leohackin.com.br/wp-content/uploads/2009/07/Imagem15.png" alt="Imagem15" width="567" height="285" /></p>
<p><strong>Massa demais!</strong> Fizemos novamente um caso de teste. Até ai nenhuma novidade.</p>
<p>Agora o exercício braçal: crie os casos de teste para a ClasseB. ClasseC, ClasseD e ClasseE lembrando que:</p>
<ul>
<li>Classes da aplicação devem ser salvas dentro da pasta classes</li>
<li>Classes dos casos de teste dentro da pasta tests</li>
</ul>
<p>Após a criação delas, faça os testes (jura?) e veja se está tudo ok.</p>
<h2>Criando nossa suite de testes</h2>
<p>Agora que executamos todos os testes de forma separada, vamos junta-los em nossa suite para faze-los todos de uma vez só.</p>
<p>Vamos criar nossa suite de testes no arquivo <strong>all_tests.php</strong> e salva-lo na pasta <em>tests</em> junto com todos os nosses casos de uso.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br />12<br />13<br />14<br />15<br />16<br />17<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'classe_a_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'classe_b_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'classe_c_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'classe_d_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'classe_e_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> AllTests <span style="color: #000000; font-weight: bold;">extends</span> TestSuite <span style="color: #009900;">&#123;</span><br />
&nbsp; <span style="color: #000000; font-weight: bold;">function</span> AllTests<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">TestSuite</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'All tests'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addTestCase</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> TestOfClasseA<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addTestCase</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> TestOfClasseB<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addTestCase</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> TestOfClasseC<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addTestCase</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> TestOfClasseD<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addTestCase</span><span style="color: #009900;">&#40;</span><span style="color: #000000; font-weight: bold;">new</span> TestOfClasseE<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; <span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Explicando nosso script:</p>
<ul>
<li>fazemos o include de <em>simpletest/autorun.php</em> para fazer rodar nossos testes</li>
<li>fazemos os includes de todas os casos de testes que usaremos na suite</li>
<li>criamos uma classe <em>AllTests</em> que extende <em>TestSuite</em>, que por sua vez é a classe que será responsável pelo agrupamento e execução de todos os testes</li>
<li>criamos um método <em>AllTests</em> que fará a execução dos casos de teste</li>
<li>Nomeamos a suite de testes com o nome <em>All tests</em> com o método $this-&gt;TestSuite;</li>
<li>Adicionamos então todos os nossos casos de teste com o método $this-&gt;addTestCase, instanciando o objeto de cada classe de teste</li>
</ul>
<p>Agora, basta rodar:</p>
<p><img class="size-full wp-image-181  alignnone" title="Imagem2" src="http://leohackin.com.br/wp-content/uploads/2009/07/Imagem2.png" alt="Imagem2" width="560" height="274" /></p>
<p><strong>Pronto!</strong> Nossa suite agrupou nossos testes (que eram cinco ao todo, cada um com um método de teste) e executou todos de uma vez. A lógica da suíte é você inserir os testes conforme seu contexto e sua necessidade de agrupamento de testes. Para incluir, basta repetir o procedimento já feito no arquivo da suíte:</p>
<ul>
<li>faça o require_once do arquivo php do caso de teste</li>
<li>inclua o caso de teste com $this-&gt;addTestCase</li>
</ul>
<p><strong>E se algum teste falha-se ?</strong> Vamos fazer o teste da ClasseB falhar. Para isso altere a classe B para para retornar algo que não seja &#8220;Estou dizendo &#8221; mas sim &#8220;Eu vou dizer &#8220;: com isso, nosso teste vai falhar. Após alterar a classeB, rode a suite de testes novamente:</p>
<p><img class="size-full wp-image-183 alignnone" title="Imagem3" src="http://leohackin.com.br/wp-content/uploads/2009/07/Imagem31.png" alt="Imagem3" width="565" height="277" /></p>
<p>Como pode ser visto, nossa suite de testes dá o erro exetamente onde ele aconteceu: no nosso caso, a suite de testes que chamamos de All tests reportou o erro do caso de teste TestOfClasseB no método testDizer. Maneirasso não ?</p>
<p>Nossa suite mostra todas as falhas por caso de teste. Simples e rápido.</p>
<h2>E vamos às considerações</h2>
<p>A forma que fizemos a construção da nossa suite de testes está diferente da forma em que o próprio site da SimpleTest (<a href="http://www.simpletest.org/en/start-testing.html" target="_blank">http://www.simpletest.org/en/start-testing.html</a>) mostra em sua página inicial no Quick Start dele, que está diferente do <a href="http://www.simpletest.org/en/group_test_tutorial.html" target="_blank">link que deveria ser a mesma explicação mais detalhada</a>, mas não é. Se olharmos o script de test suite do quick start teremos, aplicando ao nosso exemplo, teríamos:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> AllTests <span style="color: #000000; font-weight: bold;">extends</span> TestSuite <span style="color: #009900;">&#123;</span><br />
&nbsp; <span style="color: #000000; font-weight: bold;">function</span> AllTests<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">TestSuite</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'All tests'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addFile</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'classe_a_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #666666; font-style: italic;">//... outros casos de teste ...</span><br />
&nbsp; <span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Concerteza é um jeito mais prático: ao invés de fazer-mos os includes dos casos de testes e fazermos os instanciamentos dos mesmos no addTestCase, requerendo mais programação, simplesmente podemos incluir o teste com um addFile. E isso realmente funciona. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />  Mas infelizmente não sem algumas adaptações no código.</p>
<p>Se quiser re-escrever sua suite de testes nesse formato, se atente ao fato que o SimpleTest aparentemente trabalha com a suite de testes acessando os caminhos absolutos dos arquivos e se perde quando referenciamos nossos arquivos, mesmo que eles estejam na mesma pasta tests. Para contornar isso, coloque a inclusão do arquivo de classe no caso de testes e a referência ao arquivo do caso de teste na suite com seus caminhos absolutos. Vamos isso na classeA por exemplo:</p>
<p>Na classe_a_test.php teríamos:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_SERVER</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'DOCUMENT_ROOT'</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">.</span> <span style="color: #0000ff;">'/app_tdd/classes/classe_a.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span></div></td></tr></tbody></table></div>
<p>E na nossa suite all_tests.php seria re-escrita como:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> AllTests <span style="color: #000000; font-weight: bold;">extends</span> TestSuite <span style="color: #009900;">&#123;</span><br />
&nbsp; <span style="color: #000000; font-weight: bold;">function</span> AllTests<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">TestSuite</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'All tests'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; &nbsp; <span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">addFile</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$_SERVER</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'DOCUMENT_ROOT'</span><span style="color: #009900;">&#93;</span> <span style="color: #339933;">.</span> <span style="color: #0000ff;">'/app_tdd/tests/classe_a_test.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
&nbsp; <span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Espero que tenham gostado e no próximo post falaremos um pouco sobre MockObjetcs. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>Até lá.</p>

]]></content:encoded>
			<wfw:commentRss>http://www.leohackin.com.br/2009/07/agrupando-casos-de-teste-no-simpletest/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Iniciando com o SimpleTest</title>
		<link>http://www.leohackin.com.br/2009/07/iniciando-com-o-simpletest/</link>
		<comments>http://www.leohackin.com.br/2009/07/iniciando-com-o-simpletest/#comments</comments>
		<pubDate>Thu, 02 Jul 2009 20:11:24 +0000</pubDate>
		<dc:creator>Léo Hackin</dc:creator>
				<category><![CDATA[PHP]]></category>
		<category><![CDATA[tdd]]></category>
		<category><![CDATA[simpletest]]></category>

		<guid isPermaLink="false">http://leohackin.com.br/blog/?p=119</guid>
		<description><![CDATA[Salve people, Vamos iniciar hoje uma pequena jornada à terras que possivelmente muita gente só viu/leu em sites especializados e muito pouco comentadas em PHP: a terra do desenvolvimento orientado a testes, ou TDD. Se você não sabe ou nem faz idéia do que é TDD, dê uma procura no Google pois existem dezenas de [...]]]></description>
			<content:encoded><![CDATA[
<div class="topsy_widget_data topsy_theme_jade" style="float: right;margin-left: 0.75em;"><script type="text/javascript" src="http://button.topsy.com/widget/retweet-small?url=http://www.leohackin.com.br/2009/07/iniciando-com-o-simpletest/&amp;shorturl=http://bit.ly/5e07yU&amp;title=Iniciando+com+o+SimpleTest&amp;theme=jade&amp;order=count,retweet,badge&amp;txt_tweet=tuit&amp;txt_retweet=retuit"></script></div><p>Salve people,</p>
<p>Vamos iniciar hoje uma pequena jornada à terras que possivelmente muita gente só viu/leu em sites especializados e muito pouco comentadas em PHP: a terra do desenvolvimento orientado a testes, ou <strong>TDD</strong>.</p>
<p>Se você não sabe ou nem faz idéia do que é TDD, dê uma procura no <strong>Google</strong> pois existem dezenas de sites muito bacanas destilando idéias e tudo mais sobre isso.</p>
<p><em>Em poucas palavras, </em><strong><em>TDD</em></strong><em> (Test Driven Development) é um técnica de desenvolvimento de software que nos diz que devemos escrever os testes antes de escrever o código da aplicação propriamente dito.</em></p>
<p>Inicialmente isso parece meio louco: afinal, você sempre testa DEPOIS de escrever seus programas ou durante, enquanto debuga tudo, correto ? Mas com o passar do tempo, a verdadeira natureza e vantagem do TDD, quando aplicada corretamente, se faz presente.</p>
<p>Você se torna capaz de antecipar a detecção e correção de várias falhas, reduzindo dramaticamente o tempo gasto com correções em cima de implementações muito complexas já praticamente no final do seu cronograma.</p>
<p>Hoje em dia, existem várias frameworks que auxiliam nessa tarefa de escrever testes. O foco aqui é algo que poucos sites (principalmente em português) abordam de forma prática que é o uso da <strong><a href="http://www.simpletest.org" target="_blank">SimpleTest</a></strong>, uma framework para testes unitários que vem ganhando o espaço antes ocupado pelo <a href="http://www.phpunit.de/" target="_blank">PHPUnit</a>.</p>
<p>No decorrer dos próximos posts sobre o SimpleTest, você poderá adquirir um pouco de conhecimento que poderá ser útil em seus futuros projetos. Então, vamos simbora.</p>
<h2>Instalando o SimpleTest</h2>
<p>A instalação do SimpleTest em si é muito fácil.</p>
<ol>
<li>Baixe a versão mais atual do SimpleTest no site <a href="http://www.simpletest.org" target="_blank">http://www.simpletest.org</a> (a versão que usaremos nessa sequência de tutoriais é a 1.0.1). A framework é composta por uma pasta simples;</li>
<li>Descompacte o arquivo dentro de sua aplicação. Para fins de organização, vamos criar uma pasta &#8220;tests&#8221; na raíz de nossa aplicação e descompactar o zip/tar do SimpleTest lá: ao descompactar você verá uma pasta chamada <em>simpletest</em> sendo criada.</li>
</ol>
<p>Em tese, nossa aplicação pode ter qualquer estrutura de diretórios. O SimpleTest funciona tanto com functions como com classes. Vamos abordar o uso de classes, dado que o TDD é amplamente usado em sua maioria em soluções OO (Orientadas a Objeto) e acho que já passou da hora da comunidade PHP pensar OO. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_biggrin.gif' alt=':D' class='wp-smiley' /> </p>
<p>Partindo desse pressuposto, vamos criar a pasta &#8220;<em><strong>classes</strong></em>&#8221; na raíz de nossa aplicação: lá iremos botar todas as nossas classes que serão usadas nos testes.</p>
<p>Teremos então, uma estrutura de arquivos como abaixo:</p>
<p><img class="alignnone size-full wp-image-120" title="imagem5" src="http://leohackin.com.br/wp-content/uploads/2009/07/imagem5.png" alt="imagem5" width="231" height="101" /></p>
<p>A pasta <strong>app_tdd </strong>é a pasta onde está nossa aplicação: uma pasta criada dentro do meu htdocs (raíz do Apache).</p>
<p>Se o seu servidor web estiver instalado com configurações padrão, provavelmente você poderá acessar usando: <em><a href="http://localhost/app_tdd" target="_blank">http://localhost/app_tdd</a></em></p>
<h2><strong>Nosso problema: uma calculadora</strong></h2>
<p>Com o SimpleTest &#8220;instalado&#8221; em nossa aplicação e nossa estrutura de diretórios resolvida, vamos escrever nosso primeiro caso de teste.</p>
<p>O cenário de nossa aplicação é uma <strong>calculadora</strong>: nossa calculadora conseguirá efetuar apenas a operação de soma.</p>
<p>Com uma análise rápida do problema, já nos vem à cabeça que:</p>
<ul>
<li>Uma classe chamada &#8220;Calculadora&#8221; com um método chamado &#8220;soma&#8221;;</li>
<li>Nosso método soma recebendo dois números</li>
<li>Nosso método retornando o valor da soma entre os dois números</li>
</ul>
<p><strong>Nossa abordagem não TDD seria</strong>: vamos fazer a classe, implementar o método e depois testa-lo em uma página teste. Correto ? Num primeiro momento isso seria ótimo: afinal, o código e complexidade das classes inicialmente são lindos.</p>
<p>Mas <strong>imagine agora sua aplicação crescendo e crescendo</strong>: classes extendendo e usando outras classes. Você extende a Calculadora, outra classe utiliza o método soma e você vai testando apenas &#8220;o que vem depois&#8221;.</p>
<p>Num dado momento, <strong>você tem um resultado incorreto de soma</strong>: uma entrada incorreta de parâmetros, um deles ser uma letra e não um número, termos uma passagem de um objeto ao invés de um número propriamente dito &#8230; <strong>De quem é a culpa ?</strong> Da classe nova, que esqueceu de filtrar a entrada de parametros ? Do designer, que esqueceu de limitar a entrada dos valores no form para apenas números ? Do outro programador, que foi descuidado e não validou se os dados passados eram realmente números antes de chamar a soma ?</p>
<p><strong>Enfim, temos N cenários onde a detecção do erro pode ser muito custosa</strong>, seja pelo método para encontra-lo (que varia do debug minucioso ao &#8220;achismo&#8221;) e/ou pelo custo em termos de tempo para concerta-lo. Tudo isso pode gerar um custo/prejuízo que seria reduzido com a implementação do pensando TDD.</p>
<h2>Pensando primeiro em testes</h2>
<p><strong>Mentalize</strong>: <em>&#8220;Quais as situações que podem quebrar meu método soma? Se acontecer, como devo tratar esse erro ?&#8221;</em></p>
<p>Com base nesse pensamento, podemos deduzir:</p>
<ul>
<li>Para somar, nossa calculadora terá que receber sempre <strong>dois números</strong>;</li>
<li>A soma sempre ocorre entre dois números, nunca entre letras, objetos ou qualquer coisa que não seja exatamente um número;</li>
<li>Se algo der erro, devo retornar falso;</li>
</ul>
<p><strong>Interessante!</strong> Não implementamos nenhuma linha de nossa solução e já sabemos:</p>
<ul>
<li>Que vamos precisar de uma classe (Calculadora) com um método de soma;</li>
<li>Sabemos que o método deverá receber dois parâmetros que deverão ser sempre números;</li>
<li>Que se for passado qualquer coisa que não sejam dois números, eu devo retornar falso;</li>
</ul>
<p><strong>Bom, então vamos implementar a classe ?</strong> Não, pequeno gafanhoto: <strong>vamos implementar primeiro os testes</strong>, porque é com base neles que vamos ter certeza que nossa classe se comportará exatamente como pensamos que ela deve se comportar sob os mais diversos cenários.</p>
<h2>Escrevendo nosso primeiro teste</h2>
<p>Implementar um teste com SimpleTest é, como o nome já diz, &#8220;simples&#8221;.</p>
<p>Vamos criar todos os nossos testes dentro da pasta <em><span style="text-decoration: underline;">tests</span></em>. Para cada classe que tivermos que testar, vamos criar um caso de teste (unit test case) que será representado em um arquivo php.</p>
<p>Então, nosso primeiro caso de teste será o <strong>calculadora_test.php</strong>. O nome do arquivo não tem um padrão de nomenclatura, mas por convenção usa-se sempre<em> nomedaclasse</em><em>_test.php</em>.</p>
<p><strong>calculadora.php -&gt; calculadora_test.php</strong></p>
<p>A estrutura inicial do nosso arquivo calculadora_test.php será a seguinte:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'../classes/calculadora.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> TestOfCalculadora <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<span style="color: #666666; font-style: italic;">// os testes vão aqui ;)</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p><strong>Pronto!</strong> Nosso caso de teste da classe Calculadora está feito. Para testa-lo, vamos apontar o browser para <a href="http://localhost/app_tdd/tests/calculadora_test.php" target="_blank">http://localhost/app_tdd/tests/calculadora_test.php</a>. O resultado será:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap">Warning<span style="color: #339933;">:</span> <span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">../</span>classes<span style="color: #339933;">/</span>calculadora<span style="color: #339933;">.</span>php<span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#91;</span><span style="color: #000000; font-weight: bold;">function</span><span style="color: #339933;">.</span>require<span style="color: #339933;">-</span>once<span style="color: #009900;">&#93;</span><span style="color: #339933;">:</span> failed to open stream<span style="color: #339933;">:</span> No such <a href="http://www.php.net/file"><span style="color: #990000;">file</span></a> or directory in <span style="color: #339933;">/</span>Applications<span style="color: #339933;">/</span>MAMP<span style="color: #339933;">/</span>htdocs<span style="color: #339933;">/</span>app_tdd<span style="color: #339933;">/</span>tests<span style="color: #339933;">/</span>calculadora_test<span style="color: #339933;">.</span>php on line 4<br />
<br />
Fatal error<span style="color: #339933;">:</span> <span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#91;</span><span style="color: #000000; font-weight: bold;">function</span><span style="color: #339933;">.</span><span style="color: #b1b100;">require</span><span style="color: #009900;">&#93;</span><span style="color: #339933;">:</span> Failed opening required <span style="color: #0000ff;">'../classes/calculadora.php'</span> <span style="color: #009900;">&#40;</span>include_path<span style="color: #339933;">=</span><span style="color: #0000ff;">'.:/Applications/MAMP/bin/php5/lib/php:/Users/leohackin/PEAR'</span><span style="color: #009900;">&#41;</span> in <span style="color: #339933;">/</span>Applications<span style="color: #339933;">/</span>MAMP<span style="color: #339933;">/</span>htdocs<span style="color: #339933;">/</span>app_tdd<span style="color: #339933;">/</span>tests<span style="color: #339933;">/</span>calculadora_test<span style="color: #339933;">.</span>php on line <span style="color: #cc66cc;">4</span></div></td></tr></tbody></table></div>
<p><strong>Ops! </strong>Não criamos nossa classe ainda, por isso obtemos esse erro. Quando disse que escrevemos testes antes de implementar nossa lógica, estava falando sério. =)</p>
<p>Vamos criar nossa classe Calculadora então.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> Calculadora <span style="color: #009900;">&#123;</span><br />
<span style="color: #000000; font-weight: bold;">function</span> soma<span style="color: #009900;">&#40;</span><span style="color: #000088;">$a</span><span style="color: #339933;">,</span><span style="color: #000088;">$b</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Legal, agora vamos acessar nosso caso de teste denovo.</p>
<p><img class="alignnone size-full wp-image-146" title="imagem6" src="http://leohackin.com.br/wp-content/uploads/2009/07/imagem6.png" alt="imagem6" width="458" height="240" /></p>
<p><strong>Uhu! Funfou!!!</strong></p>
<p>Analisando o código:</p>
<ul>
<li>fazemos o include de dois arquivos:
<ul>
<li>o arquivo autorun.php é o arquivo que faz a &#8220;mágica&#8221; acontecer: é ele quem roda os testes e exibe os resultados, portanto deverá sempre estar no seu caso de teste;</li>
</ul>
<ul>
<li>o outro arquivo é a classe que desejamos usar no teste, no caso calculadora.php</li>
</ul>
</li>
<li>Criamos uma classe chamada <span style="text-decoration: underline;"><em>TestOfCalculadora</em></span> extendendo <em><span style="text-decoration: underline;">UnitTestCase</span></em>, que será a classe que o SimpleTest usará para fazer o teste. <strong>É obrigatório que a classe inicie com o nome &#8220;test&#8221; para que o SimpleTest execute automaticamente</strong> a mesma como um caso de teste. Existe uma forma de faze-lo sem iniciar o nome com &#8220;test&#8221;, mas isso não vem ao caso agora.</li>
</ul>
<p><strong>Maneiro né ?</strong> Mas como puderam notar, <strong>nosso caso de teste não testa nada ainda</strong>. Hahahah</p>
<p><strong>Vamos adicionar agora um teste</strong>: o teste vai verificar se a soma está realmente &#8220;somando&#8221; dois números. Para isso, devemos adicionar um método à nossa classe de testes. Vamos chamar esse teste de &#8220;<em><span style="text-decoration: underline;">testSomaDoisNumerosInteiros</span></em>&#8220;, onde vamos passar dois números inteiros esperando que a soma deles esteja correta.</p>
<p>Usar nomes grandes assim no nome do método são uma boa prática, já que deixam os testes mais legíveis na hora de rodar o caso de teste.</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br />10<br />11<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'simpletest/autorun.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #b1b100;">require_once</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'../classes/calculadora.php'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">class</span> TestOfCalculadora <span style="color: #000000; font-weight: bold;">extends</span> UnitTestCase <span style="color: #009900;">&#123;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">function</span> testSomaDoisNumerosInteiros<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #000088;">$calculadora</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Calculadora<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertEqual</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$calculadora</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">soma</span><span style="color: #009900;">&#40;</span>1<span style="color: #339933;">,</span>1<span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> 2<span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span><br />
<br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Como visto, temos nosso método <em><span style="text-decoration: underline;">testSomaDoisNumerosInteiros</span></em> que instancia nossa <span style="text-decoration: underline;">classe </span><em><span style="text-decoration: underline;">Calculadora</span></em> e depois executa um método chamado <em><span style="text-decoration: underline;">assertEqual</span></em>. Esse método é o responsável por testar nossa soma. Ele significa:</p>
<p><em>Verifique se a chamada </em><span style="text-decoration: underline;"><em>$calculadora-&gt;soma(1,1)</em></span><em> retornará um resultado </em><strong><em>igual à 2</em></strong></p>
<p>Se a chamada retornar qualquer coisa diferente de dois, nosso teste irá falhar, indentificando que algo de podre está acontecendo em nosso método soma.</p>
<p>Se rodarmos esse script teremos enfim:</p>
<p><img class="alignnone size-full wp-image-149" style="border: 1px solid black;" title="imagem1" src="http://leohackin.com.br/wp-content/uploads/2009/07/imagem1.png" alt="imagem1" width="829" height="273" /></p>
<p><strong>Tivemos uma falha</strong>. Traduzindo a mensagem de forma prática:</p>
<p><em>O seu teste testSomeDoisNumerosInteiros, do caso de teste TestOfCalculadora, falhou porque NULL (que foi retornado pela chamada ao nosso método soma) não é igual a 2 (que seria nossa resposta esperada).</em></p>
<p>A resposta para isso é que ainda nem implementamos nosso método soma. Mas vejamos que nesse ponto já sabemos exatamente como deve ser comportar nosso método para o funcionamento com dois números. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Vamos implementar nossa classe então:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> Calculadora <span style="color: #009900;">&#123;</span><br />
<span style="color: #000000; font-weight: bold;">function</span> soma<span style="color: #009900;">&#40;</span><span style="color: #000088;">$a</span><span style="color: #339933;">,</span><span style="color: #000088;">$b</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #b1b100;">return</span> <span style="color: #000088;">$a</span> <span style="color: #339933;">+</span> <span style="color: #000088;">$b</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Com nosso método agora implementado, vamos executar nosso caso de teste denovo.</p>
<p><img class="alignnone size-full wp-image-150" title="imagem2" src="http://leohackin.com.br/wp-content/uploads/2009/07/imagem2.png" alt="imagem2" width="497" height="245" /></p>
<p><strong>Agora sim!</strong> Temos um caso de teste funcional que testa uma classe implementada. Parabéns por chegar até aqui.</p>
<p>Nesse ponto, já temos conhecimento suficiente para escrever vários casos de teste para nossas classes<strong>. Um caso de teste pode conter vários testes diferentes: cada teste é feito através de um método da classe do caso de teste.</strong></p>
<p>Revisando aquelas possibilidades de cenário que poderiam &#8220;quebrar&#8221; nossa calculadora, já testamos se a soma está correta. Agora, podemos testar as possibilidades que podem gerar um erro na calculadora.</p>
<p>Uma delas é se passarmos letras no lugar de números: haviamos combinado que nessa situação, devolveriamos falso para o resultado, correto ? Então, vamos escrever o teste: vamos chama-lo de &#8220;<em><span style="text-decoration: underline;">testSomaNaoNumeros</span></em>&#8220;:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">function</span> testSomaNaoNumeros<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #000088;">$calculadora</span> <span style="color: #339933;">=</span> <span style="color: #000000; font-weight: bold;">new</span> Calculadora<span style="color: #009900;">&#40;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #000088;">$this</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">assertEqual</span><span style="color: #009900;">&#40;</span><span style="color: #000088;">$calculadora</span><span style="color: #339933;">-&gt;</span><span style="color: #004000;">soma</span><span style="color: #009900;">&#40;</span><span style="color: #cc66cc;">1</span><span style="color: #339933;">,</span><span style="color: #0000ff;">'A'</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #009900; font-weight: bold;">false</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Adicionamos essa função à nossa classe. Rodamos nosso teste novamente e &#8230;</p>
<p><img class="alignnone size-full wp-image-151" title="imagem3" src="http://leohackin.com.br/wp-content/uploads/2009/07/imagem3.png" alt="imagem3" width="860" height="284" /></p>
<p><strong>Previsivelmente</strong>, temos um erro pois nosso método soma ainda não verifica se os parâmetros recebidos são números válidos. Ai você irá pensar:</p>
<p><em><span style="text-decoration: underline;">Mas eu vou escrevendo os testes e vou implementando toda a minha lógica de negócio ao mesmo tempo ?</span></em></p>
<p>A TDD tem uma característica bacana, que anda de mãos dados ao <strong><a href="http://www.agence.com.br/refactoring-engenharia-de-software.php" target="_blank">refactoring</a></strong>: a TDD nos diz que devemos SIM escrever os testes primeiro e fazer as classes &#8220;passarem no teste&#8221; usando o mínimo de código possível: se a lógica for complexa, retorne uma resposta &#8220;hardcode&#8221; para &#8220;enganar&#8221; o teste e depois faça o refactory do código.</p>
<p>O refactory deve ser feito apenas depois de todos os testes serem feitos, pois nesse ponto você terá certeza de como o funcionamnento de sua classe atenderá a todos as respostas que são requisitadas nos testes como &#8220;corretos&#8221;.</p>
<p>Pensando nisso, vamos fazer nosso método soma &#8220;passar&#8221; no teste:</p>
<div class="codecolorer-container php default" style="overflow:auto;white-space:nowrap;border: 1px solid #9F9F9F;width:550px;"><table cellspacing="0" cellpadding="0"><tbody><tr><td style="padding:5px;text-align:center;color:#888888;background-color:#EEEEEE;border-right: 1px solid #9F9F9F;font: normal 12px/1.4em Monaco, Lucida Console, monospace;"><div>1<br />2<br />3<br />4<br />5<br />6<br />7<br />8<br />9<br /></div></td><td><div class="php codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #000000; font-weight: bold;">class</span> Calculadora <span style="color: #009900;">&#123;</span><br />
<span style="color: #000000; font-weight: bold;">function</span> soma<span style="color: #009900;">&#40;</span><span style="color: #000088;">$a</span><span style="color: #339933;">,</span><span style="color: #000088;">$b</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/is_int"><span style="color: #990000;">is_int</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$a</span><span style="color: #009900;">&#41;</span> <span style="color: #339933;">&amp;&amp;</span> <a href="http://www.php.net/is_int"><span style="color: #990000;">is_int</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$b</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#123;</span><br />
<span style="color: #b1b100;">return</span> <span style="color: #000088;">$a</span> <span style="color: #339933;">+</span> <span style="color: #000088;">$b</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span> <span style="color: #b1b100;">else</span> <span style="color: #009900;">&#123;</span><br />
<span style="color: #b1b100;">return</span> <span style="color: #009900; font-weight: bold;">false</span><span style="color: #339933;">;</span><br />
<span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span><br />
<span style="color: #009900;">&#125;</span></div></td></tr></tbody></table></div>
<p>Agora, vamos rodar nosso teste.</p>
<p><img class="alignnone size-full wp-image-152" style="border: 1px solid black;" title="imagem4" src="http://leohackin.com.br/wp-content/uploads/2009/07/imagem4.png" alt="imagem4" width="497" height="253" /></p>
<p><strong>Blz!</strong> Nosso teste passou, mas testamos apenas se os valores são inteiros e se forem, efetuamos a soma. Se não forem, a gente retorna false, como nosso teste pediu. Podemos depois refatorar isso: verificar se o valor é uma string com um número dentro e por ai vai.</p>
<h2>Finalizando</h2>
<p>Você pode estar se perguntando: <em>&#8220;Uai, mas podemos ter muito mais ocasiões que podem quebrar a soma! Podemos também extender algumas funcionalidades e exibir mensagens de erro&#8221;.</em></p>
<p>Tivemos uma amostra do que é o SimpleTest em seu cenário mais simples: apesar do tamanho do post, o conceito e a aplicação são bem simples como puderam ver.</p>
<p>Além do assetEqual, a SimpleTest tem um <a href="http://www.simpletest.org/en/unit_test_documentation.html" target="_blank">set de ações enorme de validações</a>, além de recursos mais avançados, como suites, mocks e web tests que veremos em breve.</p>
<p>Crie outras classes, pense nos testes, escreva seus casos de teste e vá executando: com a prática isso vai ficar tão automático que o ganho com a diminuição dos testes e bugs no final da aplicação vão ser notórios.</p>
<p><strong>Testes nos tornam programadores melhores. <span style="text-decoration: underline;">Pense nisso.</span></strong></p>
<p>Algumas coisas para se pensar quando começar a abordar isso:</p>
<ul>
<li> Não precisamos escrever TODOS os testes: é completamente normal se esquecermos algo ou houver alguma necessidade de mudança de negócio do cliente que nos fará escrever novos testes ou re-escrever os existentes. Tenha em mente que o TDD é para ajudar e não para ser mais uma fase carrancuda e intransponível no desenvolvimento;</li>
<li>A análise para chegar aos casos de teste faz bem ao início do projeto: com essa abordagem, você pode fazer perguntas ao cliente (e ele a você) sobre algumas coisas que possívelmente só apareceriam no final do projeto gerando assim muito re-trabalho;</li>
</ul>
<p>Bom, por enquanto é isso pessoal. No próximo post falaremos um pouco sobre agrupamentos de teste e partir para um exemplo mais complexo. <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
<p>Espero que tenham gostado do post.</p>
<p>Simbora! <img src='http://www.leohackin.com.br/wp-includes/images/smilies/icon_biggrin.gif' alt=':D' class='wp-smiley' /> </p>

]]></content:encoded>
			<wfw:commentRss>http://www.leohackin.com.br/2009/07/iniciando-com-o-simpletest/feed/</wfw:commentRss>
		<slash:comments>32</slash:comments>
		</item>
	</channel>
</rss>
