这几行作为C中的小型测试框架做了什么?

前端之家收集整理的这篇文章主要介绍了这几行作为C中的小型测试框架做了什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
嗨,我正在阅读std :: optional here的实现,我在其单元测试文件中找到以下行.
struct caller {
    template <class T> caller(T fun) { fun(); }
};
# define CAT2(X,Y) X ## Y
# define CAT(X,Y) CAT2(X,Y)
# define TEST(NAME) caller CAT(__VAR,__LINE__) = []

我真的不明白这些线是做什么的.调用者似乎是一个调用函数的模板,但它如何用作调用者CAT …?
X ## Y在这里是什么意思?稍后在文件中,用户使用TEST定义单元测试,但它们没有出现在任何可执行代码中(我的意思是它们至少不在main函数调用),所以我甚至不确定编译的二进制文件是否实际运行了测试.你能解释一下这里发生了什么吗?谢谢!

编辑:非常确定在运行二进制文件时执行测试,但是如何实现?

解决方法

您可以在预处理后查看输出(-E表示gcc)…

这是我添加宏的用法代码

struct caller {
    template <class T> caller(T fun) { fun(); }
};
# define CAT2(X,__LINE__) = []

TEST(disengaged_ctor) { foo(); };

after preprocessing the last line turns to:

caller __VAR10 = []{ foo(); };

我对__VAR和未使用的NAME *感到有些困惑.但是,[] {foo();用于创建调用者的lambda是在调用者构造函数调用的.

* =我想这个想法如下:假设你收到一条错误信息,说__VAR10中有错误,然后在第10行找到TEST(disengaged_ctor),即.失败测试的名称.

猜你在找的C&C++相关文章