我已经接管了一些BOOST TEST代码,该代码已被编写为用于测试媒体文件的静态测试设置。但是,要求是使测试设置动态,因为要测试的媒体文件的数量可能随时间变化,即一天可能有3个文件,第二天可能有15个文件需要测试。
当前的设置使用了多个BOOST_AUTO_TEST_SUITE来构建静态树结构,我的问题是,当我到测试树的那一点,我想在测试树中按顺序添加2个test_suite的TestSuiteD1和TestSuiteD2为了运行我的动态测试,我只能在该位置添加2个test_case,因此无法在此树元素下添加更多test_case(TestCase1 - TestCase3)。我一直在互联网上搜索:: make_test_suite版本,下面是:: make_test_case,但没有运气:
static boost :: unit_test :: ut_detail :: auto_test_unit_registrar TestSuiteD1_registrar0 (boost :: unit_test :: make_test_case(& fTestSuiteD1_invoker,“TestSuiteD1”), boost :: unit_test :: ut_detail :: auto_tc_exp_fail :: instance() - > value());
我在下面添加了一些示例代码,以显示我想要做的事情,并在可以添加test_suite而不是test_case时获得一些反馈:
class MyTestSuite : public TestFixture1 {
public:
static void TestCase1() { //Some test };
static void TestCase2() { //Some test };
static void TestCase3() { //Some test };
test_suite* TestThis(string a, string b, string d)
test_suite* tsE = BOOST_TEST_SUITE( "TestSuiteE" );
tsE->add( BOOST_TEST_CASE( &TestCase1 ) );
tsE->add( BOOST_TEST_CASE( &TestCase2 ) );
tsE->add( BOOST_TEST_CASE( &TestCase3 ) );
};
};
BOOST_AUTO_TEST_SUITE( TestSuiteA );
BOOST_FIXTURE_TEST_SUITE( TestSuiteB , TestFixture1 );
BOOST_AUTO_TEST_SUITE( TestSuiteC );
BOOST_AUTO_TEST_SUITE( TestSuiteD );
static test_unit* TestSuiteD1_invoker (void) {
MyTestSuite MyTS;
MyTS.TestThis("a" , "b" , "D1" );
return 0;
}
struct TestSuiteD1_id {};
static boost::unit_test::ut_detail::auto_test_unit_registrar
TestSuiteD1_registrar0 ( boost::unit_test
::make_test_case(&fTestSuiteD1_invoker , "TestSuiteD1" ),
boost::unit_test::ut_detail::auto_tc_exp_fail<TestSuiteD1_id
>::instance()->value() );
static test_unit* TestSuiteD2_invoker (void) {
MyTestSuite MyTS;
MyTS.TestThis("a" , "b" , "D2" );
return 0;
}
struct TestSuiteD2_id {};
static boost::unit_test::ut_detail::auto_test_unit_registrar TestSuiteD2_registrar0
( boost::unit_test::make_test_case(&fTestSuiteD2_invoker , "TestSuiteD2" ),
boost::unit_test::ut_detail::auto_tc_exp_fail<TestSuiteD2_id
>::instance()->value() );
BOOST_AUTO_TEST_SUITE_END()
BOOST_AUTO_TEST_SUITE_END()
BOOST_AUTO_TEST_SUITE_END()
BOOST_AUTO_TEST_SUITE_END()
答案 0 :(得分:0)
我不确定固定装置是否正确。看看BOOST_TEST_CASE_TEMPLATE
BOOST_TEST_CASE_TEMPLATE_FUNCTION( my_test, T )
{
BOOST_CHECK_EQUAL( sizeof(T), 4 );
}
test_suite*
init_unit_test_suite( int argc, char* argv[] )
{
typedef boost::mpl::list<int,long,unsigned char> test_types;
framework::master_test_suite().
add( BOOST_TEST_CASE_TEMPLATE( my_test, test_types ) );
return 0;
}