SEJan 26, 2022

Fuzzing Class Specifications

arXiv:2201.10874v129 citations
Originality Incremental advance
AI Analysis

This addresses the challenge of generating executable constraints for software engineering tasks like test generation and bug finding, offering an incremental improvement over existing techniques by supporting more expressive assertion languages.

The paper tackles the problem of automatically inferring class specifications from code, which developers rarely write manually, by introducing SpecFuzzer, a technique that combines grammar-based fuzzing, dynamic invariant detection, and mutation analysis. The results show that SpecFuzzer is more effective than state-of-the-art methods like GAssert and EvoSpex in inferring specifications, as evaluated on a benchmark of 43 Java methods.

Expressing class specifications via executable constraints is important for various software engineering tasks such as test generation, bug finding and automated debugging, but developers rarely write them. Techniques that infer specifications from code exist to fill this gap, but they are designed to support specific kinds of assertions and are difficult to adapt to support different assertion languages, e.g., to add support for quantification, or additional comparison operators, such as membership or containment. To address the above issue, we present SpecFuzzer, a novel technique that combines grammar-based fuzzing, dynamic invariant detection, and mutation analysis, to automatically produce class specifications. SpecFuzzer uses: (i) a fuzzer as a generator of candidate assertions derived from a grammar that is automatically obtained from the class definition; (ii) a dynamic invariant detector -- Daikon -- to filter out assertions invalidated by a test suite; and (iii) a mutation-based mechanism to cluster and rank assertions, so that similar constraints are grouped and then the stronger prioritized. Grammar-based fuzzing enables SpecFuzzer to be straightforwardly adapted to support different specification languages, by manipulating the fuzzing grammar, e.g., to include additional operators. We evaluate our technique on a benchmark of 43 Java methods employed in the evaluation of the state-of-the-art techniques GAssert and EvoSpex. Our results show that SpecFuzzer can easily support a more expressive assertion language, over which is more effective than GAssert and EvoSpex in inferring specifications, according to standard performance metrics.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes