当gmock看到它不希望看到的方法调用时,它会写一个如下所示的警告:
GMOCK WARNING:
Uninteresting mock function call - returning directly.
Function call: Constructor()
Stack trace:
当单元测试中的每个模拟对象都有一个名为"Constructor“的方法时,这并不是很有帮助,因为找出创建这个消息的对象并缺少一个EXPECT_CALL并不总是那么容易。
在这样的警告中,有一种方法可以告诉gmock也写类名或模拟对象的名称吗?
发布于 2014-11-11 12:40:42
这真的很不方便。
看一看无趣的调用函数报告的来源,似乎不可能修改这种行为。固定的enum给出了对方法调用的可能反应,所以这里的扩展看起来不像是一个选项。您可以将Google侦听器附加到测试套件中,但我认为到达测试套件的信息同样有限。
在我看来,如果这对我来说真的很重要的话,我会修改Google源代码中提到的行,并将对象地址(它是最近的东西和标识符)与MockObject()
放在一起。类似于:
// Writes a message that the call is uninteresting (i.e. neither
// explicitly expected nor explicitly unexpected) to the given
// ostream.
virtual void UntypedDescribeUninterestingCall(
const void* untyped_args,
::std::ostream* os) const
GTEST_LOCK_EXCLUDED_(g_gmock_mutex) {
const ArgumentTuple& args =
*static_cast<const ArgumentTuple*>(untyped_args);
*os << "Uninteresting mock function call - ";
DescribeDefaultActionTo(args, os);
*os << " Function call: " << Name();
*os << "Mock object address: " << MockObject();
UniversalPrint(args, os);
}
这并不像看上去那么疯狂;Google是一个测试库,而不是生产,所以定制(受控)修改在那里并没有那么有害。而且实际上是Google确实推荐为每个不同的项目使用Google的自定义编译。
或者你可以把补丁发给他们,看看他们是否喜欢:)
发布于 2014-11-12 23:52:38
我们已经对这个问题采取了另一种解决办法。我们有自己的Eclipse插件,它从选定的头文件生成模拟对象文件。现在,我们将插件更改为生成一个包含类名的模拟名称,例如:
MOCK_METHOD0(Timer_Constructor, void());
这将导致警告。
Uninteresting mock function call - returning directly.
Function call: Timer_Constructor()
https://stackoverflow.com/questions/26273770
复制相似问题