P4Testgen: An Extensible Test Oracle For P4

Fabian Ruffy,Jed Liu,Prathima Kotikalapudi,Vojtěch Havel,Hanneli Tavante,Rob Sherwood,Vladyslav Dubina,Volodymyr Peschanenko,Anirudh Sivaraman,Nate Foster
DOI: https://doi.org/10.1145/3603269.3604834
2023-08-06
Abstract:We present P4Testgen, a test oracle for the P4$_{16}$ language. P4Testgen supports automatic test generation for any P4 target and is designed to be extensible to many P4 targets. It models the complete semantics of the target's packet-processing pipeline including the P4 language, architectures and externs, and target-specific extensions. To handle non-deterministic behaviors and complex externs (e.g., checksums and hash functions), P4Testgen uses taint tracking and concolic execution. It also provides path selection strategies that reduce the number of tests required to achieve full coverage. We have instantiated P4Testgen for the V1model, eBPF, PNA, and Tofino P4 architectures. Each extension required effort commensurate with the complexity of the target. We validated the tests generated by P4Testgen by running them across the entire P4C test suite as well as the programs supplied with the Tofino P4 Studio. Using the tool, we have also confirmed 25 bugs in mature, production toolchains for BMv2 and Tofino.
Networking and Internet Architecture,Symbolic Computation,Software Engineering
What problem does this paper attempt to address?