Scaling Java Program Analysis and Testing Techniques
2024-07
Loading...
View/Download File
Persistent link to this item
Statistics
View StatisticsJournal Title
Journal ISSN
Volume Title
Title
Scaling Java Program Analysis and Testing Techniques
Alternative title
Authors
Published Date
2024-07
Publisher
Type
Thesis or Dissertation
Abstract
We are witnessing a significant surge in the development of large-scale software solutions, largely propelled by the extensive reuse of components and third-party libraries. Simultaneously, our reliance on software is intensifying, prompting an increasing demand for robust methods to validate and verify software behavior. Nevertheless, our current verification and testing methodologies frequently fall short when applied to these expansive systems. In the pursuit of addressing the challenges of constructing, validating, and testing large-scale software programs, this dissertation proposes enhancements to existing state-of-the-art tools and techniques, with the goal of improving their scalability. This dissertation presents three contributions: First, we present a novel algorithm that discovers integration problems of reused software components that arise from expecting the wrong contract for the component. Given an implemented software component, our algorithm checks if our assumed contract of the component's behavior is correct, i.e., matches the implementation. If a discrepancy is identified, our algorithm attempts to repair the hypothetical contract to a matching contract that satisfies the component's implementation. Second, we improve the scalability of Java program analysis by introducing path-merging to symbolic execution. Using this technique, instead of exploring all feasible paths one at a time, symbolic execution can collapse code regions into a disjunctive logical constraint, thereby reducing the number of execution paths that need to be executed.
Finally, we improve the scalability of Java testing techniques by introducing type-based targeted mutation for generator-based fuzzers. This enhancement enables the fuzzer to generate effective inputs, accelerating the likelihood of achieving desired coverage targets.
Description
University of Minnesota Ph.D. dissertation. July 2024. Major: Computer Science. Advisors: Stephen McCamant, Mats Heimdahl. 1 computer file (PDF); x, 114 pages.
Related to
Replaces
License
Collections
Series/Report Number
Funding information
Isbn identifier
Doi identifier
Previously Published Citation
Other identifiers
Suggested citation
Hussein, Soha. (2024). Scaling Java Program Analysis and Testing Techniques. Retrieved from the University Digital Conservancy, https://hdl.handle.net/11299/269660.
Content distributed via the University Digital Conservancy may be subject to additional license and use restrictions applied by the depositor. By using these files, users agree to the Terms of Use. Materials in the UDC may contain content that is disturbing and/or harmful. For more information, please see our statement on harmful content in digital repositories.