草庐IT

constant_test

全部标签

c++ - 如何告诉 Boost.Test 在第一个失败的测试用例上停止?

我在几个测试套件中订购了许多Boost测试用例。有些测试用例有一个,有些不止一个检查。然而,当执行所有测试时,它们都会被执行——不管有多少失败或通过。我知道,我可以通过使用BOOST_REQUIRE而不是BOOST_CHECK来停止执行一个测试用例并进行多次检查。但这不是我想要的。在第一个测试用例失败后,如何告诉Boost停止整个执行?与运行时解决方案(即运行时参数)相比,我更喜欢编译解决方案(例如,使用全局夹具实现)。 最佳答案 BOOST_REQUIRE将停止测试套件中的当前测试用例,但继续进行其他测试。当您要求“编译解决方案”

c++ - "constant"复杂度的真正含义是什么?时间?复制/移动的数量?

就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter为指导。9年前关闭。我可以想到C++中的三个操作,它们在某种意义上可以被描述为具有“恒定”的复杂性。我已经看到一些关于这意味着什么的争论(*),在我看来,我们可以说“所有这些操作都是恒定的,但有些比其他操作更恒定”:-)(编辑2:如果您已经认为自己知道答案,请在过早进入之前阅读此问题的一些辩论:Whatdatastructure,exactly,aredequesinC++?很

c++ - extern const char* const SOME_CONSTANT 给我链接器错误

我想像这样在API中提供一个字符串常量:externconstchar*constSOME_CONSTANT;但是如果我在我的静态库源文件中将它定义为constchar*constSOME_CONSTANT="test";当链接到该库并使用SOME_CONSTANT时,我遇到链接器错误:Error1errorLNK2001:unresolvedexternalsymbol"charconst*constSOME_CONSTANT"(?SOME_CONSTANT@@3QBDB)从externconstchar*const声明和定义中删除指针常量(第二个const关键字)使其工作。如何使用

test_sizeof

test_sizeof//结论://sizeof(arrU8)得到的大小是u8类型数组的**定义大小**,在初始化的时候用//strlen(arrU8)得到的大小是u8类型数组的**实际大小**,在复制的时候用//sizeof((char*)arrU8),把一个u8*转成char*,在32位机器上结果是4,64位机器上是8//sizeof((char*)arrU8)是输出一个指针的大小//要打印u8类型的数组,直接arrU8就可以了,不用加(char*);#include#include#includetypedefunsignedcharu8;intmain(void){ u8arrU8[1

c++ - <错误 C2059 : syntax error : 'constant' > when compiling with const int

编译以下代码时出现以下错误:3>c:\hedge\hedge\hedge\AisTarget.h(22):errorC2059:syntaxerror:'constant'3>c:\hedge\hedge\hedge\AisTarget.h(22):errorC2238:unexpectedtoken(s)preceding';'#if!defined(AisTarget_h)#defineAisTarget_h#include"GeneralAviationItems.h"#includenamespaceHEDGE{usingnamespaceGeneralAviation;cla

c++ - Boost.Test 测试静态库

我正在使用Boost.Test进行单元测试。因为一些原因,我想在不同的静态库上编写单元测试用例。问题是当我这样做时,自动注册器不工作。例如,如果我有类似的东西://foo_tests.cpp#defineBOOST_TEST_MODULE"Foo"#includeBOOST_AUTO_TEST_CASE(Bar){BOOST_CHECK(false);}//usedtogeneratelibFooTests.a//main.cpp#defineBOOST_TEST_DYN_LINK#defineBOOST_TEST_MAIN#include//usedtogeneratemain.o然

c++ - 三元运算符中的 integral_constants

MSVC和clang/gcc对于是否可以在三元运算符中使用两个不同的整型常量(以及它们是否具有common_type)存在分歧:#includeintmain(){returnfalse?std::integral_constant():std::integral_constant();}上面的代码片段在clang和gcc中编译得很好,但在MSVC中却不行。根据标准,正确的行为是什么?如果是clang/gcc行为,那么用于推断这两种不同类型的公共(public)类型的转换序列是什么? 最佳答案 tldr;代码格式正确。条件表达式的类

c++ - 帮助开始使用 Boost.Test

我正在尝试开始单元测试。我正在查看一些C++框架并想尝试Boost.Test。文档看起来非常详尽,而且有点让人不知所措,尤其是对单元测试新手来说。所以这是我想要的情况:假设我有2个类,Foo和Bar。我想为Foo编写一套测试,为Bar编写一套测试,最好是在不同的文件中。我只想在使用命令行参数运行程序时运行测试。所以我的main()应该是这样的:intmain(intargc,constchar*argv[]){if(argc==1&&strcmp(argv[0],"-test")==0)run_all_tests();elsereturnprogram_main(argc,argv);

c++ - Visual Studio 和 Boost::Test

我开始使用Boost::Test驱动的开发(在C++中),并且我正在用单元测试改造我的一个旧项目。我的问题是——在哪里添加单元测试代码?根据Boost::Test的文档,测试本身的语法看起来非常简单,但我对如何告诉编译器用我的单元测试生成可执行文件感到困惑。理想情况下,我会使用预编译的header和boost::test库的仅header版本。我是否只为测试创建一个新项目并将所有现有源文件添加到其中?比利3 最佳答案 他们将Boost单元测试添加到现有解决方案的方式是创建新项目并将测试代码放入这些项目中。您无需担心创建main()函

c++ - 是否可以在 boost::test 上使用自动注册的 BOOST_PARAM_TEST_CASE?

是否可以以任何方式将BOOST_AUTO_TEST_CASE和BOOST_AUTO_TEST_CASE_TEMPLATE宏与BOOST_PARAM_TEST_CASE混合使用?我什至对实现这一目标的非常困惑的方式很感兴趣。必须手动构建所有测试用例似乎非常乏味。但是BOOST_PARAM_TEST_CASE机制非常有用,但只有在您有测试初始化​​函数时才有效,这反过来又要求您必须使用手动测试用例构造。是否有关于如何自己连接到自动化系统的文档,以便您可以提供自己的自动注册测试?我现在正在使用boost1.46。 最佳答案 我为此写了自己