UML Activity Diagram-Based Automatic Test Case Generation for Java Programs

Mingsong Chen,Xiaokang Qiu,Wei Xu,Linzhang Wang,Jianhua Zhao,Xuandong Li
DOI: https://doi.org/10.1093/comjnl/bxm057
2007-01-01
The Computer Journal
Abstract:Test case generation based on design specifications is an important part of testing processes. In this paper, Unified Modeling Language activity diagrams are used as design specifications. By setting up several test adequacy criteria with respect to activity diagrams, an automatic approach is presented to generate test cases for Java programs. Instead of directly deriving test cases from activity diagrams, this approach selects test cases from a set of randomly generated ones according to a given test adequacy criterion. In the approach, we first instrument a Java program under testing according to its activity diagram model, and randomly generate abundant test cases for the program. Then, by running the instrumented program we obtain the corresponding program execution traces. Finally, by matching these traces with the behavior of the activity diagram, a reduced set of test cases are selected according to the given test adequacy criterion. This approach can also be used to check the consistency between the program execution traces and the behavior of activity diagrams.
What problem does this paper attempt to address?