成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何使用 Teprunner 測試平臺編寫從登錄到下單的大流程接口自動化用例

開發 前端 自動化
對于登錄→搜索商品→添加購物車→下單→支付這樣的大流程,使用teprunner測試平臺該如何編寫接口自動化用例呢?

大家好,我是剛哥。

對于登錄→搜索商品→添加購物車→下單→支付這樣的大流程,使用teprunner測試平臺該如何編寫接口自動化用例呢?

假設這幾個節點的接口和參數如下:

  1. # 登錄 
  2. url:/login 
  3. method: post 
  4. body: {"username""dongfanger""password""123456"
  5. response: {"token""de2e3ffu29"
  6.  
  7. # 搜索商品 
  8. url:/searchSku 
  9. method: get 
  10. headers: {"token""de2e3ffu29"
  11. body: {"skuName""電子書"
  12. response: {"skuId""222""price""2.3"
  13.  
  14. # 添加購物車 
  15. url:/addCart 
  16. method: post 
  17. headers: {"token""de2e3ffu29"
  18. body: {"skuId""222""skuNum""3"
  19. response: {"skuId""222""price""2.3""skuNum""3""totalPrice""6.9"
  20.  
  21. # 下單 
  22. url:/order 
  23. method: post 
  24. headers: {"token""de2e3ffu29"
  25. body: {"skuId""222""price""2.3""skuNum""3""totalPrice""6.9"
  26. response: {"orderId""333"
  27.  
  28. # 支付 
  29. url:/pay 
  30. method: post 
  31. headers: {"token""de2e3ffu29"
  32. body: {"orderId""333""payAmount""6.9"
  33. response: {"success""true"

我不會直接在teprunner測試平臺的界面上直接寫新用例的代碼,而是先在PyCharm中把代碼寫好調通,再手動復制粘貼或者經過Git同步到平臺上。本文就來介紹下怎么在PyCharm中借助tep編寫這個大流程的接口自動化用例。

先使用命令檢查tep已經是0.9.1以上版本:

  1. $ tep -V 
  2. 0.9.1 

然后初始化項目:

  1. $ tep startproject login-pay-big-process 
  2. 2021-12-27 12:41:26.721 | INFO     | tep.scaffold:create_scaffold:53 - Create new project: login-pay-big-process 
  3. Project root dir: /Users/dongfanger/PycharmProjects/login-pay-big-process 
  4.  
  5. Created folder: login-pay-big-process 
  6. Created folder: login-pay-big-process/fixtures 
  7. Created folder: login-pay-big-process/tests 
  8. Created folder: login-pay-big-process/files 
  9. Created folder: login-pay-big-process/reports 
  10. Created file: login-pay-big-process/.gitignore 
  11. Created file: login-pay-big-process/conf.yaml 
  12. Created file: login-pay-big-process/conftest.py 
  13. Created file: login-pay-big-process/pytest.ini 
  14. Created file: login-pay-big-process/requirements.txt 
  15. Created file: login-pay-big-process/fixtures/__init__.py 
  16. Created file: login-pay-big-process/fixtures/fixture_admin.py 
  17. Created file: login-pay-big-process/fixtures/fixture_env_vars.py 
  18. Created file: login-pay-big-process/fixtures/fixture_login.py 
  19. Created file: login-pay-big-process/fixtures/fixture_your_name.py 
  20. Created file: login-pay-big-process/tests/__init__.py 
  21. Created file: login-pay-big-process/tests/test_login.py 
  22. Created file: login-pay-big-process/tests/test_post.py 
  23. Created file: login-pay-big-process/tests/test_mysql.py 
  24. Created file: login-pay-big-process/tests/test_request.py 

修改fixtures/fixture_env_vars.py環境變量里面的域名:

  1. mapping = { 
  2.     "qa": { 
  3.         "domain""https://qa.com",  # 1 
  4.         "mysql_engine": mysql_engine("127.0.0.1",  # host 
  5.                                      "2306",  # port 
  6.                                      "root",  # username 
  7.                                      "123456",  # password 
  8.                                      "qa"),  # db_name 
  9.     }, 
  10.     "release": { 
  11.         "domain""https://release.com"
  12.         "mysql_engine": mysql_engine("127.0.0.1"
  13.                                      "2306"
  14.                                      "root"
  15.                                      "123456"
  16.                                      "release"), 
  17.     } 
  18.     # Add your environment and variables 

可以只修改domain,數據庫可以先不管。

編輯fixtures/fixture_login.py:

  1. from tep.client import request 
  2. from tep.fixture import * 
  3.  
  4.  
  5. def _jwt_headers(token): 
  6.     return {"Content-Type""application/json""authorization": f"Bearer {token}"
  7.  
  8.  
  9. @pytest.fixture(scope="session"
  10. def login(env_vars): 
  11.     # Code your login 
  12.     logger.info("Administrator login"
  13.     response = request( 
  14.         "post"
  15.         url=env_vars.domain + "/login",  # 1 
  16.         headers={"Content-Type""application/json"}, 
  17.         json={"username""dongfanger""password""123456"}  # 2 
  18.     ) 
  19.     assert response.status_code < 400 
  20.     response_token = jmespath.search("token", response.json()) 
  21.  
  22.     class Clazz: 
  23.         token = response_token 
  24.         jwt_headers = _jwt_headers(response_token) 
  25.  
  26.     return Clazz 

修改url。

修改body。

然后可以跑一下tests/test_login.py看能否登錄成功。

在tests目錄下新建test_login_pay.py文件:

  1. from tep.client import request 
  2.  
  3.  
  4. def test(env_vars, login): 
  5.     # 搜索商品 
  6.  
  7.     # 添加購物車 
  8.  
  9.     # 下單 
  10.      
  11.     # 支付 

先把流程架子備注清楚。再一個接口一個接口添加。

搜索商品:

  1. # 搜索商品 
  2.     response = request( 
  3.         "get"
  4.         url=env_vars.domain + "/searchSku"
  5.         headers={"token": login.token}, 
  6.         params={"skuName""電子書"
  7.     ) 
  8.     sku_id = jmespath.search("skuId", response.json()) 
  9.     sku_price = jmespath.search("price", response.json()) 
  10.     assert response.status_code < 400 
  • token直接從login fixture中取值。
  • 從響應中提取sku_id 和sku_price。

添加購物車:

  1. # 添加購物車 
  2.     sku_num = 3 
  3.     response = request( 
  4.         "post"
  5.         url=env_vars.domain + "/addCart"
  6.         headers={"token": login.token}, 
  7.         json={"skuId": sku_id, "skuNum": sku_num} 
  8.     ) 
  9.     total_price = jmespath.search("totalPrice", response.json()) 
  10.     assert response.status_code < 400 
  • token直接從login fixture中取值。
  • 入參修改為搜索商品提取的變量和自定義的sku_num變量。
  • 提取商品總價total_price。

下單:

  1. # 下單 
  2.     response = request( 
  3.         "post"
  4.         url=env_vars.domain + "/order"
  5.         headers={"token": login.token}, 
  6.         json={"skuId": sku_id, "price": sku_price, "skuNum": sku_num, "totalPrice": total_price} 
  7.     ) 
  8.     order_id = jmespath.search("orderId", response.json()) 
  9.     assert response.status_code < 400 
  • token直接從login fixture中取值。
  • 入參全部使用變量替換。
  • 提取訂單id。

支付:

  1. # 支付 
  2.     response = request( 
  3.         "post"
  4.         url=env_vars.domain + "/pay"
  5.         headers={"token": login.token}, 
  6.         json={"orderId": order_id, "payAmount""6.9"
  7.     ) 
  8.     assert response.status_code < 400 
  9.     assert response.json()["success"] == "true" 

token直接從login fixture中取值。

入參使用下單提取的order_id變量。

添加一條支付成功的斷言。

這樣一個大流程用例就寫好了。完整代碼如下:

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

 

責任編輯:武曉燕 來源: dongfanger 測試開發剛哥Python
相關推薦

2021-04-23 07:27:26

Teprunner響應式用例

2023-09-28 07:45:32

Postman自動化用例

2021-08-27 10:48:08

人工智能AI機器人

2022-12-20 15:17:13

RPA自動化UiPath

2020-12-04 10:53:44

云計算管理故障排除

2021-03-12 10:22:03

LinuxTeprunnerDocker

2024-09-29 15:32:13

自動化測試開發

2020-03-23 07:35:23

VDI自動化IT管理

2022-01-14 11:51:00

測試工具自動化

2022-03-11 10:24:47

人工智能自動化物流

2011-09-01 10:05:24

PhoneGap應用程序測試

2024-01-08 13:31:00

Rust自動化測試

2024-11-21 15:24:49

2021-01-27 11:32:12

接口測試代碼

2021-05-26 08:51:50

漏洞漏洞掃描符號執行

2022-12-26 12:30:28

接口測試

2023-09-13 11:40:12

2022-08-14 16:11:23

Python自動化測試數據

2022-06-26 09:55:00

接口自動化項目

2023-11-01 10:18:10

自動化測試工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费观看一级毛片视频 | 久草新在线 | 狠狠入ady亚洲精品经典电影 | 九九在线精品视频 | 羞羞视频网站免费观看 | 黄色a级一级片 | 久久久新视频 | 国产精品成人一区二区三区夜夜夜 | 琪琪午夜伦伦电影福利片 | 亚洲欧美国产精品一区二区 | 亚洲一区二区三区免费在线观看 | 日本在线播放一区二区 | 羞羞羞视频 | 亚洲一级毛片 | 久久精品亚洲精品 | 国产成人jvid在线播放 | 男女国产网站 | 国产精品毛片一区二区在线看 | 久久久www成人免费无遮挡大片 | 久久久久国产一区二区三区四区 | 国产精品一区二区久久久久 | 国产免费色 | 国产欧美日韩精品一区二区三区 | 91精品国产综合久久久久 | 色永久| 午夜欧美| 亚洲一区二区在线 | 免费久久久 | 色婷婷亚洲国产女人的天堂 | 精品视频一区二区 | 在线观看深夜视频 | 亚洲一卡二卡 | 久久爱黑人激情av摘花 | 97精品超碰一区二区三区 | 污片在线观看 | 亚洲国产精品成人久久久 | 精产嫩模国品一二三区 | 国产精品久久久久久久午夜片 | www.日本三级 | 亚洲天堂精品一区 | 国产成人99久久亚洲综合精品 |