是否有可能只初始化一次fixture并在多个测试用例中使用它?
Is it possible to initialize the fixture only once and use it in multiple test cases?
是否有可能只初始化一次fixture并在同一测试套件中的多个测试用例中使用它?在下面的例子中,fixture被构造和析构多次:
struct F {
F() : i( 0 ) { BOOST_TEST_MESSAGE( "setup fixture" ); }
~F() { BOOST_TEST_MESSAGE( "teardown fixture" ); }
int i;
};
BOOST_FIXTURE_TEST_SUITE( s, F )
BOOST_AUTO_TEST_CASE( test_case1 )
{
BOOST_CHECK( i == 1 );
}
BOOST_AUTO_TEST_CASE( test_case2 )
{
BOOST_CHECK_EQUAL( i, 0 );
}
BOOST_AUTO_TEST_SUITE_END()
但是我希望fixture在测试套件开始时只构造一次,并在其中的所有测试用例之间共享。这可能吗?析构函数将在退出测试套件后调用。
我正在使用Boost测试框架,但使用其他框架如unittest++没有问题。
每个测试用例都是从测试套件Fixture派生出来的,它在每个测试用例开始时被构造,并在它完成时被销毁(在您的情况中,test_case1
&test_case2
由F
衍生而来。fixture为每个单独的测试用例配置并清理环境。
对于单元测试,这通常是首选的策略——每个测试用例都是独立的,完全是原子的。
在某些场景中(例如集成测试),最好一次获得昂贵的资源,并在所有测试用例中保留它。这可以通过GLOBAL FIXTURE完成,它在测试运行开始时构造,并在测试退出时销毁。
如果任何测试用例需要不同的全局资源设置/配置,那么global FIXTURE就不能使用,您应该重新考虑您的测试策略,以便每个测试用例配置和清理自己的环境。
不幸的是,测试用例不能直接访问全局测试fixture,因此你需要提供一种允许它们访问资源的机制(例如,通过全局变量或单例)。
在下面的示例中,MyFixture
是保存资源的单例。例如
struct MyFixture
{
static MyFixture*& instance() { static MyFixture* s_inst = 0;
return s_inst; }
MyFixture()
{
instance() = this;
x = 10;
BOOST_TEST_MESSAGE( "setup fixture" );
}
~MyFixture()
{
BOOST_TEST_MESSAGE( "teardown fixture" );
}
int x;
};
BOOST_GLOBAL_FIXTURE(MyFixture)
BOOST_AUTO_TEST_CASE(TEST_1)
{
BOOST_CHECK(MyFixture::instance()->x == 10);
MyFixture::instance()->x = 12;
}
BOOST_AUTO_TEST_CASE(TEST_2)
{
BOOST_CHECK(MyFixture::instance()->x == 12);
}
这是可能的,但它要求您将BOOST_AUTO_TEstrongUITE与boost::unit_test::fixture装饰器一起使用,而不是BOOST_FIXTURE_TEstrongUITE。同样值得注意的是,虽然这可以工作,但您将无法访问测试用例中F的成员变量。提示:只需将它们放在结构体之外,而不是像我下面对I所做的那样。在boost文档中查看这里和这里的更多信息。
struct F {
F() { BOOST_TEST_MESSAGE( "setup fixture" ); }
~F() { BOOST_TEST_MESSAGE( "teardown fixture" ); }
};
int i = 0;
BOOST_AUTO_TEST_SUITE( s, *boost::unit_test::fixture<F>())
BOOST_AUTO_TEST_CASE( test_case1 )
{
BOOST_CHECK( i == 1 );
}
BOOST_AUTO_TEST_CASE( test_case2 )
{
BOOST_CHECK_EQUAL( i, 0 );
}
BOOST_AUTO_TEST_SUITE_END()
- 如何使用重载的相等(==)运算符向测试用例添加描述
- 从父数组测试用例构造二叉树失败
- 在Raspbian上编译pybind11测试用例时出现致命错误
- 我遇到了黑客排名中的问题"TWO STRINGS"的三个测试用例的分段错误。原因是什么?
- 某些测试用例未通过
- 如何在多个 Catch2 测试用例中检查相同的条件
- 谷歌启动2018,测试用例中的整数错误
- 用于查找连续子数组的最大总和的代码使测试用例失败
- 查找不适用于 c++ 中特定测试用例的最长子字符串
- 测试用例状态为失败,但返回的值为 true
- kill syscommand 在 Catch2 测试用例中失败
- 大型测试用例中C++ dfs 问题中的小错误
- 为什么在输入的第一行输入测试用例数量后得到垃圾值?
- C++ Catch 是否有类似 NUnit 的测试用例的东西,具有多个参数/输入选项
- 如何修复此代码对几个测试用例的错误答案?
- 所有测试用例都将小数点转换为二进制数
- C++回文检查解决方案被一个测试用例跳闸
- 测试用例大小为 10 的向量失败
- 是否有可能只初始化一次fixture并在多个测试用例中使用它?
- 在手动定义的套件树中提升测试用例和套件fixture