草庐IT

Test-build-desktop

全部标签

c++ - VS2013 错误 : LNK2019 When trying to build ZeroMQ server

我正在尝试在VisualStudio2013上用C++构建这个简单的ZeroMQ服务器。#include"stdafx.h"#include"zmq.hpp"#include#include#includeusingnamespacestd;int_tmain(intargc,_TCHAR*argv[]){//Preparecontextandsocketzmq::context_tctx(1);zmq::socket_tsckt(ctx,ZMQ_REP);sckt.bind("tcp://*:5555");while(true){zmq::message_trequest;//Wai

c++ - 使用 Boost::Test 测试 DLL?

我正在用C++开发DLL,并希望使用Boost测试库对该DLL执行单元测试。我仔细阅读了Boost测试手册,但由于我是新手,所以我有以下问题:我应该在开发DLL的同一个VC项目中添加测试类吗?理想情况下我想这样做,但我很困惑DLL没有main()并且另一方面,Boost测试需要它自己的main()来执行.那么在这种情况下,Boost测试输出到哪里去了?(事实上​​,我实际上实现了这个并且没有看到任何输出:(我几乎花了两天时间找出问题,但没有成功)问候,詹姆。 最佳答案 您有3种方法可以做到这一点:您绝对可以按照其他回复的建议将您的库

vitest 单元测试配合@vue/test-utils 之 axios 篇

whatisvitest&VueTestUtils&axiosvitest是由vite提供支持的极速单元测试框架,VueTestUtils是Vue.js的官方测试实用程序库,Axios是一个基于promise的网络请求库,以上均为各自官网对其的描述demo项目中使用axios是非常常见的,所以我们可以对他做一个单元测试,在test-utils的文档中提到除了jest.mock()还可以使用axios-mock-adapter,其实我们可以使用vitest的vi.mock()来完成,但是翻看了axios-mock-adapter库的示例后,明白了官方的推荐并不是不无道理,所以此篇demo引入该库

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++ - Xcode C++ : Build in Debug but not Release

我正在使用Xcode6、c++进行编码。我可以在调试中构建和运行我的程序,但我无法以某种方式在Release模式下编译。我看到的错误是:AppleLLVM6.0错误无法读取配置文件:没有这样的文件或目录我真的不知道这是什么意思...(在将main.cpp文件缩减为通常的“HelloWorld”程序后我仍然明白这一点)我已经按照建议尝试了XcodebuildsonDebugbutnotonRelease清理我的项目,关闭它,关闭Xcode重新启动并重建,甚至删除派生数据,但我仍然遇到同样的问题。有人知道如何解决这个问题吗?非常感谢T 最佳答案

c++ - Coverity 为使用 'cov-build' 的构建定义了哪些预处理器符号?

我们使用Coverity的ScanBuild为免费和开源项目提供服务。我正在研究关于受污染参数(TAINTED_SCALAR)的两个Coverity调查结果。污点是误报,因此我尝试使用Coverity的__coverity_tainted_data_sanitize__检测代码以清除问题。我想保护需要使用__coverity_tainted_data_sanitize__的代码,因为该函数仅用于使用Coverity的cov-build的分析构建。工具。也就是说,我想做类似的事情:voidFoo(std::istream&is,...){std::stringname;is>>name;

c++ - 确定 C++ 应用程序是否作为 UWP 应用程序在 Desktop Bridge (Project Centennial) 中运行

我已经将一个C++/Win32应用程序打包为appx,它运行正常。但是,由于某些路径不可用,我必须以某种方式确定应用程序是否作为打包的UWP应用程序运行并进行调整。是否可以通过简单的运行时检查来确定您是否作为打包的UWP应用程序运行? 最佳答案 IsthereasimpleruntimecheckonecandotodetermineifyouarerunningasapackagedUWPapplication?是的,您可以通过GetPackageFamilyNamefunction检查包裹身份未打包返回值APPMODEL_ERR

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