6

我在为我的一个项目生成覆盖率报告时遇到了麻烦——似乎在分叉之后的子进程中的行从未被击中,尽管它们显然是现实的。

这是fork部分的工作服报告(结果与lcov+genhtml相同),以及构建日志

该项目使用带有 libtool 的 autotools 进行构建,并将所有内容打包为静态库。(configure.ac库 makefile.am测试 makefile.am

我尝试将覆盖率标志添加到测试和--coverageCFLAGS 中,但无济于事。

最让我烦恼的是,我试图在一个简单的 C 文件上重现该行为,如下所示:

#include <stdio.h>
#include <unistd.h>
#include <sys/wait.h>
#include <sys/types.h>

int main(void)
{
    pid_t pid;
    if (!(pid = fork())) {
        puts("In child");
    } else {
        puts("In parent");
        waitpid(pid, NULL, 0);
    }
    return 0;
}

使用以下 shell 会话:

/bin/sh ./libtool  --tag=CC   --mode=compile gcc -DHAVE_CONFIG_H -I. -I./src    -Wall -Wextra -Wno-unused-result -Wno-missing-field-initializers -std=gnu99 -fplan9-extensions -I./include/ -I./dependencies/csptr/include/ -O0 --coverage -fprofile-arcs -ftest-coverage -g -O0 -MT test.lo -MD -MP -MF test.Tpo -c -o test.lo test.c
/bin/sh ./libtool  --tag=CC   --mode=link gcc -Wall -Wextra -Wno-unused-result -Wno-missing-field-initializers -std=gnu99 -fplan9-extensions -I./include/ -I./dependencies/csptr/include/ -O0 --coverage -fprofile-arcs -ftest-coverage -g -O0 -lgcov  -o test -rpath /usr/local/lib test.lo
#The two lines above are adapted versions of what autotools with libtool run to compile my project.

./test
mkdir -p coverage
lcov --compat-libtool --directory . --capture --output-file cov.info && genhtml -o coverage cov.info

...但生成的报告宣布 100% 的覆盖率。

怎么了 ?我的构建是否损坏?

4

1 回答 1

12

在我重新调查这个问题一段时间后,我能够找到它:

_exit()用来终止子进程,它具有绕过进程的任何最终确定的属性,并随之调用__gcov_flush()-- 这就是我没有得到任何报道的原因。

于 2015-04-09T20:34:07.513 回答