草庐IT

ALLOW_MOCK_LOCATION

全部标签

c++ - 谷歌模拟 : Is it ok to use global mock objects?

在所有关于gmock的文档中,我总是发现要在测试中实例化模拟对象,就像这样:TEST(Bim,Bam){MyMockClassmyMockObj;EXPECT_CALL(MyMockObj,foo(_));...}因此,对象在每次测试时都会被创建和销毁。我相信为每个测试夹具创建和销毁对象也完全没问题。但我想知道是否也可以拥有模拟对象的文件全局实例,就像这样:MyMockClassmyMockObj;TEST(Bim,Bam){EXPECT_CALL(MyMockObj,foo(_))...}我试过了,到目前为止我完全没有问题,一切似乎都很好。但也许我应该知道什么?只是因为我偶然发现了t

c++ - NiceMock 一个将另一个 Mock 作为构造函数参数的 Mock

我想将Mock与NiceMock结合使用。Mock有一个构造函数,该构造函数将另一个Mock作为参数。这是我拥有的有效代码的一个小示例classClassA{ClassA(){}};templateclassClassB>{ClassB(ClassA&a){}//constructor,nodefaultconstructorforthisclass};classClassC{ClassC(){}};classMyTest:publicTest{MockClassAa;MockClassB*b=NULL;SetUp(){b=newMockClassB(a);}...};这很好用,但是如

c++ - 使用 : Construction of objects at predetermined location in C++

在C++中在预定位置构造对象有什么用?以下代码说明了在预定位置的构造-void*address=(void*)0xBAADCAFE;MyClass*ptr=new(address)MyClass(/*argumentstoconstructor*/);这最终会在预定的“地址”处创建MyClass的对象。(假设address指向的存储足够大以容纳MyClass对象)。我想知道在内存中的这些预定位置创建对象的用途。 最佳答案 placementnew有用的一个场景是:您可以一次预分配大缓冲区,然后使用许多放置新运算符。这会给你更好的性能

c++ - Google Mock 函数改变参数值

我试图通过写入作为参数传递给函数的引用之一来模拟一些返回信息的代码。是否有一种模拟此行为的好方法,以便我可以让测试代码确定写入该变量的值? 最佳答案 我做了一些研究,结果证明GMock有几个不错的选择。来自GoogleMockCheatSheetSetArgReferee(value)SetArgPointee(value)“为第N个(从0开始)参数引用的变量赋值”和“为第N个(从0开始)参数指向的变量赋值”。 关于c++-GoogleMock函数改变参数值,我们在StackOverfl

c++ - 为什么 Google Test/Mock 通过 std::unique_ptr 显示泄露的模拟对象错误?

假设有一个Bar对象,它使用了一个Foo对象。所有权是独占的,因此Bar在其构造函数中将Foo作为std::unique_ptr获取。我想用Google测试框架测试Bar,所以我编写了以下代码:usingnamespacetesting;classFoo{public:virtualintF()=0;};classBar{public:Bar(std::unique_ptr&&foo):m_foo(std::move(foo)){}intB(){returnm_foo->F();}private:std::unique_ptrm_foo;};classMockFoo:publicFoo

c++ - g++ 在多个文件上比使用 Google mock 的单一文件慢得多

我遇到了一个似乎与g++相关的问题。基本上,当一个程序被拆分成多个文件而不是一个单一的整体文件时,g++需要花费更多的时间来编译它。事实上,如果将单个文件组合在一起并进行编译,它运行起来比在g++命令行上列出单个文件要快得多。比如9个文件,编译需要1分39秒;当我把它们放在一起时,编译只需要13秒。我试过使用strace但它只是卡在cc1plus中;当我使用-f选项时,我仍然无法找出导致问题的原因。我已经隔离了问题。这是重现它的方法。我写了一个非常简单的程序,像这样:voidfunc_01(inti){intj;volatileint*jp;jp=&j;for(;i;i--)++*jp

c++ - Google Mock - 如何命名模拟函数?

我刚刚开始使用GoogleMock。ForDummies相当容易理解。但是,我不明白为什么这个例子有classMockTurtle:publicTurtle{public:...MOCK_METHOD0(PenUp,void());MOCK_METHOD0(PenDown,void());MOCK_METHOD1(Forward,void(intdistance));MOCK_METHOD1(Turn,void(intdegrees));MOCK_METHOD2(GoTo,void(intx,inty));MOCK_CONST_METHOD0(GetX,int());MOCK_CONS

c++ - 编译时的 std::experimental::source_location

std::experimental::source_location可能会在某个时候添加到C++标准中。我想知道是否有可能将位置信息获取到编译时领域。本质上,我想要一个在从不同源位置调用时返回不同类型的函数。像这样的东西,虽然它没有编译因为location对象不是constexpr因为它是一个函数参数:#includeusingnamespacestd::experimental;constexprautoline(constsource_location&location=source_location::current()){returnstd::integral_constant

开源一个超好用的接口Mock工具——Msw-Tools

作为一名前端开发,是不是总有这样的体验:基础功能逻辑和页面UI开发很快速,本来可以提前完成,但是接口数据联调很费劲,耗时又耗力,有时为了保证进度还不得不加加班。为了摆脱这种痛苦,经过一周的努力,从零开发了一个灵活无依赖,且集成简单的数据接口Mock工具——Msw-Tools,已开源到NPM,希望对前端小伙伴有所帮助。一、前言Msw-Tools(MockServiceWorkerTools)是一个基于Msw.js和Svelte构建的数据Mock工具,用于前后端接口数据联调,方便开发者在不同数据、不同场景下进行功能测试。Msw-Tools能做什么?Msw-Tools能做什么?Msw-Tools能做

c++ - 具有负大小的 Google Mock testing::internal::ReturnAction<R> 数组

我有测试代码可以做类似的事情EXPECT_CALL(mock,getSomeString()).WillOnce(Return(&testString));其中getSomeString()通过引用返回:std:string&getSomeString();得到../../../../src/test/unit/gmock/gmock-actions.h:Inmemberfunction‘testing::internal::ReturnAction::operatortesting::Action()const[withF=conststd::string&(),R=std::bas