Scaling Java Program Analysis and Testing Techniques

Loading...
Thumbnail Image

Persistent link to this item

Statistics
View Statistics

Journal Title

Journal ISSN

Volume Title

Title

Scaling Java Program Analysis and Testing Techniques

Alternative title

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.