前言
在实际测试场景中,我们经常需要混合不同的类型生成器,因此我们需要组合数据生成器。
接下来我们介绍一款混合数据生成器——Gen.these。
一、混合生成器数据源
Gen.these方法从一组数据中创建一个生成器。这些数据可以是以下几类:
-
java.util.Iterable
-
java.util.Collection
-
java.lang.Class
-
Or a variable arguments parameter
当生成器生成值时,它将按顺序从声明的数据源获取每个元素,直到源耗尽。
def 'generate from a specific set of values'() {
expect: 'to get numbers from a varargs'
Gen.these(1,2,3).take(3).collect() == [1,2,3]
and: 'to get values from an iterable object such as a list'
Gen.these([1,2,3]).take(2).collect() == [1,2]
and: 'to get values from a given class'
Gen.these(String).iterator().next() == String
and: 'to stop producing numbers if the source is exhausted'
Gen.these(1..3).take(10).collect() == [1,2,3]
}
运行结果:
成功
【注】“take”控制获取数量,且遵循these获取顺序:从左到右。
二、数据源补给——then连接数据源
假如目标数据源一旦意外耗尽,为了继续进行数据的生成,需要另一个生成器生成值,这正是then方法所做的。且then方法在任何生成器中都可以使用,并将一个生成器与另一个生成器连接起来。
def 'generate from multiple iterators in sequence'() {
setup:
def gen = Gen.these(1, 2, 3).then([4, 5])
expect:
gen.collect() == [1, 2, 3, 4, 5]
println(gen.take(4).size())
}
运行结果:
4
通过以上结果可知,获取四个数据元素的时候,会从then数据源中再次获取,满足整体需求。
三、 数据源补给——&符号连接数据源
&符号同样可以实现连接两个数据生成器
def 'create multi source generator with & operator'() {
setup:
// def gen = Gen.string(10) & Gen.integer(5..6) & Gen.date
def gen = Gen.string(5)&Gen.integer(7,8)
expect:
println(gen.take(10).collect().toString())
}
运行结果:
[8, 8, , 8Q, 8, , aY, WL, 7, 7]
gen结果无限,因此我们从中获取10个查看。无法控制的数据量无法直接使用,谨记!!!
四、无序选择数据——any()
Gen.these是按照顺序从源生成元素。然而Gen.any从给定源生成值,顺序是随机的。
def 'generate any value from a given source'() {
given: 'a source'
def source = [1,2,null,3]
expect: 'only that the generated value is any of the elements'
println(Gen.any(source).take(2).collect())
}
运行结果:
[2, null]
从结果来看获取2个数据元素,且并非按照顺序获取,是随机获取两个。
总结
复杂混合生成器如果用在给定的数据源且可以按照顺序或者无顺序按需提取元素数量。