From Traces to Program Incorrectness: A Type-Theoretic Approach
By: Yongwei Yuan , Zhe Zhou , Julia Belyakova and more
Potential Business Impact:
Finds bugs in computer programs by watching how they work.
We present a type-theoretic framework for reasoning about incorrectness in functional programs that interact with effectful, opaque library APIs. Our approach centers on traces -- temporally-ordered sequences of library API invocations -- which naturally characterize both the preconditions of individual APIs and their composite behavior. We represent these traces using symbolic regular expressions (SREs), enabling formal specification of incorrect abstract data type (ADT) behaviors across function boundaries. The core contribution is a novel type inference algorithm that operates modulo specified incorrectness properties and leverages the symbolic finite automata (SFAs) representations of regexes for compositional reasoning of traces. When the algorithm succeeds, the inferred types witness that an ADT implementation can exhibit some subset of the specified incorrect behaviors. This represents the first systematic approach to underapproximate reasoning against trace-based incorrectness specifications, enabling a new form of trace-guided compositional analysis.
Similar Papers
Type-Based Incorrectness Reasoning
Programming Languages
Finds bugs in computer programs automatically.
A Complementary Approach to Incorrectness Typing
Programming Languages
Finds mistakes in computer programs automatically.
A Complementary Approach to Incorrectness Typing
Programming Languages
Finds errors in computer programs automatically.