c ++ Google Tests运行两次

时间:2014-02-25 11:50:29

标签: c++ eclipse unit-testing googletest

我开始使用Google Test在我的代码上运行单元测试。我使用Eclipse Kepler而不是Ubuntu 12.04。

我在第一次测试中使用了以下类:

AllTests.cpp

#include "gtest/gtest.h"
#include "SerialManagerTest.cpp"

int main(int argc, char **argv) {
::testing::InitGoogleTest(&argc, argv);
return RUN_ALL_TESTS();
}

SerialManagerTest.cpp

#include "gtest/gtest.h"
#include "SerialManager.h"
#include "SerialInterface.h"
#include "FakeSerialHandler.h"

namespace {

TEST(TestingSerialManager, FirstTest) {
  SerialInterface *fakeSerialHandler=new FakeSerialHandler();
  SerialManager* serialManager=new SerialManager(fakeSerialHandler);
  ASSERT_TRUE(serialManager->OpenPort());

  delete serialManager;
}

TEST(TestingSerialManager, SecondTest) {
SerialInterface *fakeSerialHandler=new FakeSerialHandler();
SerialManager* serialManager=new SerialManager(fakeSerialHandler);
ASSERT_FALSE(!serialManager->OpenPort());

delete serialManager;
}
}

当我运行测试时,我得到了这个输出

[==========] Running 4 tests from 1 test case.
[----------] Global test environment set-up.
[----------] 4 tests from TestingSerialManager
[ RUN      ] TestingSerialManager.FirstTest
[       OK ] TestingSerialManager.FirstTest (0 ms)
[ RUN      ] TestingSerialManager.SecondTest
[       OK ] TestingSerialManager.SecondTest (0 ms)
[ RUN      ] TestingSerialManager.FirstTest
[       OK ] TestingSerialManager.FirstTest (0 ms)
[ RUN      ] TestingSerialManager.SecondTest
[       OK ] TestingSerialManager.SecondTest (0 ms)
[----------] 4 tests from TestingSerialManager (2 ms total)

[----------] Global test environment tear-down
[==========] 4 tests from 1 test case ran. (3 ms total)
[  PASSED  ] 4 tests.

为什么每次测试都要处理两次?

1 个答案:

答案 0 :(得分:2)

为什么在翻译单元中包含翻译单元?

#include "SerialManagerTest.cpp"

它在某些情况下有它的位置,但通常是一种不好的做法。

很可能发生的事情(没有看到您的命令行),是因为最终可执行文件中包含了您的SerialManagerTest代码,因此链接了两次。也就是说,它在AllTests.oSerialManagerTest.o中重复,并且两个对象都链接到最终的测试可执行文件中。