Uma investigação da correspondência entre mutações e avisos relatados por ferramenta de análise estática
| dc.contributor.advisor1 | Vincenzi, Auri Marcelo Rizzo | |
| dc.contributor.advisor1Lattes | http://lattes.cnpq.br/0611351138131709 | por |
| dc.contributor.referee1 | Vincenzi, Auri Marcelo Rizzo | |
| dc.contributor.referee2 | Valente, Marco Túlio de Oliveira | |
| dc.contributor.referee3 | Lucena, Fábio Nogueira de | |
| dc.creator | Araújo, Claudio Antônio de | |
| dc.creator.Lattes | http://lattes.cnpq.br/9455733788398173 | por |
| dc.date.accessioned | 2016-04-18T13:34:40Z | |
| dc.date.issued | 2015-12-04 | |
| dc.description.abstract | Traditionally, mutation testing is used for test set and/or test criteria evaluation once it is considered a good fault model. Since static analyzers, in general, report a substantial number of false positive warnings, Objective: This paper uses mutation testing for evaluating an automated static analyzer. The intention of this study is to define a prioritization approach of static warnings based on their correspondence with mutations. Method: We used mutation operators as a fault model to evaluate the direct correspondence between mutations and static warnings. The main advantage of using mutation operators is that they generate a large number of programs containing faults of different types, which can be used to decide the ones most probable to be detected by static analyzers. Results: The results obtained for a set of open-source programs indicate that: 1) correspondence exists when considering specific mutation operators such that static warnings may be prioritized based on their correspondence level with mutations; 2) correspondence exists when considering specific warning categories such that, assuming we perform static analysis considering these warning categories, mutation operators may be prioritized based on their correspondence level with warnings. Conclusion: It is possible to provide an incremental testing strategy aiming at reducing the cost of both static analysis and mutation testing using the correspondence information. On the other hand, knowing that Mutation Test has a high application cost, we identified mutations of some specific mutation operators, which an automatic static analyzer is not able to detect. Therefore, this information can used to prioritize the order of applying mutation operators incrementally considering, firstly, those with no correspondence with static warnings. | eng |
| dc.description.resumo | Considerando que: 1) analisadores estáticos automatizados são ferramentas que emitem avisos, sem que seja necessário a execução do produto de software correspondente, alertando sobre a presença de possíveis defeitos no código. Uma das críticas a tais ferramentas é a grande quantidade de avisos falsos positivos emitidos, isto é, avisos relatados que não correspondem a defeitos reais, mas demandam tempo de análise por parte do desenvolvedor; 2) tradicionalmente, o Teste de Mutação tem sido utilizado para avaliar (e melhorar) a qualidade de conjuntos de casos de teste e/ou de critérios de teste, uma vez que é considerado um bom gerador de defeitos de software. Objetivo: O objetivo do presente trabalho é investigar a correspondência entre avisos estáticos e mutações e, com isso, verificar quais avisos estão mais relacionados a esses possíveis defeitos (mutações) e, assim, possivelmente, serem avisos verdadeiros positivos. Método: Os operadores de mutação são utilizados neste trabalho como um modelo de defeitos para avaliar a correspondência entre mutações e avisos estáticos. A principal vantagem da utilização de operadores de mutação é que eles geram um grande número de programas com defeitos de diferentes tipos. Esses tipos de defeitos são usados em estudos experimentais para investigar a capacidade dos analisadores estáticos em detectá-los. Resultados: Os resultados obtidos com estudos experimentais para um conjunto de sistemas de código aberto indicam que existe correspondência quando são considerados alguns operadores de mutação da μJava e alguns tipos de avisos da FindBugs. Conclusão: Os resultados obtidos podem ser utilizados de duas maneiras distintas: Primeiro, é fornecida uma abordagem de análise incremental dos avisos, de acordo com o grau de correspondência com mutações. Segundo, com o objetivo de reduzir o custo do Teste de Mutação é fornecida uma abordagem de priorização incremental para análise dos mutantes dos operadores cujas mutações são menos “percebidas” pela FindBugs. | por |
| dc.format | application/pdf | * |
| dc.identifier.citation | ARAÚJO, Claudio A. Uma investigação da correspondência entre mutações e avisos relatados por ferramenta de análise estática. 2015. 89 f. Dissertação (Mestrado em Ciência da Computação) - Universidade Federal de Goiás, Goiânia, 2015. | por |
| dc.identifier.uri | http://repositorio.bc.ufg.br/tede/handle/tede/5486 | |
| dc.language | por | por |
| dc.publisher | Universidade Federal de Goiás | por |
| dc.publisher.country | Brasil | por |
| dc.publisher.department | Instituto de Informática - INF (RG) | por |
| dc.publisher.initials | UFG | por |
| dc.publisher.program | Programa de Pós-graduação em Ciência da Computação (INF) | por |
| dc.rights | Acesso Aberto | por |
| dc.rights.uri | http://creativecommons.org/licenses/by-nc-nd/4.0/ | |
| dc.subject | Teste de software | por |
| dc.subject | Teste de mutação | por |
| dc.subject | Warning | por |
| dc.subject | Análise estática | por |
| dc.subject | Analisadores estáticos | por |
| dc.subject | Software testing | eng |
| dc.subject | Mutants | eng |
| dc.subject | Warnings | eng |
| dc.subject | Static analysis | eng |
| dc.subject | Static analyzer evaluation | eng |
| dc.subject.cnpq | CIENCIA DA COMPUTACAO::TEORIA DA COMPUTACAO | por |
| dc.title | Uma investigação da correspondência entre mutações e avisos relatados por ferramenta de análise estática | por |
| dc.title.alternative | Investigating the correspondence between mutations and static warnings reported by static analysis tool | eng |
| dc.type | Dissertação | por |
Arquivos
Pacote Original
1 - 1 de 1
Carregando...
- Nome:
- Dissertação - Cláudio Antônio de Araújo - 2015.pdf
- Tamanho:
- 6.18 MB
- Formato:
- Adobe Portable Document Format
- Descrição:
Licença do Pacote
1 - 1 de 1
Carregando...
- Nome:
- license.txt
- Tamanho:
- 2.11 KB
- Formato:
- Item-specific license agreed upon to submission
- Descrição: