核心转储和gcov覆盖率报告

3
我正在对多线程程序进行压力测试并收集覆盖率。据我所知,当程序由_exit()或某些信号(如SIGABRT、SIGSEGV等)终止时,gcov不会生成.gcda文件。
当程序崩溃时,信号会生成核心文件,但gcov覆盖率数据不会生成。显然,我可以处理信号并生成覆盖率数据,但在这种情况下,我无法生成核心转储文件。但我想生成核心转储和gcov数据文件以找出崩溃原因。
我的问题是,是否有任何方法可以在没有信号的情况下生成核心转储,或者在程序突然终止时生成gcov覆盖率数据文件?
4个回答

4
如果您需要自动进行代码覆盖回归测试,请尝试以下方法:

https://www.osadl.org/Dumping-gcov-data-at-runtime-simple-ex.online-coverage-analysis.0.html

在你的程序的 "main.c" 文件中加入:

static unsigned long long i = 0;
void __gcov_flush(void); /* check in gcc sources gcc/gcov-io.h for the prototype */

void my_handler(int signum)
{
  printf("received signal\n");
  printf("%llu\n", i);
  __gcov_flush(); /* dump coverage data on receiving SIGUSR1 */
}

int main(int argc, char **argv)
{
  struct sigaction new_action, old_action;
  int n;

  /* setup signal hander */
  new_action.sa_handler = my_handler;
  sigemptyset(&new_action.sa_mask);
  new_action.sa_flags = 0;

  sigaction(SIGUSR1, NULL, &old_action);
  if (old_action.sa_handler != SIG_IGN)
    sigaction (SIGUSR1, &new_action, NULL);
  //blah......

然后重新构建你的程序并运行:
$ ./hello &
$ killall -USR1 hello
received signal
2514147346

这样它仍然应该生成 .gcda 文件

$ gcov hello
File 'hello.c'
Lines executed:100.00% of 14
hello.c:creating 'hello.c.gcov'

1

在开始测试覆盖率之前,您需要做的是修复错误。

如果您的程序未通过其他测试,则覆盖率信息无意义。崩溃显然是某种失败,因此您需要解决此问题。

修复错误,然后您就可以了解(非故障)程序被测试的有效性有多高。

也许编写自动化测试以重现崩溃会有所帮助,以确保它不会随后退化?


0

我非常支持在运行测试时仅使用代码覆盖率 - 确定性测试。通过单元测试可以实现100%的代码行覆盖率,这是可能的(也是值得的)。

此外,在测试中,如果您遇到某种崩溃,很容易在源代码控制中禁用该测试,直到修复为止。


-1

看一下valgrind(或者发布代码以便我们提供帮助)


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接