palestra tdd javou! #08 2016
TRANSCRIPT
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
[email protected] https://github.com/matheusfechine https://br.linkedin.com/in/matheusfechine
Obrigado e