接口自动化框架设计必备利器之参数传递

在我们设计自动化测试框架的时候,我们会经常将测试数据保存在外部的文件(如Excel、YAML)中,实现测试脚本与测试数据解耦,方便后期维护。

当涉及到业务场景接口用例时,由于接口与接口存在关联关系,需要从上游接口取出来相关字段传递给下游接口作为入参使用,比如在Excel中我们会这样做:

在这里插入图片描述

在excel中新增一列【提取响应】,将上游接口的响应字段提取出来,在下游接口当中通过标记符进行使${XXX}

在YAML中我们也会有类似的用法:

  1. - casename: 修改用户信息

  2. teststeps:

  3. - name: 登录成功

  4. request:

  5. method: POST

  6. url: /login

  7. json:

  8. principal: lemon_auto

  9. credentials: lemon123456

  10. appType: 3

  11. loginType: 0

  12. headers:

  13. Content-Type: application/json

  14. extract:

  15. token: $.access_token

  16. tokentype: $.token_type

  17. validate:

  18. - eq: [status_code, 200]

  19. - eq: [$.nickName, "lemon_auto"]

  20. - name: 进入到个人中心

  21. request:

  22. method: GET

  23. url: /p/user/userInfo

  24. queryparam: null

  25. headers:

  26. Authorization: ${tokentype}${token}

  27. validate:

  28. - eq: [status_code, 200]

  29. - eq: [$.nickName, "lemon_auto"]

【extract】代表要提取的响应字段信息,在下游接口中同样通过${XXX}用法进行引用

参数传递替换实现

在框架中关键实现是需要识别到标记符并且进行参数的替换,一般的思路我们采用正则表达式识别标记符,并且配合环境变量取出对应的字段值再使用replace进行替换,整个的操作封装相比复杂性会比较高。

在python中提供了Template类,它能够非常简单的通过模块替换你想要的字符串。Template类中默认的替换模板就是${XXX}标记符,具体用法如下:

将要替换的原始字符串作为参数初始化Template对象

使用substitute方法,传递需要替换的内容from string import Template

  1. # 原始数据

  2. data = '''

  3. {

  4. "address": "青海省西宁市城东区格兰小镇",

  5. "communityName": "八家湾小区",

  6. "nearbyLandmarks": "${mark}",

  7. "userId": ${userId}

  8. }

  9. '''

  10. # 这里是需要替换的内容,字典类型

  11. dict = {'userId':123456,'mark':"王府井"}

  12. print(Template(data).substitute(dict))

替换之后的结果为:

  1. {

  2. "address": "青海省西宁市城东区格兰小镇",

  3. "communityName": "八家湾小区",

  4. "nearbyLandmarks": "王府井",

  5. "userId": 123456

  6. }

可以看到使用非常简单,通过substitute即可将字典中的数据替换到原始数据中。

那如果原始数据中的标记符和替换的内容不对应会有什么情况?

比如这里我的替换内容只有userId:

  1. from string import Template

  2. data = '''

  3. {

  4. "address": "青海省西宁市城东区格兰小镇",

  5. "communityName": "八家湾小区",

  6. "nearbyLandmarks": "${mark}",

  7. "userId": ${userId}

  8. }

  9. '''

  10. dict = {'userId':123456}

  11. print(Template(data).substitute(dict))

此时会报KeyError的错误,找不到mark这个key,如果不想要报错你可以使用safe_substitutefrom string import Template

  1. data = '''

  2. {

  3. "address": "青海省西宁市城东区格兰小镇",

  4. "communityName": "八家湾小区",

  5. "nearbyLandmarks": "${mark}",

  6. "userId": ${userId}

  7. }

  8. '''

  9. dict = {'userId':123456}

  10. print(Template(data).safe_substitute(dict)

  11. )

此时的输出结果为:

  1. {

  2. "address": "青海省西宁市城东区格兰小镇",

  3. "communityName": "八家湾小区",

  4. "nearbyLandmarks": "${mark}",

  5. "userId": 123456

  6. }

我们可以看到safe_substitute不会报错,并且只会替换和标记符匹配的数据,不匹配的则保持原样。

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

 

          视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

  • 22
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值