草庐IT

olio_msg_send_test_messages

全部标签

c++ - boost::unit_test 案例失败,因为子进程以非零值退出

我有以下代码:boolf(){command="mkdir-p/\/\/";result=aSystemCall(command);if(result==...}BOOST_AUTO_TEST_CASE(BadDir){BOOST_CHECK_EQUAL(false,f());}如果我在命令行中执行command,我会收到权限被拒绝的错误。我知道这一点。这正是我想要测试的。aSystemCall将命令作为子进程执行。当child退出时出现此命令的非零错误,aSystemCall返回一个错误。它不会抛出。如果我在命令行中运行BadDir测试用例,aSystemCall之后的代码永远不会执

c++ - 如何在 Parasoft C++test 中将函数标记为不返回?

我们有一个die函数输出错误信息并退出,例如:voiddie(constchar*msg){fprintf(stderr,"Error:%s\n",msg);exit(1);}我们使用ParasoftC++test静态分析我们的代码,但它没有意识到die是一个非返回函数。所以当它看到如下代码时:voidfoo(Bar*bar){if(!bar){die("barisNULL");}Barbar2=*bar;}它警告*bar可能正在取消引用空指针,即使bar为NULL会阻止该行执行。有没有办法以Parasoft可以识别的方式将die标记为不返回?编辑:我需要在GCC和VS2003中都能工

c++ - 如何预期 static_assert 失败并使用 Boost.Test 框架处理它?

如果我有一个接受模板参数的方法,该模板参数应该可转换为base_of或与返回类型相同的类型,我应该怎么做?例如,考虑这个方法:templateclassIFoo{public:templateT*as(){static_assert(std::is_same::value||std::is_convertible::value||std::is_base_of::value,"IFoo::as()requiresServiceTtobeabaseofT");...}};现在,我想对其进行BOOST_CHECK!classA{};classB{};BOOST_AUTO_TEST_CASE

c++ - 谷歌模拟 : How to configure custom message to explain match failure

如果匹配失败,Googlemock会打印如下消息:test.cpp:112:EXPECT_CALL(mock_obj,foo(MyMatcher(bar)))...Expectedarg#0:isequalto[1,2;3,4]Actual:{1}Expected:tobecalledonceActual:nevercalled-unsatisfiedandactive使用自定义匹配器MyMatcher我可以定义一个描述字符串,用于在匹配失败时生成失败消息。但它只定义了消息的Expectedarg#0部分。有什么方法可以自定义Actual的打印方式吗?在我的例子中,我不能为bar的类重

c++ - 如何在 MPI_Send 中发送一个集合对象

我搜索发送一个set对象,我发现最接近的是vector(它不同,不适用于set)。如何在MPI_Send中发送一个集合对象?(不使用boost库)任何人都可以举一个简单的例子吗? 最佳答案 在MPI中,无论是将复杂的数据结构写入文件还是通过网络,问题都是一样的;您必须将数据提取到“普通旧数据”(POD)中,保存它,然后输出它,同样能够将保存的数据解压缩为相同类型的结构。通常,这称为序列化。对于任何给定的结构,您始终可以编写自己的例程来执行此操作,但在C++中,Boost中有一个名为BoostSerializationLibrary的

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++ - 设置 Google Test 时找不到 -lgtest

我正在使用GoogleTestforC++并尝试在我的Linux机器上进行设置。我的make文件包含以下代码:CC=g++CFLAGS=-I$(GOOGLETESTDIR)/include-L$(GOOGLETESTDIR)/lib-lgtest-lpthread-WallDEPS=fib.hOBJS=fib.omain.oall:|r6clean:-rm-fr6$(OBJS)%.o:%.cpp$(DEPS)$(CC)-c-o$@$运行make时出现错误:/usr/bin/ld:cannotfind-lgtest我该如何解决这个问题?我对这种测试很陌生,对Linux也很陌生,所以我真的

c++ - 为什么 istream_iterator<string>(ifstream ("test.txt")) 会导致错误?

我尝试编写代码从名为“test.txt”的文件中读取字符串并将字符串写入标准输出。下面的代码运行良好:intmain(){usingnamespacestd;ifstreamfile("test.txt");copy(istream_iterator(file),istream_iterator(),ostream_iterator(cout,""));}但是,通过此修改,代码不再编译:intmain(){usingnamespacestd;copy(istream_iterator(ifstream("test.txt")),//(),ostream_iterator(cout,""

c++ - 为什么 virtual void test()=00 有效但 virtual void test()=+0 和 virtual void test()=-0 无效?

我搜索了一些关于虚函数声明的帖子,相信=0在virtualvoidtest()=0;是固定句法所以virtualvoidtest()=NULL;virtualvoidtest()=false;virtualvoidtest()=1-1;virtualvoidtest()=0.0;和其他声明应该是无效的。但是我发现了virtualvoidtest()=00;virtualvoidtest()=000;virtualvoidtest()=0000;还能编译,为什么?还有,我觉得整数+0和-0其实和0一样(不知道对不对),就像00其实就是0一样,为什么virtualvoidtest()=+0

c++ - gtest,对 'testing::Test::~Test()' 的 undefined reference ,testing::Test::Test()

我使用apt-getinstalllibgtest-dev安装了gtest我正在尝试检查它是否有效。所以我在eclipse中编写了简单的测试代码。但是有错误,undefinedreferenceto'testing::Test::~Test()'undefinedreferenceto'testing::Test::Test()'相反,如果我将ATest类的继承更改为protected,错误就会消失,但是出现其他错误testing::Testisinaccessiblebaseof'ATest_AAA_Test'怎么了?#include#includeclassA{public:int