gcovr 文件夹级别摘要

gcovr folder level summaries

我有一个结构如下的项目:

/path/to/source/A/ChildA1/A1.cpp
/path/to/source/A/ChildA2/A2.cpp
/path/to/source/B/ChildB1/B1.cpp
/path/to/source/B/ChildB2/B2.cpp

最高级别的覆盖率报告显示了每个直接包含代码的文件夹的摘要:

/path/to/source/A/ChildA1/
/path/to/source/A/ChildA2/
/path/to/source/B/ChildB1/
/path/to/source/B/ChildB2/

有什么方法我也可以获得不直接包含代码的级别的报告?也就是说,只为:

/path/to/source/A/
/path/to/source/B/

几个月以来我一直在使用 gcovr。我仅为源级别创建报告。但是,是的,它也可以用于您的目的。

一种方法是从整个报告中提取(grep 或 findstr)特定文件夹的数据。

例如我们从 gcovr 得到的报告是这样的:

------------------------------------------------------------------------------
                       GCC Code Coverage Report
Directory: ...../src/
------------------------------------------------------------------------------
File                                       Lines    Exec  Cover   Missing
------------------------------------------------------------------------------
src/A/A1/xyz.cpp                            1609       2     0%   97,99,101....
src/A/A2/abcg.cpp                            271       4     1%   .......
src/B/B1/mnop.cpp                             74       2     2%   34,42,56-.....
src/B/B2/wrds.cpp                           1533       6     0%   76,83,85-.....
src/C/C1/abcdefg.cpp                        1079       8     0%   143,150,152.....

因此,您可以通过指定目录结构(如 "src/A" 并从所有被 grep 的行中获取第二个字段总和和第三个字段总和来获取该目录的覆盖范围来简单地执行 grep 语句。

这看起来很忙,但是是的,它需要一个简单的 3-4 行脚本来完成。

脚本应该是这样的:

python gcovr -d -r src/directory/ > ABCcoverage.txt
while read -r DIRPATH ; do
    grep "$DIRPATH" ABCcoverage.txt > temp.txt
    #ln is lines in file and ex is no. of executed lines
    lnsum=0 ; exsum=0
    while read -r LINE ; do
        ln=$(echo $LINE | awk '{print }')
        ex=$(echo $LINE | awk '{print }')
        lnsum=$(expr $lnsum + $ln)
        exsum=$(expr $exsum + $ex)
    done < "temp.txt"
    echo $DIRPATH, lines:$lnsum, executed:$exsum, covered %:$(expr ( $exsum / $lnsum ) \* 100 ) >> IntendedResult.txt
done < "DIRLIST.txt"

尽管如此,执行算术运算的方法要方便得多。因此,请随意编辑人员。 :D

另一种方法是生成 xml 报告而不是此控制台报告。它使用 cobertura xml 格式,因此具有包标签(每个目录结构的包)。但是请相信我,编写代码来计算每一行并检查它是否对每个包都有任何命中是非常烦人的。