1

我有一个单元测试,它通过读取函数发送的缓冲区来验证函数:

template <typename Manifold>
void print_manifold(Manifold const& manifold)
try
{
  std::cout << "Manifold has " << manifold.N0() << " vertices and "
            << manifold.N1() << " edges and " << manifold.N2() << " faces and "
            << manifold.N3() << " simplices.\n";
  // fmt::print(
  //    "Manifold has {} vertices and {} edges and {} faces and {}
  //    simplices.\n", manifold.N0(), manifold.N1(), manifold.N2(),
  //    manifold.N3());
}
catch (...)
{
  std::cerr << "print_manifold() went wrong ...\n";
  throw;
}  // print_manifold

和:

SCENARIO("Printing results", "[utility]")
{
  // redirect std::cout
  stringstream buffer;
  cout.rdbuf(buffer.rdbuf());
  GIVEN("A Manifold3")
  {
    Manifold3 const manifold(640, 4);
    WHEN("We want to print statistics on a manifold.")
    {
      THEN("Statistics are successfully printed.")
      {
        print_manifold(manifold);
        CHECK_THAT(buffer.str(), Catch::Contains("Manifold has"));
      }
    }
}

有没有办法捕获fmt::print去生成的输出stdout

当我注释掉cout代码并取消注释fmt代码时,我得到了以前的cout <<.

4

1 回答 1

1

这更像是一个 C stdio 而不是 {fmt} 问题,但您可以重定向stdout到管道并从中读取输出,如Redirecting stdout to pipe in C的答案中所述。虽然这不是一个很好的单元测试,因为它取决于全局状态,但您当前的测试有同样的问题。

于 2019-12-08T15:26:12.707 回答