【发布时间】:2017-04-06 19:55:14
【问题描述】:
我让EXPECT_CALL 通过了我的测试,直到我添加了一个标头来包装我正在测试的unsigned char *。我知道测试正在下降,因为它与预期的 unsigned char * 不同。我只是不确定如何重新设计我的测试,所以分配给的 unsigned char * 会导致测试通过。
我的测试(省略了变量的初始化):
EXPECT_CALL(networkConnectionMock, Transmit(packetData, dataSize));
packetManager.Update(0.01f);
packetManager.Send(packetData, dataSize);
被测函数:
void PacketManager::Send(unsigned char *packetData, int packetSize)
{
if(this->secondSinceLastUpdate <= 1.0f)
packetsSent++;
else
{
packetsSent = 0;
this->secondSinceLastUpdate = 0.0f;
}
std::stringstream convert;
convert << htonl((uint32_t)packetSize);
Header *header = new Header;
header->name = "PKT_" + convert.str();
header->packetSize = packetSize;
header->packetData = packetData;
unsigned char * pktHeader = new unsigned char[sizeof(Header)];
pktHeader = (unsigned char*)header;
PKT_Header = pktHeader; // tried assigning to public variable,
// but would be assigned to after EXPECT_CALL is setup.
int totalPacketSize = packetSize; // rewrite to loop through que
if(header->packetSize <= 800 && totalPacketSize <= 1024 && packetsSent <= 30)
networkConnection->Transmit(pktHeader, packetSize);
}
模拟输出:
[==========] Running 1 test from 1 test case.
[----------] Global test environment set-up.
[----------] 1 test from PacketManager
[ RUN ] PacketManager.SendsPacketsUnder1024
unknown file: Failure
Unexpected mock function call - returning directly.
Function call: Transmit(0x2096c10, 100)
Google Mock tried the following 1 expectation, but it didn't match:
/home/zerophase/ClionProjects/PacketManager/tests/basic_tests/basic_check.cpp:20: EXPECT_CALL(networkConnectionMock, Transmit(packetData, dataSize))...
Expected arg #0: is equal to 0x2096560
Actual: 0x2096c10
Expected: to be called once
Actual: never called - unsatisfied and active
/home/zerophase/ClionProjects/PacketManager/tests/basic_tests/basic_check.cpp:20: Failure
Actual function call count doesn't match EXPECT_CALL(networkConnectionMock, Transmit(packetData, dataSize))...
Expected: to be called once
Actual: never called - unsatisfied and active
[ FAILED ] PacketManager.SendsPacketsUnder1024 (0 ms)
[----------] 1 test from PacketManager (0 ms total)
[----------] Global test environment tear-down
[==========] 1 test from 1 test case ran. (0 ms total)
[ PASSED ] 0 tests.
[ FAILED ] 1 test, listed below:
[ FAILED ] PacketManager.SendsPacketsUnder1024
EXPECT_CALL 仍然是我想用来测试 Transmit 被调用的吗?
【问题讨论】:
-
请附上google mock的相关输出。
-
@AntonioPérez 我添加了 gmock 输出。
标签: c++ c googletest gmock