Groovy 参数默认值在接口测试中应用
最近在工作中频繁的使用到 Groovy 编程语言的一个特性:就是可以设置参数默认值。在编写方法或者函数的代码的时候,可以选择对参数进行一个默认值的设定。这样做就相当于对方法进行了重载。我们没写一个方法,其实就是有很多个方法重载,对于已经设置过默认值的参数。会多一个重载方法是忽略这个参数的(使用默认值)。
下面我详细介绍一下这个特性。
Groovy 特性
这个特性在接口测试中用到的地方很多。在一开始我使用这个特性去标记一些参数的格式。相当于写一个参数的 demo。再后来,我发现在设置默认值的时候,可以去使用一些脚本或者直接调用方法。在文章分段随机实践—模拟线上流量中,我就用到了这个特性。
Groovy 语言是编写有参方法的代码的时候,可以选择设置方法的默认值,即调用者不传该参数时,该参数的值。说起来有点拗口。下面我举一个简单的例子,假设需求是求两个 int 类型值的和。传统的 Java 代码如下。
那么如果我想对 a 参数默认值设置成 10,用户如果不传这个参数,只传一个参数 b,那么返回 a 的默认值和 b 的和。
这样写就实现了刚刚的需求。
脚本支持
因为 Groovy 语言的特性,还有一个就是在字符串中增加脚本的支持。所以我们在设置参数默认值的时候,也可以使用这一特性。例如我们写一个打招呼的方法,实现如果用户不传名字过来,默认随机一个用户名。
看到这里,你也许就会发现。这个默认值的设定并不局限于具体的值,而是可以使用脚本,甚至调用其他方法。下面再分享一下。之前文章中举到的例子就是随机参数的问题。
随机参数
当我们在做接口测试的过程中,对于有些接口的参数,我们完全可以枚举出来。然后再测试的。过程里随机的选择一个参数发起请求。下面我就来实现这个需求。
在这个实现案例中,我将小组的 id 范围从 1~5 随机请求。这种请求方式,目前我在性能测试中经常会遇到。在接口功能测试或者说接口的自动化测试中。我们可以用这种方式对接口的某个参数进行随机,或者说是某种程度上的遍历。那么回到性能测试中,这种方式结合对用户数据的分析结果。即可以达到请求方法+用户模型=实际流量的好处,而且我们可以传入多个用户模型就可以模拟不同场景下的实际流量。
性能实践
在之前的文章中,我已经测试过随机这种方式,性能消耗啦。这里,我就不再测试 random 方法的性能了,我对比一下使用默认值和非默认值。两种方式性能的差异。测试脚本如下:
测试结果如下:
直接使用默认值的时间消耗 3500ms
使用非默认值方式小时 700ms
时间消耗上来说,默认值会增加更多额外消耗,但是如果在一百万次数上的消耗,我觉得还是可以接受的。在编写性能测试脚本的过程中,数据的维护和复用所消耗的时间和精力会更多,而代码执行上的这点消耗,完全可以通过万能优化方案解决。
万能优化方案,俗称人民币优化方案,哈哈!!!
Have Fun ~ Tester !
版权声明: 本文为 InfoQ 作者【FunTester】的原创文章。
原文链接:【http://xie.infoq.cn/article/185d132b9a56dd0847eeedf4e】。文章转载请联系作者。
评论