2020-01-30 22:21:33 +01:00
|
|
|
"""Generate HTML code coverage reports."""
|
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
|
|
|
|
|
|
|
import os
|
|
|
|
|
2020-02-04 20:21:53 +01:00
|
|
|
from ..io import (
|
|
|
|
make_dirs,
|
|
|
|
)
|
|
|
|
|
2020-01-30 22:21:33 +01:00
|
|
|
from ..util import (
|
|
|
|
display,
|
|
|
|
)
|
|
|
|
|
|
|
|
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'))
|