Automatically fixing static analysis tools violations
Dissertação (mestrado)—Universidade de Brasília, Instituto de Ciências Exatas, Departamento de Ciência da Computação, 2019.
Main Author: | Marcilio, Diego Venâncio |
---|---|
Other Authors: | Almeida, Rodrigo Bonifácio de |
Format: | Dissertação |
Language: | Português |
Published: |
2020
|
Subjects: | |
Online Access: |
https://repositorio.unb.br/handle/10482/37098 |
Tags: |
Add Tag
No Tags, Be the first to tag this record!
|
id |
ir-10482-37098 |
---|---|
recordtype |
dspace |
spelling |
ir-10482-370982020-03-11T22:12:39Z Automatically fixing static analysis tools violations Marcilio, Diego Venâncio Almeida, Rodrigo Bonifácio de Software Estática Software - defeitos Dissertação (mestrado)—Universidade de Brasília, Instituto de Ciências Exatas, Departamento de Ciência da Computação, 2019. A qualidade de software tem se tornado cada vez mais importante à medida que a so- ciedade depende mais de sistemas de software. Defeitos de software podem custar caro à organizações, especialmente quando causam falhas. Ferramentas de análise estática analisam código para encontrar desvios, ou violações, de práticas recomendadas de pro- gramação definidas como regras. Essa análise pode encontrar defeitos de software de forma antecipada, mais rápida e barata, em contraste à inspeções manuais. Para corrigir- se uma violação é necessário que o programador modifique o código problemático. Essas modificações podem ser tediosas, passíveis de erro e repetitivas. Dessa forma, a au- tomação de transformações de código é uma funcionalidade frequentemente requisitada por desenvolvedores. Esse trabalho implementa transformações automáticas para resolver violações identificadas por ferramentas de análise estática. Primeiro, nós investigamos o uso da ferramenta SonarQube, uma ferramenta amplamente utilizada, em duas grandes organizações open-source e duas instituições do Governo Federal do Brasil. Nossos re- sultados mostram que um pequeno subconjunto de regras é responsável por uma grande porção das violações resolvidas. Nós implementamos transformações automáticas para 11 regras do conjunto de regras comumente resolvidas achadas no estudo anterior. Nós submetemos 38 pull requests, incluindo 920 soluções para violações, geradas automati- camente pela nossa técnica para diversos projetos open-source na linguagem Java. Os mantenedores dos projetos aceitaram 84% das nossas transformações, sendo 95% delas sem nenhuma modificação. Esses resultados indicam que nossa abordagem é prática, e pode auxiliar desenvolvedores com resoluções automáticas, uma funcionalidade frequente- mente requisitada. Software quality is becoming more important as the reliance on software systems in- creases. Software defects may have a high cost to organizations as some can lead to software failure. Static analysis tools analyze code to find deviations, or violations, from recommended programming practices defined as rules. This analysis can find software defects earlier, faster, and cheaper than manual inspections. When fixing a violation, a programmer is required to modify the violating code. Such modifications can be tedious, error-prone, and repetitive. Unsurprisingly, automated transformations are frequently re- quested by developers. This work implements automatic transformations tailored to solve violations identified by static analysis tools. First, we investigate the use of SonarQube, a widely used Static Analysis Tool, in two large open source organizations and two Brazil- ian Government Federal Institutions. Our results show that a small subset of the rules is responsible for a large portion of the fixes. We implement automatic fixes for 11 rules from the previously found set of frequently fixed rules. We submitted 38 pull requests, including 920 fixes generated automatically by our technique for various open-source Java projects. Projects maintainers accepted 84% of our fixes (95% of them without any mod- ifications). These results indicate that our approach is feasible, and can aid developers with automatic fixes, a long requested feature. 2020-03-11T22:12:39Z 2020-03-11T22:12:39Z 2020-03-11 2019-08-05 Dissertação MARCILIO, Diego Venâncio. Automatically fixing static analysis tools violations. 2019. xi, 62 f., il. Dissertação (Mestrado em Informática)—Universidade de Brasília, Brasília, 2019. https://repositorio.unb.br/handle/10482/37098 Português Acesso Aberto A concessão da licença deste item refere-se ao termo de autorização impresso assinado pelo autor com as seguintes condições: Na qualidade de titular dos direitos de autor da publicação, autorizo a Universidade de Brasília e o IBICT a disponibilizar por meio dos sites www.bce.unb.br, www.ibict.br, http://hercules.vtls.com/cgi-bin/ndltd/chameleon?lng=pt&skin=ndltd sem ressarcimento dos direitos autorais, de acordo com a Lei nº 9610/98, o texto integral da obra disponibilizada, conforme permissões assinaladas, para fins de leitura, impressão e/ou download, a título de divulgação da produção científica brasileira, a partir desta data. application/pdf |
institution |
REPOSITORIO UNB |
collection |
REPOSITORIO UNB |
language |
Português |
topic |
Software Estática Software - defeitos |
spellingShingle |
Software Estática Software - defeitos Marcilio, Diego Venâncio Automatically fixing static analysis tools violations |
description |
Dissertação (mestrado)—Universidade de Brasília, Instituto de Ciências Exatas, Departamento de Ciência da Computação, 2019. |
author2 |
Almeida, Rodrigo Bonifácio de |
format |
Dissertação |
author |
Marcilio, Diego Venâncio |
author_sort |
Marcilio, Diego Venâncio |
title |
Automatically fixing static analysis tools violations |
title_short |
Automatically fixing static analysis tools violations |
title_full |
Automatically fixing static analysis tools violations |
title_fullStr |
Automatically fixing static analysis tools violations |
title_full_unstemmed |
Automatically fixing static analysis tools violations |
title_sort |
automatically fixing static analysis tools violations |
publishDate |
2020 |
url |
https://repositorio.unb.br/handle/10482/37098 |
_version_ |
1672205867707006976 |
score |
13.657419 |