Adaptive Testing for Specification Coverage
This addresses the problem of systematic testing for cyber-physical systems, particularly in domains like avionics, but appears incremental as it builds on existing formal methods.
The paper tackles the challenge of ensuring correctness in cyber-physical systems by proposing an adaptive testing method for Signal Temporal Logic specifications, resulting in a prototype tool that effectively generates test suites to increase coverage and infer implemented parts of specifications.
Ensuring correctness of cyber-physical systems (CPS) is an extremely challenging task that is in practice often addressed with simulation based testing. Formal specification languages, such as Signal Temporal Logic (STL), are used to mathematically express CPS requirements and thus render the simulation activity more systematic and principled. We propose a novel method for adaptive generation of tests with specification coverage for STL. To achieve this goal, we devise cooperative reachability games that we combine with numerical optimization to create tests that explore the system in a way that exercise various parts of the specification. To the best of our knowledge our approach is the first adaptive testing approach that can be applied directly to MATLAB\texttrademark\; Simulink/Stateflow models. We implemented our approach in a prototype tool and evaluated it on several illustrating examples and a case study from the avionics domain, demonstrating the effectiveness of adaptive testing to (1) incrementally build a test case that reaches a test objective, (2) generate a test suite that increases the specification coverage, and (3) infer what part of the specification is actually implemented.