<?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>Programando na madrugada &#187; TDD</title>
	<atom:link href="http://www.luizpicanco.com/category/padrao/tdd/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.luizpicanco.com</link>
	<description>Programação na melhor hora do dia</description>
	<lastBuildDate>Sun, 31 Jul 2011 03:44:51 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Catálogo de Anti-Padrões em TDD</title>
		<link>http://www.luizpicanco.com/2007/09/20/catalogo-de-anti-padroes-em-tdd/</link>
		<comments>http://www.luizpicanco.com/2007/09/20/catalogo-de-anti-padroes-em-tdd/#comments</comments>
		<pubDate>Thu, 20 Sep 2007 04:45:04 +0000</pubDate>
		<dc:creator>Luiz Picanço</dc:creator>
				<category><![CDATA[TDD]]></category>

		<guid isPermaLink="false">http://www.luizantonio.com/2007/09/20/catalogo-de-anti-padroes-em-tdd/</guid>
		<description><![CDATA[Catálogo interessante prouzido pelo James Carr e traduzido pelo Victor The Liar Todos os metodos de um teste unitário estão passando perfeitamente, aparentando serem validos, entretanto sob uma inspeção mais próxima é descoberto que o teste unitário não testa o real intuíto para que foi criado. Excessive Setup Um teste que necessita muito trabalho para [...]]]></description>
			<content:encoded><![CDATA[<p class="MsoNormal" style="margin-bottom: 12pt; line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Catálogo interessante prouzido pelo <a href="http://blog.james-carr.org/">James Carr</a> e traduzido pelo <a href="http://malditacomedia.blogspot.com/2007/08/tdd-anti-patterns.html">Victor</a><o:p></o:p></span></p>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Liar <o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Todos os metodos de um       teste unitário estão passando perfeitamente, aparentando serem validos,       entretanto sob uma inspeção mais próxima é descoberto que o teste       unitário não testa o real intuíto para que foi criado.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Excessive Setup <o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste que necessita       muito trabalho para ser configurado antes mesmo de ser executado. Algumas       vezes centenas de linhas de código tornam-se necessárias para adaptar o       ambiente a um único método de testes, com dezenas de objetos envolvidos.       Aqui a maior dificuldade é compreender &#8220;o quê&#8221; realmente está       sendo testado dentro de toda a &#8220;sujeira&#8221; que um setup pode       causar. (tradutor: <em>Lembrem-se sempre do princípio <a href="http://en.wikipedia.org/wiki/KISS_principle"><span style="color: blue">KISS</span></a></em>)<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Giant <o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário que,       mesmo sendo verdadeiro na intenção de validar um objeto, pode possuir       centenas de linhas contendo inúmeros casos de teste (inúmeros mesmos).       Esta pode ser uma indicação do que chamamos de <a href="http://en.wikipedia.org/wiki/God_object"><span style="color: blue">God       Object</span></a>, objeto que possui responsabilidades demais dentro do       sistema. Indício claro de alto acoplamento em seu sistema.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Mockery <o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Muitas vezes um mock pode       ser útil e bastante indicado. Mas desenvolvedores podem perder tempo       desnecessariamente esforçando-se em mockear o que não está sendo testado.       Percebe-se neste caso que a classe possuí tantos mocks, stubs ou fakes       que no final das coisas o sistema não está sendo testado, mas o que é       retornado da interação entre os mocks. (tradudor: <em>use apenas o que for       estritamente necessário!</em>)<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Inspector <o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitáro que viola       o encapsulamente em um esforço de atingir 100% de cobertura de testes,       mas está situação nem sempre é favoravél, pois qualquer tentativa de       refactor pode quebrar testes desnecessariamente, necessitanto adequações       nas classes de teste unitário.<o:p></o:p></span></li>
</ul>
</li>
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Generous Leftovers<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Uma instância de um teste       unitário cria um dado que é persistido em algum lugar, e outro teste       utiliza tal dado para seus próprios asserts. Caso algo saia errado, o       teste que utiliza o dado cadastrado também falhará. (tradutor: <em>Testes       devem ser independentes!</em> )<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The local Hero<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste que é dependente       de algo específico do ambiente de desenvolvimento em que ele foi escrito.       O resultado: o teste passa perfeitamente na células de desenvolvimento,       mas falha quando alguém tenta executá-lo fora desse ambiente.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Nitpicker<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitáro que       compara toda a saída quando o que lhe deveria interessar é uma pequena       parte apenas, assim o teste deve se manter sempre alinhado com detalhes       que o teste não deveria tratar. Esta situação é endemica em testes de       aplicações web.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Dodger</span></strong><span style="font-size: 10pt; font-family: "Arial","sans-serif""> <o:p></o:p></span>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário que       possui muitos testes para efeitos pequenos (e presumidamente simples de       testar), mas nunca testando o comportamente real desejado. Encontrado em       testes relacionados para testes de banco de dados, onde um método é       chamado, e então o teste seleciona itens do banco e procede asserts       contra os resultados.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Loudmout </span></strong><span style="font-size: 10pt; font-family: "Arial","sans-serif""><o:p></o:p></span>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário (ou suite       de testes) que enxe o console com mensagens de diagnóstico, logs e       qualquer outro tipo de saídas, mesmo quando os testes estão passando.       Algumas vezes durante a criação dos testes existe o desejo de manualmente       ver a saída dos metodos, mas mesmo eles deixando de serem necessários, são       deixados para trás.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Greedy Catcher <o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário que trata       exceções e sobrepões pilhas de execução (stack trace) algumas vezes com       mensagens menos informativas, mas algumas vezes ainda apenas logando       (Loudmouth) e deixando o teste passar.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Sequencer </span></strong><span style="font-size: 10pt; font-family: "Arial","sans-serif""><o:p></o:p></span>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário       dependente de uma lista que sempre é retornada em forma desordenada.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Hidden Dependecy</span></strong><span style="font-size: 10pt; font-family: "Arial","sans-serif""><o:p></o:p></span>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Primo de primeiro grau do       &#8220;The Local Hero&#8221;, um teste unitário dependente de um dado que       deve ser populado em algum lugar par ao teste rodar. Se o dado não estive       presente, o teste falhará deixando pouca informação para o desenvolvedor       o que é necessário, ou porque o teste falhou&#8230; forçando-o a buscar       através de uma floresta de código para descobrir de onde vem o dado que o       teste deveria utilizar.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Enumerator</span></strong><span style="font-size: 10pt; font-family: "Arial","sans-serif""><o:p></o:p></span>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário em que os       nomes de métodos são apenas uma enumeração: teste1, teste2, teste3. Como       resultado, a intenção dos testes torna-se pouco clara, e a única maneira       de ter certeza é ler o código fonte e rezar para que esteja bem escrito.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Stranger<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um método de teste que nem       ao menos pertence ao Teste Unitário que ele está inserido. O método está       realmente testando um objeto separado e independente, normalmente um       objeto utilizado pelo objeto que sofre o teste.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Operating System      Evangelist<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário que está       ajustado apenas para um determinado sistema operacional para que possa       funcionar. Um bom exemplo seria um caso de teste que utilize o separador       de linhas do Windows para um assert, que falha apenas rodando em Linux.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Success Against All Odds<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste escrito para       passar antes mesmo de falhar. Como um infeliz efeito colateral, o caso de       teste acaba sempre passando mesmo que tenha sido feito para falhar.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Free Ride<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Ao invés de escrever um       novo teste para uma nova funcionalidade ou característica, apenas um novo       assert é criado ao final de um teste já existente.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The One<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Uma combinação de alguns       outros padrões, particularmente o TheFreeRide e TheGiant. Um teste       unitário que contém apenas um único metodo que teste todo tipo de       funcionalidade que um objeto pode conter. Um indicador comum é que o       teste possui o mesmo nome da classe, e ainda com múltiplas linhas, setups       e asserts<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Peeping Tom<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste que,       compartilhando recursos, pode ver o resultado de outro test, e pode       falhar mesmo que o sistema testado esteja em perfeito funcionamento.       Verificado na ferramenta Fitnesse, onde a utilização de variáveis       estáticas para abrigar coleções não eram corretamente limpas após a       execução do teste, podendo surgir erros durante a execução de qualquer       teste. Também conhecido com TheUninvitedGuests.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<ul type="disc">
<li class="MsoNormal" style="line-height: normal"><strong><span style="font-size: 10pt; font-family: "Arial","sans-serif"">The Slow Poke<o:p></o:p></span></strong>
<ul type="circle">
<li class="MsoNormal" style="line-height: normal"><span style="font-size: 10pt; font-family: "Arial","sans-serif"">Um teste unitário que é       incrivelmente lento para ser executado. Quando o teste é iniciado, os       programadores podem ir ao banheiro, fumar um cigarro ou pior ainda,       inicar o teste no final do dia e ir para casa, esperando que o resultado       saia no dia seguinte.<o:p></o:p></span></li>
</ul>
</li>
</ul>
<p class="MsoNormal"><span style="font-size: 10pt; line-height: 115%; font-family: "Arial","sans-serif""><o:p> </o:p></span></p>
]]></content:encoded>
			<wfw:commentRss>http://www.luizpicanco.com/2007/09/20/catalogo-de-anti-padroes-em-tdd/feed/</wfw:commentRss>
		<slash:comments>1108</slash:comments>
		</item>
	</channel>
</rss>

