PLApr 14

The Search for Constrained Random Generators

arXiv:2511.1225367.81 citationsh-index: 12
AI Analysis

For developers using property-based testing, this work provides an automatic method to generate valid test cases satisfying complex preconditions, addressing a key bottleneck in PBT.

The paper tackles the constrained random generation problem in property-based testing, proposing a novel approach using deductive program synthesis to automatically generate correct generators. The system, Palamedes, handles recursive predicates and is implemented in Lean, reducing implementation burden.

Among the biggest challenges in property-based testing (PBT) is the constrained random generation problem: given a predicate on program values, randomly sample from the set of all values satisfying that predicate, and only those values. Efficient solutions to this problem are critical, since the executable specifications used by PBT often have preconditions that input values must satisfy in order to be valid test cases, and satisfying values are often sparsely distributed. We propose a novel approach to this problem using ideas from deductive program synthesis. We present a set of synthesis rules, based on a denotational semantics of generators, that give rise to an automatic procedure for synthesizing correct generators. Our system handles recursive predicates by rewriting them as catamorphisms and then matching with appropriate anamorphisms; this is theoretically simpler than other approaches to synthesis for recursive functions, yet still extremely expressive. Our implementation, Palamedes, is an extensible library for the Lean theorem prover. The synthesis algorithm itself is built on standard proof-search tactics, reducing implementation burden and allowing the algorithm to benefit from further advances in Lean proof automation.

Foundations

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

Your Notes