coverage_lines.py 1.3 KB
Newer Older
L
Liu Xudong 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
#!/usr/bin/env python
# -*- coding: utf-8 -*-
"""
usage: coverage_lines.py info_file expected
"""
import os
import sys


def get_lines(info_file):
    """
    Args:
        info_file (str): File generated by lcov.

    Returns:
        float: Coverage rate.
    """
    hits = .0
    total = .0

    with open(info_file) as info_file:
        for line in info_file:
            line = line.strip()

            if not line.startswith('DA:'):
                continue

            line = line[3:]

            total += 1

            if int(line.split(',')[1]) > 0:
                hits += 1

    if total == 0:
C
chalsliu 已提交
36
        print('no data found')
L
Liu Xudong 已提交
37 38 39 40 41 42 43 44 45 46 47 48 49
        exit()

    return hits / total


if __name__ == '__main__':
    if len(sys.argv) < 3:
        exit()

    info_file = sys.argv[1]
    expected = float(sys.argv[2])

    if not os.path.isfile(info_file):
C
chalsliu 已提交
50
        print('info file {} is not exists, ignored'.format(info_file))
L
Liu Xudong 已提交
51 52 53 54 55 56
        exit()

    actual = get_lines(info_file)
    actual = round(actual, 3)

    if actual < expected:
C
chalsliu 已提交
57 58
        print('expected >= {} %, actual {} %, failed'.format(
            round(expected * 100, 1), round(actual * 100, 1)))
L
Liu Xudong 已提交
59 60 61

        exit(1)

C
chalsliu 已提交
62 63
    print('expected >= {} %, actual {} %, passed'.format(
        round(expected * 100, 1), round(actual * 100, 1)))