網站首頁 編程語言 正文
1.只有一個py文件
1.使用pytest做接口測試,如果測試case只存在于單個.py文件,那么測試case默認從上到下執行,如果使用了pytest-order插件
2.如果存在多個py文件
1.使用pytest做接口測試,如果測試case存在于多個.py文件中,那么默認是按照文件名的ascii碼順序執行,進入文件后,默認按照從上到下順序執行每個單元測試接口。
test_user.py # 用戶相關
class TestUser:
def test_user_create:
def test_user_login:
def test_user_delete
test_order.py # 訂單相關
class TestOrder:
def test_order_create:
def test_order_list:
def test_order_delete
test_stock.py # 庫存相關
class TestStock:
def test_stock_add:
def test_stock_list:
def test_stock_reduce
1.按照文件名ascii排序:test_order > test_stock > test_user
2.test_order_create > test_order_list > test_order_delete > test_stock_add > test_stock_list > …
2.如果單個.py測試文件中使用了pytest-order插件,那么該文件中添加了order的測試用例將會最先執行,沒添加的將會按照1的順序執行,這樣就會出現單元測試的順序在多文件中交叉執行的現象。(所以單個.py文件在使用pytest-order插件的情況下,建議每個case都帶上order=x,且x不要相同)
test_user.py # 用戶相關
class TestUser:
@pytest.mark.run(order=1)
def test_user_create:
def test_user_login:
@pytest.mark.run(order=2)
def test_user_delete
test_order.py # 訂單相關
class TestOrder:
def test_order_create:
def test_order_list:
def test_order_delete
test_stock.py # 庫存相關
class TestStock:
def test_stock_add:
def test_stock_list:
def test_stock_reduce
1.由于 test_user 文件中的 case 使用了 pytest-order 插件,所以優先執行使用了order排序的 case
2.test_user_create > test_user_delete> test_order_create> … > test_stock_add > … > test_user_delete
3.如果多個.py文件使用了pytest-order插件,如果每個order指定的順序不沖突,就按照order指定的順序執行,如果有沖突,那就會出現在多個.py文件中交叉執行,可能不符合我們預期。
test_user.py # 用戶相關
class TestUser:
@pytest.mark.run(order=1)
def test_user_create:
def test_user_login:
@pytest.mark.run(order=2)
def test_user_delete
test_order.py # 訂單相關
class TestOrder:
def test_order_create:
def test_order_list:
def test_order_delete
test_stock.py # 庫存相關
class TestStock:
@pytest.mark.run(order=1)
def test_stock_add:
@pytest.mark.run(order=2)
def test_stock_list:
def test_stock_reduce
1.test_stock 和 test_user 存在 order 沖突,所以按照文件名ascii順序排序
2.test_stock_add > test_user_create > test_stock_list > test_user_delete > order相關 > test_stock_reduce > test_user_login
4.多個py文件修改按照文件名ascii碼排序方式
需求:不要再多個文件中來回執行case,保證測試用例順序為:用戶模塊-->訂單模塊-->庫存模塊
方式一:通過修改文件名,使得文件名ascii碼排序,和我們測試case執行順序一致,確保case中沒有pytest-order插件
test_1_user.py # 用戶相關
class TestUser:
def test_user_create:
def test_user_login:
def test_user_delete
test_2_order.py # 訂單相關
class TestOrder:
def test_order_create:
def test_order_list:
def test_order_delete
test_3_stock.py # 庫存相關
class TestStock:
def test_stock_add:
def test_stock_list:
def test_stock_reduce
但通常情況下,我們.py文件是根據模塊去命名的,所以通過修改文件名實現我們預期的執行順序,并不是很友好
方式二:如果使用pytest-order插件來控制,必須保證每個文件的order值是不能重復的,后一個.py文件order最小值必須大于前一個.py文件最大值,這樣就可以確保文件執行順序
這樣在增加測試用例后,就可能需要修改很多order順序
test_user.py # 用戶相關
class TestUser:
@pytest.mark.run(order=1)
def test_user_create:
@pytest.mark.run(order=3)
def test_user_login:
@pytest.mark.run(order=2)
def test_user_delete
test_order.py # 訂單相關
class TestOrder:
@pytest.mark.run(order=4)
def test_order_create:
@pytest.mark.run(order=5)
def test_order_list:
@pytest.mark.run(order=6)
def test_order_delete
test_stock.py # 庫存相關
class TestStock:
@pytest.mark.run(order=7)
def test_stock_add:
@pytest.mark.run(order=8)
def test_stock_list:
@pytest.mark.run(order=9)
def test_stock_reduce
方式三:通過pytest提供的勾子方法pytest_collection_modifyitems,對case執行順序進行修改
# conftest.py
def pytest_collection_modifyitems(config, items)
# 期望用例順序按照.py文件執行
appoint_classes = {"TestUser": [], "TestOrder": [], "TestStock": []}
for item in items:
for cls_name in appoint_classes:
if item.parent.name == cls_name:
appoint_classes[cls_name].append(item)
items.clear()
for cases in appoint_classes.values():
items.extend(cases)
用戶只需要將其新增的測試模塊class按照預期的順序添加到appoint_classes中即可,簡單靈活
總結
原文鏈接:https://blog.csdn.net/qq_42517220/article/details/124117773
相關推薦
- 2022-05-19 PyTorch中的torch.cat簡單介紹_python
- 2022-02-03 gogs倉庫代碼拉取不需要用戶賬號驗證問題
- 2022-12-12 flutter?InheritedWidget使用方法總結_Android
- 2022-03-20 基于ABP框架實現數據字典開發_實用技巧
- 2022-04-01 mybatis if 并且判斷列表是否為空
- 2023-06-19 深入了解Golang中Slice切片的使用_Golang
- 2024-01-06 關于class.getClassLoader().getResourceAsStream()和cla
- 2022-05-20 C++實現公司人事管理系統_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支