terça-feira, 22 de janeiro de 2008

TestNG - Uma ótima alternativa

O TestNG é uma ferramenta largamente utilizada para fazer Testes de Unidade (pelo que andei ouvindo, até mais que isso), aqui na empresa, o Israel Freitas usa essa ferramenta e tenta a muito tempo evangelizar outros, porém pouco lhe dei ouvidos, "já que eu tenho o JUnit pra que procurar outra ferramenta que faz a mesma coisa de maneira diferente" ? Mas por insistência dele, resolvi fazer um teste e publicar algo sobre o assunto, confesso que minha opinião sobre o TestNG mudou de maneira drástica.


Esta ferramenta foi criada por Cédric Beust (a senior software engineer at Google) e Alexandru Popescu, esta já usa conceitos como Annotations bem antes do JUnit, além disso, percebi muitas funcionalidades e facilidades oferecidas por ele.

Um conceito interessante é o de dependência entre testes, vale a pena ser estudado.

O TestNG (a versão testada é a 5.6) permite a utilização dos asserts do JUnit, inserindo somente o import: import static org.testng.AssertJUnit.*;

Para ilustrar, criei um exemplo bem simples:


Foi criado a classe POJO somente com 2 atributos e seus getters e setters:

 0: public class POJO {
1:
2: private int id;
3: private String nome;
4:
5: public int getId() {
6: return id;
7: }
8: public void setId(int id) {
9: this.id = id;
10: }
11: public String getNome() {
12: return nome;
13: }
14: public void setNome(String nome) {
15: this.nome = nome;
16: }
17: }

Um teste bem simples foi feito pra a classe:

 0: import org.testng.annotations.*;
1: import static org.testng.AssertJUnit.*;
2:
3: public class POJOTest{
4:
5: @BeforeClass
6: public void setUp() {
7: }
8:
9: @Test
10: public void gettersAndSettersTest()
11: {
12: POJO pojo = getEntidade();
13: assertEquals(pojo.getId(), 1);
14: }
15:
16: private POJO getEntidade() {
17: POJO pojo = new POJO();
18: pojo.setId(1);
19: pojo.setNome("nome");
20: return pojo;
21: }
22: }

* Perceba que uso os asserts do JUnit.

Criei o arquivo de configuração do TestNG:
*tire os '$' de todas as linhas

<$!DOCTYPE suite SYSTEM "http://beust.com/testng/testng-1.0.dtd" >
<$suite name="My First TestNG test">
<$test name="Hello Test!">
<$classes>
<$class name="POJOTest" />
<$/classes>
<$/test>
<$/suite>


Utilizando o plugin para o Eclipse rodei este teste com extrema facilidade e o log do resultado foi gerado:

[Parser] Running:
C:\Arquivos de programas\Apache Software Foundation\Tomcat 5.5\webapps\TestNGExamples\temp-testng-customsuite.xml

PASSED: gettersAndSettersTest

===============================================
POJOTest
Tests run: 1, Failures: 0, Skips: 0
===============================================


===============================================
TestNGExamples
Total tests run: 1, Failures: 0, Skips: 0
===============================================

O nível de detalhes do log do resultado é determinado na propriedade "Log Level" da configuração da execução do TestNG.


Os links abaixo vão ajudar muito na utilização do TestNG.

Site oficial
Plugin pro Eclipse
Annotations pra todos os gostos
TestNG com Ant
Automatizando a Migração do JUnit para o TestNG
Comparação entre TestNG e JUnit4
Bom artigo sobre o assunto


Avaliação geral:

Como um usuário do JUnit, considero o TestNG um adversário de peso, bem mais rico quando se fala de annotations. Acredito que esta ferramenta deve ter seu uso considerado, além de ser muito robusta e cheia de novidades, tem muita documentação disponível na WEB.
A única carência que percebi, foi a ausência de asserts, porém com introdução dos asserts do JUnit a carência foi resolvida.