SlideShare une entreprise Scribd logo
1  sur  26
Télécharger pour lire hors ligne
Fabrício Ferrari de Campos
Baseadas em Estrutura
Teste e Cobertura de Comandos
Teste e Cobertura de Decisão
Outras técnicas baseadas na estrutura
O que e cobertura de
           teste
Cobertura de teste é uma medida, referente
ao número de itens (código) testados, pelo
total de itens, multiplicado por 100%.
               número de itens
                                   x 100%
                 exercitados
Cobertura =
                 total de itens
Teste e Cobertura de
        Comandos
Definir casos de teste que executem todos
os comandos pelo menos uma vez (passa por
todos os nodos do grafo)
Métrica: número de nodos cobertos
Fácil de satisfazer
Não garante qualidade do código
Teste e Cobertura de
        Comandos
Cobertura de comando é medida, de acordo
com o número de comandos exercitados
divididos pelo total de comandos,
multiplicado por 100%.
               número de comandos
                                  x 100%
                     exercitados
 Cobertura
            =
de comando
                total de comandos
Teste e Cobertura de
         Comandos                           2   1


1.a = Integer.parseInt(args[0]);
                                            3
2.b = Integer.parseInt(args[1]);
3.while(a < 0){                             4
4. if (b < 0){
5.      b = b + 2; Um teste é o                 5
6. }
                     suficiente             7
7. a = a + 1;
                     a  b     C         9
8.}                       (resultado)

                    -1 -1     1
9.c = a + b;
Teste e Cobertura de
         Comandos
Questão simulado (CTFL-BSTQB)
Se você estiver voando com um bilhete da classe
econômica, há uma possibilidade de você conseguir
mudar para a classe executiva. Principalmente se
você tiver um cartão fidelidade da companhia aérea.
Se você não tiver o cartão fidelidade (CF), há a
possibilidade de você ser quot;despejadoquot; do vôo se ele
estiver lotado e você chegar atrasado.
Teste e Cobertura de
      Comandos
             n                             s                       s
  cartão                     econômica               executiva
fidelidade                     lotada                 lotada

 s                            n                  n
             s
executiva                    econômica
 lotada

 n               econômica

                                                                 despejado
                                         mudar
 mudar
                                                                  do vôo


embarcar
Teste e Cobertura de
          Comandos
Questão simulado (CTFL-BSTQB)
Três testes foram executados:
Teste 1: O passageiro tem o CF e mudou para a classe executiva
Teste 2: O passageiro não tem o CF e permaneceu na classe
econômica
Teste 3: O passageiro foi quot;despejadoquot; do vôo
Qual é a cobertura de comando obtida com esses três testes?

a) 60%
b) 70%
c) 80%
d) 90%
Teste e Cobertura de
         Comandos
Resposta correta
Alternativa: c) 80%

Os três testes apresentados cobrem 8 comandos
de 10, ou seja, 80% dos comandos. Os testes não
cobrem o comando 3 e o 9.
Teste e Cobertura de
               ~
          Decisao
Uma decisão é um IF, um loop (ex. do-while
ou repeat-until), ou um CASE, no qual
existem duas ou mais possibilidades de
saídas ou resultados a partir de um comando
               número de decisões
                                     x 100%
                    exercitados
 Cobertura
            =
de decisão      total de decisões
Teste e Cobertura de
               ~
          Decisao
Teste de decisão é uma forma de teste de
controle de fluxo, já que ele gera um fluxo
específico através dos pontos de decisões
A cobertura de decisão é mais eficiente que
a cobertura de comandos: 100% da cobertura
de decisão garante 100% da cobertura de
comandos, mas não vice-versa
Teste e Cobertura de
               ~
          Decisao
Os testes devem cobrir cada saída possível
de um nodo que tenha uma condição
Métrica: número de arestas cobertas
Teste de decisão derivam-se dos casos de
testes para executar decisões específicas,
normalmente para se aumentar a cobertura
Teste e Cobertura de
                 ~
            Decisao                           2   1


1.a = Integer.parseInt(args[0]);
                                              3
2.b = Integer.parseInt(args[1]);
3.while(a < 0){ três testes são               4
4. if (b < 0){
                    necessários
5.      b = b + 2;    ab        C                 5
                            (resultado)
6. }
                     -1 -1      1             7
7. a = a + 1;
                     00         0         9
8.}
                     -1 0       0
9.c = a + b;
Teste e Cobertura de
                  ~
             Decisao
Questão simulado (CTFL-BSTQB)
Tendo como base o pseudocódigo abaixo, quantos testes são
necessários para atingir 100% da cobertura de desvio/decisão?
                                         a)   1
1. If x = 3 then
                                         b)   2
2.       Display_messageX;
                                         c)   3
3.       If y = 2 then
                                         d)   4
4.               Display_messageY;
5.       else
6.               Display_messageZ;
7. else
8.       Display_messageZ;
Teste e Cobertura de
                   ~
              Decisao
Resposta correta
Alternativa: c) 3
Criando três testes conseguimos cobrir 100% das decisões
do pseudocódigo, por exemplo:
   x      y

   3      2

   0      0

   3      0
Outras tecnicas baseadas
     na estrutura
Cobertura de desvio
LCSAJ (Linear Code Sequence and Jump -
Seqüência de Código Linear e Salto)
Cobertura de Caminho
Cobertura de desvio
Está estreitamente relacionada com a
cobertura de decisão, tanto que 100% de
cobertura de desvio, equivale a 100% de
cobertura de decisão
Cobertura de decisão medi a cobertura dos
desvios condicionais, já a cobertura de desvio
medi a cobertura de desvios condicionais e
não condicionais
LCSAJ
Inclui a cobertura de código linear e salto,
cobertura de decisão, cobertura de condições
e cobertura de múltiplas condições
Essa técnica requer a cobertura de todas as
condições que podem afetar ou determinar o
resultado de uma condição
Cobertura de Caminho
Especifica dos caminhos possíveis de um
software, quantos são cobertos na execução
de um teste
Porcentagem de caminhos exercitada por
uma suite de teste. 100% de cobertura de
caminho implicam em 100% de cobertura
LCSAJ
^
  Baseadas na experiencia
Suposição de erro
Teste exploratório
~
       Suposicao de erro
Deve ser usada sempre como um
complemento à outras técnicas mais formais
Não há regras para a suposição de erro
Quando usado para aumentar a técnica
sistemática, testes intuitivos podem ser úteis
para identificar testes específicos que não são
facilmente identificados pelas técnicas formais
Depende muito da habilidade e experiência
do testador
Teste exploratorio
Ocorre simultaneamente à modelagem,
execução e registro de teste, e baseia-se nos
objetivos de teste, onde é realizado em um
tempo predefinido
É uma abordagem muito usual, em locais
onde a especificação é rara ou inadequada e
existe grande pressão por conta de prazo, ou
para aprimorar/complementar um teste mais
formal
Teste exploratorio
Pode servir como uma checagem do
processo de teste, assegurando que os
defeitos mais importantes sejam encontrados
O aspecto principal é a aprendizagem:
sobre o software, seu uso, seu pontos fortes
e fracos
Também pode servir de complemento para
outras técnicas formais
 BSTQB. Base de Conhecimento para Certificação em Teste -
Foundation Level Syllabus. 2007br.
 BSTQB. Glossário Padrão de Termos Utilizados em Teste de
Software. Versão 1.3br
 D. Grahan; V. Veenendaal; I. Evans; R. Black. Foundations of
Software Testing: ISTQB Certification. Cengage Learning Business
Press, 2006.
www.inf.pucrs.br/~copstein/CursoTeste/Dia3/Dia3_TesteFunciona
lTesteEstrutural.ppt (Professor Dr. Bernardo Copstein)

Contenu connexe

Tendances

Tecnicas Para Planejamento E Execucao De Testes De Software
Tecnicas Para Planejamento E Execucao De Testes De SoftwareTecnicas Para Planejamento E Execucao De Testes De Software
Tecnicas Para Planejamento E Execucao De Testes De Softwaremarthahuback
 
Karate - Web-Service API Testing Made Simple
Karate - Web-Service API Testing Made SimpleKarate - Web-Service API Testing Made Simple
Karate - Web-Service API Testing Made SimpleVodqaBLR
 
Criando uma arquitetura para seus testes de API com RestAssured
Criando uma arquitetura para seus testes de API com RestAssuredCriando uma arquitetura para seus testes de API com RestAssured
Criando uma arquitetura para seus testes de API com RestAssuredElias Nogueira
 
Arquitetura de Automação de Teste
Arquitetura de Automação de TesteArquitetura de Automação de Teste
Arquitetura de Automação de TesteElias Nogueira
 
Test case techniques
Test case techniquesTest case techniques
Test case techniquesPina Parmar
 
Noções em teste de software e introdução a automação
Noções em teste de software e introdução a automaçãoNoções em teste de software e introdução a automação
Noções em teste de software e introdução a automaçãoSandy Maciel
 
Karate - powerful and simple framework for REST API automation testing
Karate - powerful and simple framework for REST API automation testingKarate - powerful and simple framework for REST API automation testing
Karate - powerful and simple framework for REST API automation testingRoman Liubun
 
Test automation principles, terminologies and implementations
Test automation principles, terminologies and implementationsTest automation principles, terminologies and implementations
Test automation principles, terminologies and implementationsSteven Li
 
Scrum Testing Methodology
Scrum Testing MethodologyScrum Testing Methodology
Scrum Testing MethodologyGaya1985
 
Fundamentals of Software Testing
Fundamentals of Software TestingFundamentals of Software Testing
Fundamentals of Software TestingSagar Joshi
 
Estrategias de Pruebas de Software
Estrategias de Pruebas de SoftwareEstrategias de Pruebas de Software
Estrategias de Pruebas de SoftwareLucia Gasperin
 
Arquitetura básica de testes para seu projeto Java
Arquitetura básica de testes para seu projeto JavaArquitetura básica de testes para seu projeto Java
Arquitetura básica de testes para seu projeto JavaElias Nogueira
 
[MoT SP #1] PRISMA para Testes Baseados em Risco
[MoT SP #1] PRISMA para Testes Baseados em Risco[MoT SP #1] PRISMA para Testes Baseados em Risco
[MoT SP #1] PRISMA para Testes Baseados em RiscoJúlio de Lima
 
Test Automation Framework Designs
Test Automation Framework DesignsTest Automation Framework Designs
Test Automation Framework DesignsSauce Labs
 
Papel do QA na Transformação Ágil
Papel do QA na Transformação ÁgilPapel do QA na Transformação Ágil
Papel do QA na Transformação ÁgilElias Nogueira
 
Testes de Software - Fundamentos
Testes de Software - FundamentosTestes de Software - Fundamentos
Testes de Software - FundamentosLucas Amaral
 

Tendances (20)

Tecnicas Para Planejamento E Execucao De Testes De Software
Tecnicas Para Planejamento E Execucao De Testes De SoftwareTecnicas Para Planejamento E Execucao De Testes De Software
Tecnicas Para Planejamento E Execucao De Testes De Software
 
Karate - Web-Service API Testing Made Simple
Karate - Web-Service API Testing Made SimpleKarate - Web-Service API Testing Made Simple
Karate - Web-Service API Testing Made Simple
 
Criando uma arquitetura para seus testes de API com RestAssured
Criando uma arquitetura para seus testes de API com RestAssuredCriando uma arquitetura para seus testes de API com RestAssured
Criando uma arquitetura para seus testes de API com RestAssured
 
Arquitetura de Automação de Teste
Arquitetura de Automação de TesteArquitetura de Automação de Teste
Arquitetura de Automação de Teste
 
Plano de teste
Plano de testePlano de teste
Plano de teste
 
Introduction to Software Test Automation
Introduction to Software Test AutomationIntroduction to Software Test Automation
Introduction to Software Test Automation
 
Test case techniques
Test case techniquesTest case techniques
Test case techniques
 
Noções em teste de software e introdução a automação
Noções em teste de software e introdução a automaçãoNoções em teste de software e introdução a automação
Noções em teste de software e introdução a automação
 
Karate - powerful and simple framework for REST API automation testing
Karate - powerful and simple framework for REST API automation testingKarate - powerful and simple framework for REST API automation testing
Karate - powerful and simple framework for REST API automation testing
 
Test automation principles, terminologies and implementations
Test automation principles, terminologies and implementationsTest automation principles, terminologies and implementations
Test automation principles, terminologies and implementations
 
Scrum Testing Methodology
Scrum Testing MethodologyScrum Testing Methodology
Scrum Testing Methodology
 
Fundamentals of Software Testing
Fundamentals of Software TestingFundamentals of Software Testing
Fundamentals of Software Testing
 
Estrategias de Pruebas de Software
Estrategias de Pruebas de SoftwareEstrategias de Pruebas de Software
Estrategias de Pruebas de Software
 
Arquitetura básica de testes para seu projeto Java
Arquitetura básica de testes para seu projeto JavaArquitetura básica de testes para seu projeto Java
Arquitetura básica de testes para seu projeto Java
 
[MoT SP #1] PRISMA para Testes Baseados em Risco
[MoT SP #1] PRISMA para Testes Baseados em Risco[MoT SP #1] PRISMA para Testes Baseados em Risco
[MoT SP #1] PRISMA para Testes Baseados em Risco
 
Teste de software
Teste de softwareTeste de software
Teste de software
 
Test Automation Framework Designs
Test Automation Framework DesignsTest Automation Framework Designs
Test Automation Framework Designs
 
Papel do QA na Transformação Ágil
Papel do QA na Transformação ÁgilPapel do QA na Transformação Ágil
Papel do QA na Transformação Ágil
 
Teste de software
Teste de softwareTeste de software
Teste de software
 
Testes de Software - Fundamentos
Testes de Software - FundamentosTestes de Software - Fundamentos
Testes de Software - Fundamentos
 

Similaire à Técnicas de modelagem de teste (parte 2)

Atividades de Teste e Cobertura de Código em Java
Atividades de Teste e Cobertura de Código em JavaAtividades de Teste e Cobertura de Código em Java
Atividades de Teste e Cobertura de Código em Javaaceiro
 
GOTEST-Aula4-Automacao-Parte1.pdf
GOTEST-Aula4-Automacao-Parte1.pdfGOTEST-Aula4-Automacao-Parte1.pdf
GOTEST-Aula4-Automacao-Parte1.pdfRodolphoCesar2
 
Generalização, validação e comparação de resultados
Generalização, validação e comparação de resultadosGeneralização, validação e comparação de resultados
Generalização, validação e comparação de resultadosLuís Nunes
 
MALHA ABERTA E MALHA FECHADA
MALHA ABERTA E MALHA FECHADAMALHA ABERTA E MALHA FECHADA
MALHA ABERTA E MALHA FECHADARafael Costa
 
1 2 malha aberta e fechada
1 2   malha aberta e fechada1 2   malha aberta e fechada
1 2 malha aberta e fechadaRafael Costa
 
TDC Connections 2021 Clausula de Guarda
TDC Connections 2021 Clausula de GuardaTDC Connections 2021 Clausula de Guarda
TDC Connections 2021 Clausula de GuardaDouglas Siviotti
 
8a. aula -_estrutura_de_controle_de_repeticao_-_while_java
8a. aula -_estrutura_de_controle_de_repeticao_-_while_java8a. aula -_estrutura_de_controle_de_repeticao_-_while_java
8a. aula -_estrutura_de_controle_de_repeticao_-_while_javaMirlem Pereira
 
Testes de Software - Módulo 2
Testes de Software - Módulo 2Testes de Software - Módulo 2
Testes de Software - Módulo 2Rodrigo Paes
 
TDC2013 Otimizando-C
TDC2013 Otimizando-CTDC2013 Otimizando-C
TDC2013 Otimizando-Cosmarcf
 
Estratégias e Técnicas de Testes - Parte 2
Estratégias e Técnicas de Testes - Parte 2Estratégias e Técnicas de Testes - Parte 2
Estratégias e Técnicas de Testes - Parte 2Lorena Caldas
 
2 controle fluxo
2 controle fluxo2 controle fluxo
2 controle fluxoprofwtelles
 
Modelagem Analítica – Queueing Theory (Part I)
Modelagem Analítica – Queueing Theory (Part I)Modelagem Analítica – Queueing Theory (Part I)
Modelagem Analítica – Queueing Theory (Part I)Joao Galdino Mello de Souza
 

Similaire à Técnicas de modelagem de teste (parte 2) (20)

Atividades de Teste e Cobertura de Código em Java
Atividades de Teste e Cobertura de Código em JavaAtividades de Teste e Cobertura de Código em Java
Atividades de Teste e Cobertura de Código em Java
 
GOTEST-Aula4-Automacao-Parte1.pdf
GOTEST-Aula4-Automacao-Parte1.pdfGOTEST-Aula4-Automacao-Parte1.pdf
GOTEST-Aula4-Automacao-Parte1.pdf
 
Generalização, validação e comparação de resultados
Generalização, validação e comparação de resultadosGeneralização, validação e comparação de resultados
Generalização, validação e comparação de resultados
 
Apresentacao-Llanos-8.pdf
Apresentacao-Llanos-8.pdfApresentacao-Llanos-8.pdf
Apresentacao-Llanos-8.pdf
 
var_copulas
var_copulasvar_copulas
var_copulas
 
Complexidade Ciclomática
Complexidade CiclomáticaComplexidade Ciclomática
Complexidade Ciclomática
 
MALHA ABERTA E MALHA FECHADA
MALHA ABERTA E MALHA FECHADAMALHA ABERTA E MALHA FECHADA
MALHA ABERTA E MALHA FECHADA
 
1 2 malha aberta e fechada
1 2   malha aberta e fechada1 2   malha aberta e fechada
1 2 malha aberta e fechada
 
Unit Testing
Unit TestingUnit Testing
Unit Testing
 
TDC Connections 2021 Clausula de Guarda
TDC Connections 2021 Clausula de GuardaTDC Connections 2021 Clausula de Guarda
TDC Connections 2021 Clausula de Guarda
 
Exercicios de estatistica resolvido.4
Exercicios de estatistica resolvido.4Exercicios de estatistica resolvido.4
Exercicios de estatistica resolvido.4
 
8a. aula -_estrutura_de_controle_de_repeticao_-_while_java
8a. aula -_estrutura_de_controle_de_repeticao_-_while_java8a. aula -_estrutura_de_controle_de_repeticao_-_while_java
8a. aula -_estrutura_de_controle_de_repeticao_-_while_java
 
Ap algoritmosglauco
Ap algoritmosglaucoAp algoritmosglauco
Ap algoritmosglauco
 
Introdução ao design de teste de software
Introdução ao design de teste de softwareIntrodução ao design de teste de software
Introdução ao design de teste de software
 
Modulo 2
Modulo 2Modulo 2
Modulo 2
 
Testes de Software - Módulo 2
Testes de Software - Módulo 2Testes de Software - Módulo 2
Testes de Software - Módulo 2
 
TDC2013 Otimizando-C
TDC2013 Otimizando-CTDC2013 Otimizando-C
TDC2013 Otimizando-C
 
Estratégias e Técnicas de Testes - Parte 2
Estratégias e Técnicas de Testes - Parte 2Estratégias e Técnicas de Testes - Parte 2
Estratégias e Técnicas de Testes - Parte 2
 
2 controle fluxo
2 controle fluxo2 controle fluxo
2 controle fluxo
 
Modelagem Analítica – Queueing Theory (Part I)
Modelagem Analítica – Queueing Theory (Part I)Modelagem Analítica – Queueing Theory (Part I)
Modelagem Analítica – Queueing Theory (Part I)
 

Plus de Fabrício Campos

Como ser produtivo? Contando tomates
Como ser produtivo? Contando tomatesComo ser produtivo? Contando tomates
Como ser produtivo? Contando tomatesFabrício Campos
 
SVN - Subversion: Guia de sobrevivência do usuário
SVN - Subversion: Guia de sobrevivência  do usuárioSVN - Subversion: Guia de sobrevivência  do usuário
SVN - Subversion: Guia de sobrevivência do usuárioFabrício Campos
 
Teste de Performance - 3º Encontro da ALATS
Teste de Performance - 3º Encontro da ALATSTeste de Performance - 3º Encontro da ALATS
Teste de Performance - 3º Encontro da ALATSFabrício Campos
 
QAMP (Quality Assurance Management Professional)
QAMP (Quality Assurance Management Professional)QAMP (Quality Assurance Management Professional)
QAMP (Quality Assurance Management Professional)Fabrício Campos
 
A Importância do Teste de Software
A Importância do Teste de SoftwareA Importância do Teste de Software
A Importância do Teste de SoftwareFabrício Campos
 

Plus de Fabrício Campos (7)

Como ser produtivo? Contando tomates
Como ser produtivo? Contando tomatesComo ser produtivo? Contando tomates
Como ser produtivo? Contando tomates
 
SVN - Subversion: Guia de sobrevivência do usuário
SVN - Subversion: Guia de sobrevivência  do usuárioSVN - Subversion: Guia de sobrevivência  do usuário
SVN - Subversion: Guia de sobrevivência do usuário
 
Teste de Performance - 3º Encontro da ALATS
Teste de Performance - 3º Encontro da ALATSTeste de Performance - 3º Encontro da ALATS
Teste de Performance - 3º Encontro da ALATS
 
QAMP (Quality Assurance Management Professional)
QAMP (Quality Assurance Management Professional)QAMP (Quality Assurance Management Professional)
QAMP (Quality Assurance Management Professional)
 
A Importância do Teste de Software
A Importância do Teste de SoftwareA Importância do Teste de Software
A Importância do Teste de Software
 
CTFL - BSTQB
CTFL - BSTQBCTFL - BSTQB
CTFL - BSTQB
 
Por que testar?
Por que testar?Por que testar?
Por que testar?
 

Dernier

ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docxATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx2m Assessoria
 
Boas práticas de programação com Object Calisthenics
Boas práticas de programação com Object CalisthenicsBoas práticas de programação com Object Calisthenics
Boas práticas de programação com Object CalisthenicsDanilo Pinotti
 
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docxATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx2m Assessoria
 
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docxATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx2m Assessoria
 
Padrões de Projeto: Proxy e Command com exemplo
Padrões de Projeto: Proxy e Command com exemploPadrões de Projeto: Proxy e Command com exemplo
Padrões de Projeto: Proxy e Command com exemploDanilo Pinotti
 
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docxATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx2m Assessoria
 

Dernier (6)

ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docxATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
 
Boas práticas de programação com Object Calisthenics
Boas práticas de programação com Object CalisthenicsBoas práticas de programação com Object Calisthenics
Boas práticas de programação com Object Calisthenics
 
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docxATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
 
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docxATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
 
Padrões de Projeto: Proxy e Command com exemplo
Padrões de Projeto: Proxy e Command com exemploPadrões de Projeto: Proxy e Command com exemplo
Padrões de Projeto: Proxy e Command com exemplo
 
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docxATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
 

Técnicas de modelagem de teste (parte 2)

  • 2. Baseadas em Estrutura Teste e Cobertura de Comandos Teste e Cobertura de Decisão Outras técnicas baseadas na estrutura
  • 3. O que e cobertura de teste Cobertura de teste é uma medida, referente ao número de itens (código) testados, pelo total de itens, multiplicado por 100%. número de itens x 100% exercitados Cobertura = total de itens
  • 4. Teste e Cobertura de Comandos Definir casos de teste que executem todos os comandos pelo menos uma vez (passa por todos os nodos do grafo) Métrica: número de nodos cobertos Fácil de satisfazer Não garante qualidade do código
  • 5. Teste e Cobertura de Comandos Cobertura de comando é medida, de acordo com o número de comandos exercitados divididos pelo total de comandos, multiplicado por 100%. número de comandos x 100% exercitados Cobertura = de comando total de comandos
  • 6. Teste e Cobertura de Comandos 2 1 1.a = Integer.parseInt(args[0]); 3 2.b = Integer.parseInt(args[1]); 3.while(a < 0){ 4 4. if (b < 0){ 5. b = b + 2; Um teste é o 5 6. } suficiente 7 7. a = a + 1; a b C 9 8.} (resultado) -1 -1 1 9.c = a + b;
  • 7. Teste e Cobertura de Comandos Questão simulado (CTFL-BSTQB) Se você estiver voando com um bilhete da classe econômica, há uma possibilidade de você conseguir mudar para a classe executiva. Principalmente se você tiver um cartão fidelidade da companhia aérea. Se você não tiver o cartão fidelidade (CF), há a possibilidade de você ser quot;despejadoquot; do vôo se ele estiver lotado e você chegar atrasado.
  • 8. Teste e Cobertura de Comandos n s s cartão econômica executiva fidelidade lotada lotada s n n s executiva econômica lotada n econômica despejado mudar mudar do vôo embarcar
  • 9. Teste e Cobertura de Comandos Questão simulado (CTFL-BSTQB) Três testes foram executados: Teste 1: O passageiro tem o CF e mudou para a classe executiva Teste 2: O passageiro não tem o CF e permaneceu na classe econômica Teste 3: O passageiro foi quot;despejadoquot; do vôo Qual é a cobertura de comando obtida com esses três testes? a) 60% b) 70% c) 80% d) 90%
  • 10. Teste e Cobertura de Comandos Resposta correta Alternativa: c) 80% Os três testes apresentados cobrem 8 comandos de 10, ou seja, 80% dos comandos. Os testes não cobrem o comando 3 e o 9.
  • 11. Teste e Cobertura de ~ Decisao Uma decisão é um IF, um loop (ex. do-while ou repeat-until), ou um CASE, no qual existem duas ou mais possibilidades de saídas ou resultados a partir de um comando número de decisões x 100% exercitados Cobertura = de decisão total de decisões
  • 12. Teste e Cobertura de ~ Decisao Teste de decisão é uma forma de teste de controle de fluxo, já que ele gera um fluxo específico através dos pontos de decisões A cobertura de decisão é mais eficiente que a cobertura de comandos: 100% da cobertura de decisão garante 100% da cobertura de comandos, mas não vice-versa
  • 13. Teste e Cobertura de ~ Decisao Os testes devem cobrir cada saída possível de um nodo que tenha uma condição Métrica: número de arestas cobertas Teste de decisão derivam-se dos casos de testes para executar decisões específicas, normalmente para se aumentar a cobertura
  • 14. Teste e Cobertura de ~ Decisao 2 1 1.a = Integer.parseInt(args[0]); 3 2.b = Integer.parseInt(args[1]); 3.while(a < 0){ três testes são 4 4. if (b < 0){ necessários 5. b = b + 2; ab C 5 (resultado) 6. } -1 -1 1 7 7. a = a + 1; 00 0 9 8.} -1 0 0 9.c = a + b;
  • 15. Teste e Cobertura de ~ Decisao Questão simulado (CTFL-BSTQB) Tendo como base o pseudocódigo abaixo, quantos testes são necessários para atingir 100% da cobertura de desvio/decisão? a) 1 1. If x = 3 then b) 2 2. Display_messageX; c) 3 3. If y = 2 then d) 4 4. Display_messageY; 5. else 6. Display_messageZ; 7. else 8. Display_messageZ;
  • 16. Teste e Cobertura de ~ Decisao Resposta correta Alternativa: c) 3 Criando três testes conseguimos cobrir 100% das decisões do pseudocódigo, por exemplo: x y 3 2 0 0 3 0
  • 17. Outras tecnicas baseadas na estrutura Cobertura de desvio LCSAJ (Linear Code Sequence and Jump - Seqüência de Código Linear e Salto) Cobertura de Caminho
  • 18. Cobertura de desvio Está estreitamente relacionada com a cobertura de decisão, tanto que 100% de cobertura de desvio, equivale a 100% de cobertura de decisão Cobertura de decisão medi a cobertura dos desvios condicionais, já a cobertura de desvio medi a cobertura de desvios condicionais e não condicionais
  • 19. LCSAJ Inclui a cobertura de código linear e salto, cobertura de decisão, cobertura de condições e cobertura de múltiplas condições Essa técnica requer a cobertura de todas as condições que podem afetar ou determinar o resultado de uma condição
  • 20. Cobertura de Caminho Especifica dos caminhos possíveis de um software, quantos são cobertos na execução de um teste Porcentagem de caminhos exercitada por uma suite de teste. 100% de cobertura de caminho implicam em 100% de cobertura LCSAJ
  • 21. ^ Baseadas na experiencia Suposição de erro Teste exploratório
  • 22. ~ Suposicao de erro Deve ser usada sempre como um complemento à outras técnicas mais formais Não há regras para a suposição de erro Quando usado para aumentar a técnica sistemática, testes intuitivos podem ser úteis para identificar testes específicos que não são facilmente identificados pelas técnicas formais Depende muito da habilidade e experiência do testador
  • 23. Teste exploratorio Ocorre simultaneamente à modelagem, execução e registro de teste, e baseia-se nos objetivos de teste, onde é realizado em um tempo predefinido É uma abordagem muito usual, em locais onde a especificação é rara ou inadequada e existe grande pressão por conta de prazo, ou para aprimorar/complementar um teste mais formal
  • 24. Teste exploratorio Pode servir como uma checagem do processo de teste, assegurando que os defeitos mais importantes sejam encontrados O aspecto principal é a aprendizagem: sobre o software, seu uso, seu pontos fortes e fracos Também pode servir de complemento para outras técnicas formais
  • 25.
  • 26.  BSTQB. Base de Conhecimento para Certificação em Teste - Foundation Level Syllabus. 2007br.  BSTQB. Glossário Padrão de Termos Utilizados em Teste de Software. Versão 1.3br  D. Grahan; V. Veenendaal; I. Evans; R. Black. Foundations of Software Testing: ISTQB Certification. Cengage Learning Business Press, 2006. www.inf.pucrs.br/~copstein/CursoTeste/Dia3/Dia3_TesteFunciona lTesteEstrutural.ppt (Professor Dr. Bernardo Copstein)