Publication | Closed Access
Taming compiler fuzzers
146
Citations
39
References
2013
Year
Unknown Venue
Software MaintenanceEngineeringCompiler TechnologyVerificationTest Data GenerationSoftware EngineeringSoftware AnalysisFormal VerificationRandom Test CasesCompiler BugsFuzzingCompilersCompiler FuzzersCompiler SupportComputer ScienceAggressive RandomStatic Program AnalysisSoftware DesignMutation-based TestingProgram AnalysisSoftware TestingFormal MethodsCombinatorial Testing Workflow
Aggressive random testing tools ("fuzzers") are impressively effective at finding compiler bugs. For example, a single test-case generator has resulted in more than 1,700 bugs reported for a single JavaScript engine. However, fuzzers can be frustrating to use: they indiscriminately and repeatedly find bugs that may not be severe enough to fix right away. Currently, users filter out undesirable test cases using ad hoc methods such as disallowing problematic features in tests and grepping test results. This paper formulates and addresses the fuzzer taming problem: given a potentially large number of random test cases that trigger failures, order them such that diverse, interesting test cases are highly ranked. Our evaluation shows our ability to solve the fuzzer taming problem for 3,799 test cases triggering 46 bugs in a C compiler and 2,603 test cases triggering 28 bugs in a JavaScript engine.
| Year | Citations | |
|---|---|---|
Page 1
Page 1