我正在Linux和GCC10上尝试Google框架。
基本测试工作正常,但是死亡测试有一些我不懂的地方。死亡测试宏(如EXPECT_DEBUG_DEATH )有第二个参数("matcher"),它应该是一个正则字符串,与测试结束前在stderr中打印的任何内容相比较。
TEST(MyDeathTests, MyDeathTest)
{
EXPECT_DEBUG_DEATH({ assert(false); }, "");
EXPECT_DEBUG_DEATH({ fprintf(stderr, "Bye\n"); fflush(stderr); exit(1); }, "");
EXPECT_DEBUG_DEATH({ std::cerr << "Darn" << std::endl << std::flush; std::abort(); }, "");
}死亡是正确的。但是,测试只有在使用空匹配器字符串时才会成功,正如您在上面的片段中看到的那样。测试输出中的“实际msg”始终是空的。我尝试了一些exit()、stdout、stderr和C输出函数的变体,但都没有效果。
知道为什么没有收到死亡信息吗?
发布于 2021-06-13 18:49:38
事实证明,我有两种误解:
Actual msg假设的空消息没有真正显示空消息字符串。它只使用奇怪的格式。在打印错误消息之前,Google在[ DEATH ]之后添加了一个行中断,然后是Actual msg。这让我觉得我会在控制台上看到未捕获的错误输出,但实际上是正确检测到的Actual msg.。
知道了这些事实,一切都如愿以偿。
https://stackoverflow.com/questions/67862591
复制相似问题