49 lines
1.2 KiB
Python
49 lines
1.2 KiB
Python
"""Generate HTML code coverage reports."""
|
|
from __future__ import (absolute_import, division, print_function)
|
|
__metaclass__ = type
|
|
|
|
import os
|
|
|
|
from ...io import (
|
|
make_dirs,
|
|
)
|
|
|
|
from ...util import (
|
|
display,
|
|
)
|
|
|
|
from ...util_common import (
|
|
ResultType,
|
|
)
|
|
|
|
from .combine import (
|
|
command_coverage_combine,
|
|
CoverageCombineConfig,
|
|
)
|
|
|
|
from . import (
|
|
run_coverage,
|
|
)
|
|
|
|
|
|
def command_coverage_html(args):
|
|
"""
|
|
:type args: CoverageHtmlConfig
|
|
"""
|
|
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'))
|
|
|
|
|
|
class CoverageHtmlConfig(CoverageCombineConfig):
|
|
"""Configuration for the coverage html command."""
|