Pytest+Allure接口自动化一些学习分享

测试开发技术

共 2920字,需浏览 6分钟

 ·

2020-09-24 20:19

好书

速递

狂师力作,2020年行业畅销书:《自动化测试实战宝典:Robot Framework + Python从小工到专家》,内容覆盖了后端接口、Web、移动端、小程序、H5多端自动化技术,兼顾知识广度的同时,也有项目实战深度应用。


新书传送门: 重磅消息 |《自动化测试实战宝典:从小工到专家》隆重上市!

1. 自我介绍

大家好,我是林宗霖,是一名95后的测试猿,也是《自动化测试实战宝典:从小工到专家》这本书的读者,首先感谢狂师大大帮忙推荐本文。

笔者对测试这一岗位的浅薄认知是:测试基础要牢,知识面要广。而要想知识面广,就需要不断的学习,并且不仅限于测试这一岗位的知识的学习,比如说市场、产品、开发、运维等方面的知识。目前笔者在简书上更新一些干货文章,欢迎大家去阅读,有错指出,一起探讨进步。(简书搜索:猪儿打滚)

2. Pytest+Allure学习中一些分享

目前在项目所使用的接口自动化,用的是之前写的unittest+ddt。偶尔上BOSS看了一些招聘消息,就花了时间学习pytest,并写了这个接口自动化:pytest+allure。写的有点仓促,主要目的是学习并使用pytest和allure,以及相应的学习思路。

2.1 主体思路

1、采用数据驱动:yaml文件管理测试用例,一个yaml文件最好对标一个接口,然后有不同情况的请求/判断数据。2、请求需要处理数据依赖的情况,因为用了requests.session()进行会话保持,所以排除cookies的依赖。需要处理的是其它参数的依赖,比如:支付请求的参数订单号的值,来自于确认订单的响应参数订单号的值。

对应的解决方案

  • 依赖数据变量开头用$标记,比如$orderid(一个请求中,不能出现多个同名依赖数据变量)
  • 需要指定提取该变量的测试用例
  • 需要指定需要提取的变量名,比如:
 variables:  # 需要获取的变量值(本用例需要)
     - login: # 提取变量的测试用例
       - code_value
       - data_value  # 变量名
  • 对应的测试用例,需要指定要提取的变量,以及值在response的位置,比如:
relevance: # 提取出去的变量(提供其它用例)
  code_value: content.data.code  # 变量名: 变量位置
  data_value: content.data  

variables指定的变量名需要和relevance中指定的变量一致,就比如上面,从login提取code_value和data_value,那么login.yaml提供该数据的请求中,relevance也需要指定code_value和data_value(暂时没处理如果有多个相同的情况,默认取一个)

  • 测试用例的数据,通过 @pytest.mark.parametrize("param, title", test_params)传递 其中param为每次请求的内容,title对应该请求的标题

2.2 难点

难点1: 处理依赖数据;还是用上面的例子:支付请求的参数订单号的值,来自于确认订单的响应参数订单号的值。

1.在“支付请求”测试用例pay.yaml中,比如url上需要带上orderid,写成:http://www.xxx.com?orderid=$orderid

2.然后说明该参数值需要去“确认订单”测试用例order.yaml中去获取,所以用例pay.yaml中写上:

 variables:  
     - order:
        - orderid

3.比如orderid需要取自一个正确下单的请求用例,那么就在“确认订单”测试用例order.yaml该请求用例中,写上:

relevance: # 提取出去的变量(提供其它用例)
  orderid: content.data.orderid # 变量名: 变量位置

逻辑解释

  • 处理yaml数据时,发现一个接口请求数据中有$开头的数据,则添加到一个list中,然后该list值会以dict{variables_data:[orderid]}的形式,组装在这个接口请求数据中(非全局)

  • 同时,如果发现一个接口请求有步骤2的结构,则会处理成这样:variables: [{'login': ['orderid']}, {'xxx': ['xxx','xxx']}]当发现一个接口请求数据,同时有variables_datavariables这两个值,那说明这个接口需要其它用例提供依赖数据值

  • 根据variables: [{'login': ['orderid']}, {'xxx': ['xxx','xxx']}],找到login.yaml这个测试用例文件,然后读取该文件内容和进行判断,看哪个用例中存在relevance: {'orderid': 'content.data.orderid'},说明所想要获取的orderid的值,取自于这个用例请求response的content.data.orderid。那么就会发送这个请求,在响应中取值response.content.data.orderid。比如说如果orderid=10

  • 接着把这个值,替换到http://www.xxx.com?orderid=$orderid中,也就是http://www.xxx.com?orderid=10。然后发送该请求

难点2:把yaml用例数据,解析成适用@pytest.mark.parametrize()的数据格式@pytest.mark.parametrize("param1, param2", params),其中的params所需的数据结构需可迭代,比如[ [param1_1, param2_1], [param1_2, param2_2]... ]。那么每次获取传递来的就是里面的[param1_x, param2_x]

yaml读取的数据结构,可自行百度;然后详细代码逻辑就不说明了。

3. 代码目录结构

3.1 大体业务逻辑

git项目地址:https://github.com/LinZLin/API_Pytest

如果觉得有用,帮忙点个好看朋友圈转发分享一下就行。


作者新书

新书资讯新书除了纸质图书外,电子版也已在京东、当当网上线了。


(点击直达小程序)


推荐阅读


推荐一款万能抓包神器:Fiddler Everywhere

推荐一款技术人必备的接口测试神器:Apifox

接口测试框架接入性能测试实践分享

推荐一款Python开源库,技术人必备的造数据神器!

重磅消息 |《自动化测试实战宝典:从小工到专家》隆重上市!


END

所有原创文章
第一时间发布至此公众号「测试开发技术」

长按二维码/微信扫码  关注


关注后,回复「me」试试
点击阅读原文
浏览 47
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报