问题描述
Database Rider中有什么方法可以减少 @DataSet 配置属性的重复?
例如,假设我们有:
@DataSet(value = "yml/test1.yml",cleanAfter = true,skipCleaningFor = {"zone_code","product_code","product_type","user_type"})
public void test1() {
//...
}
@DataSet(value = "yml/test2.yml","user_type"})
public void test2() {
//...
}
在这里您可以看到 cleanAfter 和 skipCleaningFor 重复。这只是一个例子。 skipCleaningFor的列表甚至可以更长。使用相同的已跳过表列表进行数千个测试是一场噩梦。想象我们需要在数千个地方更改此列表。
将列表提取到某个static final
变量中不是一种选择,因为注释的参数只能是真正的内联常量(您会得到编译错误)。
Meta datasets是减少重复的方法之一,但它们包含ALL属性,并且无法覆盖某些属性(例如本例中的 value )
Merge datasets看起来很有希望,但不确定...
解决方法
似乎我弄清楚了如何使用合并数据集来做到这一点。 首先,我们需要使用skipCleaningFor的配置对所有测试进行一些BaseTest:
@DataSet(value = "yml/empty.yml",skipCleaningFor = {"zone_code","product_code","product_type","user_type"})
class BaseTest
其中empty.yml只是一些空数据集,以避免测试执行期间出错。 然后,在测试类中,我们将
@DbUnit(mergeDataSets = true)
@DBRider
class MyTest extends BaseTest {
@DataSet(value = "yml/test1.yml",cleanAfter = true)
public void test1() {
//...
}
@DataSet(value = "yml/test2.yml",cleanAfter = true)
public void test2() {
//...
}
就是这样-配置不再重复!