Palestra TDD Javou! #08 2016

Preview:

Citation preview

TDDAutomatizando Testes com Java

Javou! #08 - 2016

Bruno MaomehUm grande aficionado pelo conhecimento, admirador do desenvolvimento de software e metodologias ágeis. Trabalhando por mais de 9 anos com desenvolvimento, eu também sou entusiasta por comunidades de desenvolvimento de sistemas, atuando como coordenador do Grupo de Usuários Java do Rio Grande do Sul (RSJug) e do JavaSF International Group (JavaSF).

Matheus FechineGraduado em Ciências da Computação com pós graduação em Desenvolvimento de Software com ênfase em arquitetura java, ambas pela Universidade de Fortaleza (UNIFOR), atua no mercado como desenvolvedor desde 2008 e Coordenador da comunidade JavaCE. Sente-se torturado ao ver um código sem cobertura de teste. Pai do Levi, torcedor do Ceará, faixa azul de jiu jitsu, apreciador de Punk Rock e baixista nas horas vagas.

O que é um teste?

O que é um teste?

Um teste é tudo aquilo que assegura que alguma coisa

está funcionando.

O que é um teste?

"Afirma-se que o teste de software é um processo, ou uma série de processos, projetado para se certificar a respeito do código de computador, de fazer o que foi designado a cumprir, e sem realizar nada que não seja intencional.” (Glenford J. Myers - 2004)

Testes Manuais● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais

● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais

● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais

● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais

● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais

● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou.

Testes Manuais

Testes Manuais● Faz alteração no código;● Levanta o Tomcat;● Abre o Chrome;● Faz login na aplicação;● Entra na página do formulário;● Preenche um formulário;● Envia o formulário;● Verifica se a correção funcionou;● Faz alteração no código.

Testes Manuais

Fazer testes manuais É LENTO!!

Uma hora você vai esquecer ou errar algum passo!!

Testes automatizados

Testes automatizados

Tipos de testes

Teste de unidade

Teste de integração

Teste de aceitação

Teste de segurança

Teste de performance

Teste de configuraçãoTeste de regressão

Tipos de testes

Teste de unidade

Teste de integração

Teste de aceitação

Teste de segurança

Teste de performance

Teste de configuraçãoTeste de regressão

Teste de Unidade

Teste de unidade● Ajuda na rastreabilidade de

bugs no sistema;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como documentação do

código;● Auxilia na criação do design do

sistema.

Teste de unidade● Ajuda na rastreabilidade de bugs

no sistema;● Previnem regressão do

código;● Incentivam a refatoração do

código;● Servem como documentação do

código;● Auxilia na criação do design do

sistema.

Teste de unidade● Ajuda na rastreabilidade de bugs

no sistema;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como documentação do

código;● Auxilia na criação do design do

sistema.

Teste de unidade● Ajuda na rastreabilidade de bugs

no sistema;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como

documentação do código;● Auxilia na criação do design do

sistema.

Teste de unidade● Ajuda na rastreabilidade de bugs

no sistema;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como documentação do

código;● Auxilia na criação do

design do sistema.

NÃO é Teste de Unidade

● Se ele conversa com o banco de dados;● Se ele se comunica através da rede;● Se ele toca o sistema de arquivos;● Se ele não pode ser executado ao mesmo tempo

de outros testes de unidade;● Se for necessário configurar ou preparar o

ambiente para executá-los.

Teste de Integração

Teste de integração● Garante a comunicação

com outros módulos ou sistema;

● Previnem regressão do código;

● Incentivam a refatoração do código;

● Servem como documentação de código e de api.

Teste de integração● Garante a comunicação

com outros módulos ou sistema;

● Previnem regressão do código;

● Incentivam a refatoração do código;

● Servem como documentação de código e de api.

Teste de integração● Garante a comunicação

com outros módulos ou sistema;

● Previnem regressão do código;

● Incentivam a refatoração do código;

● Servem como documentação de código e de api;

Teste de integração● Garante a comunicação

com outros módulos ou sistema;

● Previnem regressão do código;

● Incentivam a refatoração do código;

● Servem como documentação de código e de api.

Teste de Aceitação

Teste de aceitação● Garante a funcionalidade do

sistema como um todo;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como documentação de

código e de api;● Simula o teste com o usuário

final.

Teste de aceitação● Garante a funcionalidade do

sistema como um todo;● Previnem regressão do

código;● Incentivam a refatoração do

código;● Servem como documentação de

código e de api;● Simula o teste com o usuário

final.

Teste de aceitação● Garante a funcionalidade do

sistema como um todo;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como documentação de

código e de api;● Simula o teste com o usuário

final.

Teste de aceitação● Garante a funcionalidade do

sistema como um todo;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como

documentação de código e de api;

● Simula o teste com o usuário final.

Teste de aceitação● Garante a funcionalidade do

sistema como um todo;● Previnem regressão do código;● Incentivam a refatoração do

código;● Servem como documentação de

código e de api;● Simula o teste com o

usuário final.

Testes automatizados

Qual tipo de teste usar?

Em regras gerais

(isso não é uma estatística, apenas referência)

O que é TDD?

O que é TDD?

TDD é uma prática de desenvolvimento de software onde todo o código do sistema é escrito depois de escrever testes automatizados.

"We never have enough time for testing, so let's just write the test first." (Kent Beck)

O que é TDD?Ciclo do TDD: Vermelho-Verde-Amarelo

O que é TDD?

Ciclo do TDD: Vermelho-Verde-Amarelo

O que é TDD?

Ciclo do TDD: Vermelho-Verde-Amarelo

O que é TDD?

Ciclo do TDD: Vermelho-Verde-Amarelo

O que é TDD?Muito além de técnicas de "test-first"

● Auxilia na detecção de falhas no design do sistema.● Também deve ter informações sobre o código testado.

Se um teste está ficando muito complicado, é um grande indício que exista problema com o design.

É hora de refatorar!!

RED@Testpublic void naoDeveRetornarCategoriasPorNome(){

Response response = controller.obtemCategoriasPelo("TESTE");

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

RED@GET@Produces("application/json")public Response obtemCategoriasPelo(@QueryParam("nome")String nomeCategoria) {

return null;

}

RED@Testpublic void naoDeveRetornarCategoriasPorNome(){

Response response = controller.obtemCategoriasPelo("TESTE");

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

VAMOS CORRIGIR!

GREEN@GET@Produces("application/json")public Response obtemCategoriasPelo(@QueryParam("nome")String nomeCategoria) {

return Response.noContent().build();

}

GREEN@Testpublic void naoDeveRetornarCategoriasPorNome(){

Response response = controller.obtemCategoriasPelo("TESTE");

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

GREEN@Testpublic void naoDeveRetornarCategoriasPorNome(){

Response response = controller.obtemCategoriasPelo("TESTE");

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

EXISTE VERDE MAIS LINDO QUE ESSE???

YELLOW@Testpublic void naoDeveRetornarCategoriasPorNome(){

when(service.obtemCategoriasPelo(anyString())).thenReturn(null);

Response response = controller.obtemCategoriasPelo("TESTE");

verify(service).obtemCategoriasPelo(anyString());

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

YELLOW@GET@Produces("application/json")public Response obtemCategoriasPelo(@QueryParam("nome")String nomeCategoria) {

List<Categoria> listaCategorias = service .obtemCategoriasPelo(nomeCategoria);

return Response.ok(listaCategorias).build();}

RED@Testpublic void naoDeveRetornarCategoriasPorNome(){

when(service.obtemCategoriasPelo(anyString())).thenReturn(null);

Response response = controller.obtemCategoriasPelo("TESTE");

verify(service).obtemCategoriasPelo(anyString());

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

GREEN@GET@Produces("application/json")public Response obtemCategoriasPelo(@QueryParam("nome")String nomeCategoria) {

List<Categoria> listaCategorias = service .obtemCategoriasPelo(nomeCategoria);

if(listaCategorias!=null){return Response.ok(listaCategorias).build();

}return Response.noContent().build();

}

GREEN@Testpublic void naoDeveRetornarCategoriasPorNome(){

when(service.obtemCategoriasPelo(anyString())).thenReturn(null);

Response response = controller.obtemCategoriasPelo("TESTE");

verify(service).obtemCategoriasPelo(anyString());

assertEquals(Status.NO_CONTENT.getStatusCode(), response.getStatus());

}

@matheusmoura

matheusfmoura@gmail.com https://github.com/matheusfechine https://br.linkedin.com/in/matheusfechine

Obrigado e