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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
#!/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:
        print 'no data found'
        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):
        print 'info file {} is not exists, ignored'.format(info_file)
        exit()

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

    if actual < expected:
        print 'expected >= {} %, actual {} %, failed'.format(
            round(expected * 100, 1), round(actual * 100, 1))

        exit(1)

    print 'expected >= {} %, actual {} %, passed'.format(
        round(expected * 100, 1), round(actual * 100, 1))