htmlreport: fix errors when unmatched suppressions are reported via --enable=information. Incorporate tests.

This commit is contained in:
Matthias Krüger 2015-03-05 17:09:19 +01:00
parent e38f15ecc0
commit fad50de311
3 changed files with 30 additions and 5 deletions

View File

@ -25,3 +25,11 @@ echo ""
../cppcheck --errorlist --inconclusive --xml-version=2 > errorlist.xml ../cppcheck --errorlist --inconclusive --xml-version=2 > errorlist.xml
xmllint --noout errorlist.xml xmllint --noout errorlist.xml
./cppcheck-htmlreport --file ./errorlist.xml --title "errorlist" --report-dir . ./cppcheck-htmlreport --file ./errorlist.xml --title "errorlist" --report-dir .
../cppcheck ../samples/memleak/good.c ../samples/resourceLeak/good.c --xml-version=2 --enable=information --suppressions-list=test_suppressions.txt --xml 2> unmatchedSuppr.xml
xmllint --noout unmatchedSuppr.xml
./cppcheck-htmlreport --file ./unmatchedSuppr.xml --title "unmatched Suppressions" --report-dir=.
grep "unmatchedSuppression<.*>information<.*>Unmatched suppression: variableScope*<" index.html
grep ">unmatchedSuppression</.*>information<.*>Unmatched suppression: uninitstring<" index.html
grep "notexisting" index.html
grep ">unmatchedSuppression<.*>information<.*>Unmatched suppression: \*<" index.html

View File

@ -433,8 +433,11 @@ if __name__ == '__main__':
with io.open(source_filename, 'r', encoding=options.source_encoding) as input_file: with io.open(source_filename, 'r', encoding=options.source_encoding) as input_file:
content = input_file.read() content = input_file.read()
except IOError: except IOError:
sys.stderr.write("ERROR: Source file '%s' not found.\n" % if (error['id'] == 'unmatchedSuppression'):
source_filename) continue; # file not found, bail out
else:
sys.stderr.write("ERROR: Source file '%s' not found.\n" %
source_filename)
continue continue
except UnicodeDecodeError: except UnicodeDecodeError:
sys.stderr.write("WARNING: Unicode decode error in '%s'.\n" % sys.stderr.write("WARNING: Unicode decode error in '%s'.\n" %
@ -522,9 +525,15 @@ if __name__ == '__main__':
output_file.write("\n <tr><td colspan='4'>%s</td></tr>" % (filename)) output_file.write("\n <tr><td colspan='4'>%s</td></tr>" % (filename))
output_file.write("\n <tr><td colspan='4'> Could not generated due to UnicodeDecodeError</td></tr>") output_file.write("\n <tr><td colspan='4'> Could not generated due to UnicodeDecodeError</td></tr>")
else: else:
output_file.write( if filename.endswith('*'): # assume unmatched suppression
"\n <tr><td colspan='4'><a href='%s'>%s</a></td></tr>" % output_file.write(
(data['htmlfile'], filename)) "\n <tr><td colspan='4'>%s</td></tr>" %
(filename))
else:
output_file.write(
"\n <tr><td colspan='4'><a href='%s'>%s</a></td></tr>" %
(data['htmlfile'], filename))
for error in sorted(data['errors'], key=lambda k: k['line']): for error in sorted(data['errors'], key=lambda k: k['line']):
error_class = '' error_class = ''
try: try:
@ -540,6 +549,11 @@ if __name__ == '__main__':
output_file.write( output_file.write(
'\n <tr><td></td><td>%s</td><td>%s</td><td>%s</td></tr>' % '\n <tr><td></td><td>%s</td><td>%s</td><td>%s</td></tr>' %
(error['id'], error['severity'], error['msg'])) (error['id'], error['severity'], error['msg']))
elif (error['id'] == 'unmatchedSuppression') and filename.endswith('*'):
output_file.write(
"\n <tr><td></td><td>%s</td><td>%s</td><td %s>%s</td></tr>" %
(error['id'], error['severity'], error_class,
error['msg']))
else: else:
output_file.write( output_file.write(
"\n <tr><td><a href='%s#line-%d'>%d</a></td><td>%s</td><td>%s</td><td %s>%s</td></tr>" % "\n <tr><td><a href='%s#line-%d'>%d</a></td><td>%s</td><td>%s</td><td %s>%s</td></tr>" %

View File

@ -0,0 +1,3 @@
variableScope:../samples/memleak/good.c
*:../samples/resourceLeak/notexisting.c*
uninitstring:*