gcov产生0覆盖率,但单元测试运行得很好

时间:2017-02-03 19:44:51

标签: c gcov

我为代码写了大约8个单元测试,对于其中一些代码,gcov覆盖率与单元测试覆盖率一致(显示所有块都已执行等)。其余的,gcov看起来像这样:

function XXX called 0 returned 0% blocks executed 0%

但我的单元测试看起来是这样的:

Lines executed:80.00% of 10
Branches executed:100.00% of 8
Taken at least once:75.00% of 8
No calls

我很困惑因为它显示了函数中的一些行被执行,但gcov告诉我不然。有没有人知道我做错了什么? 谢谢!

1 个答案:

答案 0 :(得分:0)

为了更详细地描述问题,万一其他人遇到同样的问题,我正在运行单元测试,我知道单元测试很好,一切似乎编译得很好,但不知怎的,我是获得0覆盖率。

事实证明我的makefile正在做一些有趣的事情。我的makefile中有这个块,看起来像这样:

unittestresults.out: 
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o unittest1 -g unittest1.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o unittest2 -g unittest2.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o unittest3 -g unittest3.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o unittest4 -g unittest4.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o cardtest1 -g cardtest1.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o cardtest2 -g cardtest2.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o cardtest3 -g cardtest3.c dominion.o rngs.o
    gcc -fprofile-arcs -ftest-coverage -Wall -lm -std=c99 -o cardtest4 -g cardtest4.c dominion.o rngs.o
    ./unittest1 &> unittestresult.out
    ./unittest2 >> unittestresult.out
    ./unittest3 >> unittestresult.out
    ./unittest4 >> unittestresult.out
    ./cardtest1 >> unittestresult.out
    ./cardtest2 >> unittestresult.out
    ./cardtest3 >> unittestresult.out
    ./cardtest4 >> unittestresult.out
    gcov -b dominion.c >> unittestresult.out
    cat dominion.c.gcov >> unittestresult.out

我最后将第一行更改为此并修复了所有内容。使用相同的单元测试,我现在得到报道:

unittestresults.out: unittest1.c unittest2.c unittest3.c unittest4.c cardtest1.c cardtest2.c cardtest3.c cardtest4.c dominion.o rngs.o