The example in Analyzing Test Coverage Data tells us that we can achieve 100% test coverage by executing the strsort
program without either of its two switches. To complete testing, execute the program with the following command:
strsort aaa bbbb
This produces the following output:
[strsort.c:15] **READ_NULL** >> if(dir * strcmp(a[j-1], a[j]) > 0) { Reading null pointer: <argument 2> Stack trace where the error occurred: strcmp() (interface) bubble_sort() strsort.c, 15 main() strsort.c, 41 **Memory corrupted. Program may crash!!** **Insure trapped signal: 11** Stack trace where the error occurred: strcmp() ../sysdeps/generic/strcmp.c, 39 strcmp() (interface) bubble_sort() strsort.c, 15 main() strsort.c, 41 Segmentation violation Abort (core dumped) Exit 134
The error reported in the output can be ignored. It is intentional and part of an exercise for learning how to use Insure++.
When the tca tca.log
command is executed, the following output is produced:
COVERAGE SUMMARY ================ 0 blocks untested 13 blocks tested 100% covered
This indicates that the application is 100% tested. The set of test cases that have been run, including this last one, completely exercised all the code in this application. It makes sense to incorporate these test cases (in conjunction with Insure++) into a quality assurance test suite for this code.
There are several options you can use to control coverage analysis. See Configuration Options (psrc).