GMock:覆盖默认期望
GMock: Overriding a default expectation
在GMock中,是否可以替换之前设置的期望值?
假设,测试套件对特定方法调用有默认期望,这是大多数测试用例想要的:
class MyClass {
public:
virtual int foo() = 0;
};
class MyMock {
public:
MOCK_METHOD0(foo, int());
};
class MyTest: public Test {
protected:
void SetUp() {
EXPECT_CALL(m_mock, foo()).WillOnce(Return(1));
}
MyMock m_mock;
};
TEST_F(MyTest, myTestCaseA) {
EXPECT_EQ(1, m_mock.foo());
}
这工作正常。然而,一些测试用例有不同的期望。如果我添加一个新的期望,如下所示,它不起作用。
TEST_F(MyTest, myTestCaseB) {
EXPECT_CALL(m_mock, foo()).WillOnce(Return(2));
EXPECT_EQ(2, m_mock.foo());
};
我收到这条消息:
[ RUN ] MyTest.myTestCaseB
/home/.../MyTest.cpp:94: Failure
Actual function call count doesn't match EXPECT_CALL(m_mock, foo())...
Expected: to be called once
Actual: never called - unsatisfied and active
[ FAILED ] MyTest.myTestCaseB (0 ms)
我明白我为什么会收到这个。问题是如果测试用例指定了自己的期望,如何取消默认期望? GMock 是否允许它或我可以使用哪些方法来实现预期的行为?
不,没有办法清除任意期望。您可以使用 VerifyAndClearExpectations
清除 所有 ,这可能比您想要的要多。我可以想到几种避免该问题的替代方案:
您可以通过简单地提前调用一次m_mock.foo()
来解决您的问题,从而满足最初的期望。
TEST_F(MyTest, myTestCaseB) {
EXPECT_CALL(m_mock, foo()).WillOnce(Return(2));
(void)m_mock.foo();
EXPECT_EQ(2, m_mock.foo());
}
另一种选择是改变期望值使其成为 return 变量的值,然后在测试主体之前更新变量,如食谱中所述 Returning Live Values from Mock Methods。例如:
void SetUp() {
m_foo_value = 1;
EXPECT_CALL(m_mock, foo()).WillOnce(Return(ByRef(m_foo_value)));
}
TEST_F(MyTest, myTestCaseB) {
m_foo_value = 2;
EXPECT_EQ(2, m_mock.foo());
}
另一种方法是分别指定 return 值和计数。
void SetUp() {
ON_CALL(m_mock, foo()).WillByDefault(Return(1));
EXPECT_CALL(m_mock, foo()).Times(1);
}
那么,你只需要为特殊测试指定一个新的return值:
TEST_F(MyTest, myTestCaseB) {
ON_CALL(m_mock, foo()).WillByDefault(Return(2));
EXPECT_EQ(2, m_mock.foo());
}
在GMock中,是否可以替换之前设置的期望值?
假设,测试套件对特定方法调用有默认期望,这是大多数测试用例想要的:
class MyClass {
public:
virtual int foo() = 0;
};
class MyMock {
public:
MOCK_METHOD0(foo, int());
};
class MyTest: public Test {
protected:
void SetUp() {
EXPECT_CALL(m_mock, foo()).WillOnce(Return(1));
}
MyMock m_mock;
};
TEST_F(MyTest, myTestCaseA) {
EXPECT_EQ(1, m_mock.foo());
}
这工作正常。然而,一些测试用例有不同的期望。如果我添加一个新的期望,如下所示,它不起作用。
TEST_F(MyTest, myTestCaseB) {
EXPECT_CALL(m_mock, foo()).WillOnce(Return(2));
EXPECT_EQ(2, m_mock.foo());
};
我收到这条消息:
[ RUN ] MyTest.myTestCaseB
/home/.../MyTest.cpp:94: Failure
Actual function call count doesn't match EXPECT_CALL(m_mock, foo())...
Expected: to be called once
Actual: never called - unsatisfied and active
[ FAILED ] MyTest.myTestCaseB (0 ms)
我明白我为什么会收到这个。问题是如果测试用例指定了自己的期望,如何取消默认期望? GMock 是否允许它或我可以使用哪些方法来实现预期的行为?
不,没有办法清除任意期望。您可以使用 VerifyAndClearExpectations
清除 所有 ,这可能比您想要的要多。我可以想到几种避免该问题的替代方案:
您可以通过简单地提前调用一次
m_mock.foo()
来解决您的问题,从而满足最初的期望。TEST_F(MyTest, myTestCaseB) { EXPECT_CALL(m_mock, foo()).WillOnce(Return(2)); (void)m_mock.foo(); EXPECT_EQ(2, m_mock.foo()); }
另一种选择是改变期望值使其成为 return 变量的值,然后在测试主体之前更新变量,如食谱中所述 Returning Live Values from Mock Methods。例如:
void SetUp() { m_foo_value = 1; EXPECT_CALL(m_mock, foo()).WillOnce(Return(ByRef(m_foo_value))); } TEST_F(MyTest, myTestCaseB) { m_foo_value = 2; EXPECT_EQ(2, m_mock.foo()); }
另一种方法是分别指定 return 值和计数。
void SetUp() { ON_CALL(m_mock, foo()).WillByDefault(Return(1)); EXPECT_CALL(m_mock, foo()).Times(1); }
那么,你只需要为特殊测试指定一个新的return值:
TEST_F(MyTest, myTestCaseB) { ON_CALL(m_mock, foo()).WillByDefault(Return(2)); EXPECT_EQ(2, m_mock.foo()); }