ESBMC-Python: A Bounded Model Checker for Python Programs

Research output: Chapter in Book/Report/Conference proceedingConference contributionpeer-review

10 Downloads (Pure)

Abstract

This paper introduces a tool for verifying Python programs, which, using type annotation and front-end processing, can harness the capabilities of a bounded model-checking (BMC) pipeline. It transforms an input program into an abstract syntax tree to infer and add type information. Then, it translates Python expressions and statements into an intermediate representation. Finally, it converts this description into formulae evaluated with satisfiability modulo theories (SMT) solvers. The proposed approach was realized with the efficient SMT-based bounded model checker (ESBMC), which resulted in a tool called ESBMC-Python, the first BMC-based Python-code verifier. Experimental results, with a test suite specifically developed for this purpose, showed its effectiveness, where successful and failed tests were correctly evaluated. Moreover, it found a real problem in the Ethereum Consensus Specification.
Original languageEnglish
Title of host publicationThe ACM SIGSOFT International Symposium on Software Testing and Analysis (ISSTA)
Publication statusAccepted/In press - 26 Jul 2024

Keywords

  • Formal Verification
  • Bounded Model Checking
  • Python

Fingerprint

Dive into the research topics of 'ESBMC-Python: A Bounded Model Checker for Python Programs'. Together they form a unique fingerprint.

Cite this