English

Model-Based Testing of an Intermediate Verifier Using Executable Operational Semantics

Logic in Computer Science 2025-08-26 v1

Abstract

Lightweight validation technique, such as those based on random testing, are sometimes practical alternatives to full formal verification -- providing valuable benefits, such as finding bugs, without requiring a disproportionate effort. In fact, they can be useful even for fully formally verified tools, by exercising the parts of a complex system that go beyond the reach of formal models. In this context, this paper introduces BCC: a model-based testing technique for the Boogie intermediate verifier. BCC combines the formalization of a small, deterministic subset of the Boogie language with the generative capabilities of the PLT Redex language engineering framework. Basically, BCC uses PLT Redex to generate random Boogie programs, and to execute them according to a formal operational semantics; then, it runs the same programs through the Boogie verifier. Any inconsistency between the two executions (in PLT Redex and with Boogie) may indicate a potential bug in Boogie's implementation. To understand whether BCC can be useful in practice, we used it to generate three million Boogie programs. These experiments found 2% of cases indicative of completeness failures (i.e., spurious verification failures) in Boogie's toolchain. These results indicate that lightweight analysis tools, such as those for model-based random testing, are also useful to test and validate formal verification tools such as Boogie.

Keywords

Cite

@article{arxiv.2508.17895,
  title  = {Model-Based Testing of an Intermediate Verifier Using Executable Operational Semantics},
  author = {Lidia Losavio and Marco Paganoni and Carlo A. Furia},
  journal= {arXiv preprint arXiv:2508.17895},
  year   = {2025}
}

Comments

In Proceedings of the 20th International Conference on integrated Formal Methods (iFM), Paris, France, 17-21 November 2025

R2 v1 2026-07-01T05:04:24.145Z