43 lines
1.1 KiB
Python
43 lines
1.1 KiB
Python
|
"""Generate HTML code coverage reports."""
|
||
|
from __future__ import (absolute_import, division, print_function)
|
||
|
__metaclass__ = type
|
||
|
|
||
|
import os
|
||
|
|
||
|
from ..util import (
|
||
|
display,
|
||
|
make_dirs,
|
||
|
)
|
||
|
|
||
|
from ..util_common import (
|
||
|
ResultType,
|
||
|
)
|
||
|
|
||
|
from .combine import (
|
||
|
command_coverage_combine,
|
||
|
)
|
||
|
|
||
|
from . import (
|
||
|
run_coverage,
|
||
|
CoverageConfig,
|
||
|
)
|
||
|
|
||
|
|
||
|
def command_coverage_html(args):
|
||
|
"""
|
||
|
:type args: CoverageConfig
|
||
|
"""
|
||
|
output_files = command_coverage_combine(args)
|
||
|
|
||
|
for output_file in output_files:
|
||
|
if output_file.endswith('-powershell'):
|
||
|
# coverage.py does not support non-Python files so we just skip the local html report.
|
||
|
display.info("Skipping output file %s in html generation" % output_file, verbosity=3)
|
||
|
continue
|
||
|
|
||
|
dir_name = os.path.join(ResultType.REPORTS.path, os.path.basename(output_file))
|
||
|
make_dirs(dir_name)
|
||
|
run_coverage(args, output_file, 'html', ['-i', '-d', dir_name])
|
||
|
|
||
|
display.info('HTML report generated: file:///%s' % os.path.join(dir_name, 'index.html'))
|