查看原文
其他

效率翻倍!再也不用手动改测试接口的参数了

编程派 2020-09-13

点击上方蓝字,每天一起学 Python,文末领送书福利


文 | 花心测试

编辑 | EarlGrey


在做接口测试的时候,我们经常会遇到一种情况就是要对接口的参数进行各种可能的校验,手动修改很麻烦,尤其是那些接口参数有几十个甚至更多的。

有没有一种方法可以批量的对指定参数做生成处理呢?

答案是肯定的!

python的jinja2模板库可以很好的满足我们的需求,通过维护一个原始数据模板,将我们想要动态生成的变量模板化,就可以实现需求。

现在我们有这样的一个请求数据

  1. {

  2. "abc":"123",

  3. "p2p":"123",

  4. "smid":"20180807220733939b66d80092eea34ce9e77f30bedff12345b7d5a3faa11b",

  5. "test":{

  6. "test1":"1",

  7. "test2":"2"

  8. },

  9. "test3":"3"

  10. }

如果想对其中的smid字段进行批量修改并生成新的请求数据就可以进行如下操作:

1、首先新建一个名为fp_template.txt的文本文件;

2、将上面的接口请求数据复制粘贴进这个txt文件中,我们以此作为“模板文件”;

3、新建一个predata文件夹用来存放生成后的数据文件;

4、对smid字段进行模板化(模板格式可以参考jinja2的语法,这里不做赘述),于是上面的请求参数就变成了下面这样:

  1. {

  2. "abc":"123",

  3. "p2p":"123",

  4. "smid":"{{ smid }}",

  5. "test":{

  6. "test1":"1",

  7. "test2":"2"

  8. },

  9. "test3":"3"

  10. }

实现代码代码如下:

  1. # -*- coding: UTF-8 -*-

  2. from jinja2 import Environment,FileSystemLoader

  3. import os


  4. class DataTemplateFaker:

  5. def __init__(self):

  6. self.aesPath = os.getcwd()#获取启动路径

  7. self.resultPath = self.aesPath + "/predata/"#指定用来保存生成数据的路径

  8. self.templateFile = "fp_template.txt"


  9. #修改我们要批量生成smid的格式

  10. def init_smid(self,start,end):

  11. smidArg = [x for x in range(start, end)]

  12. re = []

  13. for n in smidArg:

  14. re.append("20180807220733939b66d80092eea34ce9e77f30bedff" + str(n) + "b7d5a3faa11b")

  15. return re


  16. #操作模板文件

  17. def preContent(self,arg):

  18. env = Environment(loader=FileSystemLoader('./'))

  19. tpl = env.get_template(self.templateFile)

  20. renderContent = tpl.render(smid=arg)

  21. return renderContent


  22. #通过修改的smid列表批量替换模板文件并写入指定文件中

  23. def makeContent(self,preList):

  24. x = 0

  25. for i in preList:

  26. x = x + 1

  27. filename = str(self.resultPath) + 'data_' + str(x) + '.txt' #用以区分存放新生成的请求数据(也可以写到一个文件中)

  28. renderContent = self.preContent(i)

  29. with open(filename, 'w') as f:

  30. f.writelines(renderContent)

  31. f.close()


  32. if __name__ == "__main__":

  33. AT = DataTemplateFaker()

  34. reList = AT.init_smid(1,10)#控制生成数据的范围

  35. AT.makeContent(reList)

运行程序,就能得到新生成的数据

当然,我们也可以对其他的参数进行指定修改,如修改p2p,只需要修改模板文件:

  1. {

  2. "abc":"123",

  3. "p2p":"{{ p2p }}",

  4. "smid":"20180807220733939b66d80092eea34ce9e77f30bedff12345b7d5a3faa11b",

  5. "test":{

  6. "test1":"1",

  7. "test2":"2"

  8. },

  9. "test3":"3"

  10. }

然后在代码中加入一个方法init_p2p()

  1. # -*- coding: UTF-8 -*-

  2. from jinja2 import Environment,FileSystemLoader

  3. import os


  4. class DataTemplateFaker:

  5. def __init__(self):

  6. self.aesPath = os.getcwd()#获取启动路径

  7. self.resultPath = self.aesPath + "/predata/"#指定用来保存生成数据的路径

  8. self.templateFile = "fp_template.txt"


  9. #修改我们要批量生成smid的格式

  10. def init_smid(self,start,end):

  11. smidArg = [x for x in range(start, end)]

  12. re = []

  13. for n in smidArg:

  14. re.append("20180807220733939b66d80092eea34ce9e77f30bedff" + str(n) + "b7d5a3faa11b")

  15. return re

  16. #修改我们要批量生成p2p的格式

  17. def init_p2p(self,start,end):

  18. p2pArg = [x for x in range(start, end)]

  19. return p2pArg


  20. #操作模板文件

  21. def preContent(self,arg):

  22. env = Environment(loader=FileSystemLoader('./'))

  23. tpl = env.get_template(self.templateFile)

  24. renderContent = tpl.render(smid=arg)

  25. return renderContent


  26. #通过修改的smid列表批量替换模板文件并写入指定文件中

  27. def makeContent(self,preList):

  28. x = 0

  29. for i in preList:

  30. x = x + 1

  31. filename = str(self.resultPath) + 'data_' + str(x) + '.txt' #用以区分存放新生成的请求数据(也可以写到一个文件中)

  32. renderContent = self.preContent(i)

  33. with open(filename, 'w') as f:

  34. f.writelines(renderContent)

  35. f.close()


  36. if __name__ == "__main__":

  37. AT = DataTemplateFaker()

  38. reList = AT.init_p2p(1,10)#控制生成数据的范围

  39. AT.makeContent(reList)

这只是一个很简单的demo,当然还有很多可优化的地方,比如多字段同时修改、引入faker库进行关联生成伪造数据等,越是复杂且参数繁多的接口越适用,其他的方法就可以天马行空,任君发挥了。

作者:[花心测试] 出处:[https://www.cnblogs.com/flowertester/] 原文:https://www.cnblogs.com/flowertester/p/11421471.html



文末送书活动

活动规则大家请一定要查看,点击这篇推文哦:从今天起,每天至少送大家一本书

这篇推文的福利赠书为:《Python 数据科学入门》,送给本篇文章点赞最多、且符合活动要求的精选留言者。


最新赠书名单:将在留言区公布,请联系加我好友(微信号:codingpython)领取奖励哈~

回复下方「关键词」,获取优质资源


回复关键词「 pybook03」,立即获取主页君与小伙伴一起翻译的《Think Python 2e》电子版

回复关键词「书单02」,立即获取主页君整理的 10 本 Python 入门书的电子版

回复关键词「book 数字」,将数字替换成 0 及以上数字,有惊喜好礼哦~


推荐阅读


题图:pexels,CC0 授权。

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存