您可以使用BOOST_FIXTURE_TEST_CASE_TEMPLATE
实例化多个测试:
#define BOOST_TEST_DYN_LINK
#define BOOST_TEST_MODULE TestModuleName
#include <boost/test/unit_test.hpp>
#include <boost/mpl/vector.hpp>
struct Fixture1 { int i; Fixture1() : i(1) {} };
struct Fixture2 { int i; Fixture2() : i(2) {} };
struct Fixture3 { int i; Fixture3() : i(3) {} };
typedef boost::mpl::vector<Fixture1, Fixture2, Fixture3> Fixtures;
BOOST_FIXTURE_TEST_CASE_TEMPLATE(Test, T, Fixtures, T){
std::cout << T::i << "\n";
}
将打印
1
2
3
mpl::vector
此代码为“Fixtures”中的每种类型实例化一个自己的测试用例。每个夹具类型将作为T
(的第二个参数BOOST_FIXTURE_TEST_CASE_TEMPLATE
)传入,T
并将用作测试用例的夹具(最后一个参数)。
警告
由于测试用例(类)的模板性质,您需要预先T::
访问夹具成员以指示它们是(模板参数)依赖名称。
改进
因为BOOST_FIXTURE_TEST_CASE_TEMPLATE
它是如此通用,所以可能想要定义一个方便的“快捷方式”,它更明确地说明正在做什么:
#define MULTI_FIXTURE_TEST_CASE(NAME, TPARAM, ...) \
typedef boost::mpl::vector<__VA_ARGS__> NAME##_fixtures; \
BOOST_FIXTURE_TEST_CASE_TEMPLATE(NAME, TPARAM, NAME##_fixtures, TPARAM)
MULTI_FIXTURE_TEST_CASE(Test, T, Fixture1, Fixture2, Fixture3){
std::cout << T::i << "\n";
}
如您所见,它在某种程度上隐藏了mpl::vector
. 我认为最好在它自己的头文件中定义这个宏,这也#include <boost/mpl/vector.hpp>
可以避免丢失依赖项。固定装置列表名称是测试用例的名称加上“_fixtures”,因此希望它不会与现有名称冲突并且有点意义。