pytest多文件執行順序控制詳解
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中即可,簡單靈活
總結
到此這篇關於pytest多文件執行順序控制的文章就介紹到這瞭,更多相關pytest多文件執行順序內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Python自動化測試pytest中fixtureAPI簡單說明
- pytest自動化測試中的fixture的聲明和調用
- python單測框架之pytest常見用法
- pytest fixtures裝飾器的使用和如何控制用例的執行順序
- pytest基本用法簡介