Tep集成 HttpRunner 与 Flask 实现开箱即用

开发 前端
刚开始只是我用来调试代码的,等到把Mock写完以后,想到可能大家也需要调试代码,就把它做到tep里面了,并且附带了测试用例的示例代码,安装完以后就能一键运行,开箱即用,美滋滋。归根结底,都是为了把tep做大做强。

 

大家好,我是刚哥。

趁着元旦假期最后一天,有着大把时间,奔着把tep做大做强的目标,好好学习了一波。在开始正文之前,先回答可能会问到的两个问题。第一个问题是为什么要集成HttpRunner?因为我最近在思考如何给tep做分层设计,参考了我司现有的接口自动化平台,它的设计是每个用例有很多测试步骤,可以针对用例设置预设变量,然后在测试步骤中引用。正当我准备自己开发类似功能时,想到了HttpRunner,我记得HttpRunner第3版是建议直接编写pytest代码而非以前的ymal或json文件了。大有所获,HttpRunner正是以这种方式编写的代码,而且和pytest有很好的结合,很符合tep要集成的第三方包的希望。第二个问题是为什么要集成Flask?刚开始只是我用来调试代码的,等到把Mock写完以后,想到可能大家也需要调试代码,就把它做到tep里面了,并且附带了测试用例的示例代码,安装完以后就能一键运行,开箱即用,美滋滋。归根结底,都是为了把tep做大做强。

tep0.9.3正式发布

要体验HttpRunner和Flask,需要先安装或升级到tep0.9.3。

安装:

  1. pip install tep 

升级:

  1. pip install -U tep 

或者指定版本:

  1. pip install tep==0.9.3 

安装tep时会顺带安装HttpRunner和Flask,安装完以后就可以执行命令初始化项目:

  1. tep startproject demo093 

输出:

  1. D:\PycharmProjects>tep startproject demo093 
  2. 2022-01-03 16:07:31.929 | INFO     | tep.scaffold:create_scaffold:53 - Create new project: demo093 
  3. Project root dir: D:\PycharmProjects\demo093 
  4.  
  5. Created folder: demo093 
  6. Created folder: demo093\fixtures 
  7. Created folder: demo093\tests 
  8. Created folder: demo093\files 
  9. Created folder: demo093\reports 
  10. Created folder: demo093\utils 
  11. Created file: demo093\.gitignore 
  12. Created file: demo093\conf.yaml 
  13. Created file: demo093\conftest.py 
  14. Created file: demo093\pytest.ini 
  15. Created file: demo093\fixtures\__init__.py 
  16. Created file: demo093\fixtures\fixture_admin.py 
  17. Created file: demo093\fixtures\fixture_env_vars.py 
  18. Created file: demo093\fixtures\fixture_login.py 
  19. Created file: demo093\fixtures\fixture_your_name.py 
  20. Created file: demo093\tests\__init__.py 
  21. Created file: demo093\tests\test_login.py 
  22. Created file: demo093\tests\test_post.py 
  23. Created file: demo093\tests\test_mysql.py 
  24. Created file: demo093\tests\test_request.py 
  25. Created file: demo093\tests\test_login_pay.py 
  26. Created file: demo093\tests\test_login_pay_httprunner.py 
  27. Created file: demo093\utils\__init__.py 
  28. Created file: demo093\utils\flask_mock_api.py 
  • 修改了fixture_env_vars.py里面的domain为http://127.0.0.1:5000,这是Flask启动后的默认地址。
  • 修改了fixture_login.py里面的登录url和username,跟Flask的Mock对应。
  • 新增了utils\flask_mock_api.py,直接启动Mock服务。
  • 新增了tests\test_login_pay.py,用例数据一体开发模式,登录到下单流程的示例代码,可以一键运行成功。
  • 新增了tests\test_login_pay_httprunner.py,HttpRunner开发模式,登录到下单流程的示例代码,可以一键运行成功。

新版README.md

之前tep的README是全英文的,这次我也决定不装了,改成中文 ,丰富了内容,大家可以对tep有个全新和全面的了解啦。以下是全文:

tep

tep是Try Easy Pytest的首字母缩写,是一款基于pytest测试框架的测试工具,集成了各种实用的第三方包和优秀的自动化测试设计思想,帮你快速实现自动化项目落地。

安装

支持Python3.6以上,推荐Python3.8以上。

标准安装:

  1. $ pip install tep 

国内镜像:

  1. $ pip --default-timeout=600 install -i https://pypi.tuna.tsinghua.edu.cn/simple tep 

检查安装成功:

  1. $ tep -V  # 或者 tep --version 
  2. 0.2.3 

快速创建项目

tep提供了脚手架,预置了项目结构和代码,打开cmd,使用startproject命令快速创建项目:

  1. tep startproject project_name 

并且提供了-venv参数,在项目初始化时,可以同时创建一个虚拟环境(推荐):

  1. tep startproject project_name -venv 

输出测试报告

tep提供了--tep-reports参数来生成allure测试报告:

  1. pytest  --tep-reports 

报告文件存放在根目录的reports/中。

Mock服务

tep自带了一个Flask应用(utils/flask_mock_api.py),提供了登录到下单流程的5个接口,启动后即可一键运行示例中的测试用例。

三种开发模式

tep兼容三种开发模式:用例数据一体(适合新手)、用例数据分离(适合老手)、HttpRunner(新老皆宜)。

①用例数据一体,示例代码如下所示:

  1. def test(env_vars, login): 
  2.     # 搜索商品 
  3.     response = request( 
  4.         "get"
  5.         url=env_vars.domain + "/searchSku"
  6.         headers={"token": login.token}, 
  7.         params={"skuName""电子书"
  8.     ) 
  9.     sku_id = jmespath.search("skuId", response.json()) 
  10.     sku_price = jmespath.search("price", response.json()) 
  11.     assert response.status_code < 400 
  12.  
  13.     # 添加购物车 
  14.     sku_num = 3 
  15.     response = request( 
  16.         "post"
  17.         url=env_vars.domain + "/addCart"
  18.         headers={"token": login.token}, 
  19.         json={"skuId": sku_id, "skuNum": sku_num} 
  20.     ) 
  21.     total_price = jmespath.search("totalPrice", response.json()) 
  22.     assert response.status_code < 400 
  23.  
  24.     # 下单 
  25.     response = request( 
  26.         "post"
  27.         url=env_vars.domain + "/order"
  28.         headers={"token": login.token}, 
  29.         json={"skuId": sku_id, "price": sku_price, "skuNum": sku_num, "totalPrice": total_price} 
  30.     ) 
  31.     order_id = jmespath.search("orderId", response.json()) 
  32.     assert response.status_code < 400 
  33.  
  34.     # 支付 
  35.     response = request( 
  36.         "post"
  37.         url=env_vars.domain + "/pay"
  38.         headers={"token": login.token}, 
  39.         json={"orderId": order_id, "payAmount""6.9"
  40.     ) 
  41.     assert response.status_code < 400 
  42.     assert response.json()["success"] == "true" 

更多内容请参考《如何使用teprunner测试平台编写从登录到下单的大流程接口自动化用例》

②用例数据分离

开发中,敬请期待...

③HttpRunner,示例代码如下所示:

  1. from httprunner import HttpRunner, Config, Step, RunRequest 
  2.  
  3.  
  4. class TestLoginPay(HttpRunner): 
  5.     config = ( 
  6.         Config("登录到下单流程"
  7.             .variables( 
  8.             **{ 
  9.                 "skuNum""3" 
  10.             } 
  11.         ) 
  12.             .base_url("http://127.0.0.1:5000"
  13.     ) 
  14.  
  15.     teststeps = [ 
  16.         Step( 
  17.             RunRequest("登录"
  18.                 .post("/login"
  19.                 .with_headers(**{"Content-Type""application/json"}) 
  20.                 .with_json({"username""dongfanger""password""123456"}) 
  21.                 .extract() 
  22.                 .with_jmespath("body.token""token"
  23.                 .validate() 
  24.                 .assert_equal("status_code", 200) 
  25.         ), 
  26.         Step( 
  27.             RunRequest("搜索商品"
  28.                 .get("searchSku?skuName=电子书"
  29.                 .with_headers(**{"token""$token"}) 
  30.                 .extract() 
  31.                 .with_jmespath("body.skuId""skuId"
  32.                 .with_jmespath("body.price""skuPrice"
  33.                 .validate() 
  34.                 .assert_equal("status_code", 200) 
  35.         ), 
  36.         Step( 
  37.             RunRequest("添加购物车"
  38.                 .post("/addCart"
  39.                 .with_headers(**{"Content-Type""application/json"
  40.                                  "token""$token"}) 
  41.                 .with_json({"skuId""$skuId""skuNum""$skuNum"}) 
  42.                 .extract() 
  43.                 .with_jmespath("body.totalPrice""totalPrice"
  44.                 .validate() 
  45.                 .assert_equal("status_code", 200) 
  46.         ), 
  47.         Step( 
  48.             RunRequest("下单"
  49.                 .post("/order"
  50.                 .with_headers(**{"Content-Type""application/json"
  51.                                  "token""$token"}) 
  52.                 .with_json({"skuId""$skuId""price""$skuPrice""skuNum""$skuNum""totalPrice""$totalPrice"}) 
  53.                 .extract() 
  54.                 .with_jmespath("body.orderId""orderId"
  55.                 .validate() 
  56.                 .assert_equal("status_code", 200) 
  57.         ), 
  58.         Step( 
  59.             RunRequest("支付"
  60.                 .post("/pay"
  61.                 .with_headers(**{"Content-Type""application/json"
  62.                                  "token""$token"}) 
  63.                 .with_json({"orderId""$orderId""payAmount""6.9"}) 
  64.                 .validate() 
  65.                 .assert_equal("status_code", 200) 
  66.                 .assert_equal("body.success""true"
  67.         ), 
  68.     ] 

用户手册

https://dongfanger.gitee.io/blog/chapters/tep.html

 

责任编辑:武晓燕 来源: 测试开发刚哥Python
相关推荐

2022-08-08 08:29:55

图片压缩前端互联网

2023-11-04 12:43:44

前端图片参数

2023-03-08 21:25:58

开源工具库开箱

2017-01-09 13:21:24

达沃超融合

2013-11-01 09:37:19

Android系统架构工具

2021-08-31 15:53:48

Nuxt 开箱服务

2023-01-29 07:49:57

2022-08-02 09:01:55

后台管理模版

2021-09-28 09:30:18

uni-appVue 3.0uniCloud

2021-09-01 17:43:32

StreamNativ开源

2023-01-15 20:28:32

前端图片压缩

2022-01-05 09:58:59

鸿蒙HarmonyOS应用

2021-09-26 05:41:47

基础设施连接无线技术网络

2022-01-11 09:32:20

鸿蒙HarmonyOS应用

2019-11-25 00:00:00

开源技术 数据

2024-11-25 06:20:00

Netty封装框架

2023-10-31 08:03:33

开源电子签名组件

2025-01-23 20:42:44

2022-05-19 15:10:03

英特尔TensorFlow
点赞
收藏

51CTO技术栈公众号