Pytest 固件

来源:https://www.cnblogs.com/cdc1216/archive/2023/03/01/17154291.html
-Advertisement-
Play Games

一、固件使用背景 在執行測試用例時,我們常常需要在測試用例執行的前後去完成一些額外的操作。例如針對於 Web 測試,在用例執行前需要打開瀏覽器,完成用戶登錄等一系列前置操作;在用例執行完成後,要清除瀏覽器緩存,關閉瀏覽器...... Pytest 框架提供的固件機制(又稱為夾具)可以幫我們實現一系列 ...


一、固件使用背景

在執行測試用例時,我們常常需要在測試用例執行的前後去完成一些額外的操作。例如針對於 Web 測試,在用例執行前需要打開瀏覽器,完成用戶登錄等一系列前置操作;在用例執行完成後,要清除瀏覽器緩存,關閉瀏覽器...... Pytest 框架提供的固件機制(又稱為夾具)可以幫我們實現一系列的前後置操作。

我們先創建一套測試用例:

二、前後置函數

1. 測試方法級別

setupteardown 方法作用於每一個測試方法,每個測試方法執行之前都會先去執行 setup 方法,執行之後都會再去執行 teardown 方法。

 1 # cases/test_cases.py
 2 class TestCase:
 3  4     def setup(self):
 5         print("\n測試方法執行前做對應的操作!!!")
 6  7     def teardown(self):
 8         print("\n測試方法執行後做對應的操作!!!")
 9 10     def test_case_001(self):
11         print("模擬測試案例001")
12 13     def test_case_002(self):
14         print("模擬測試案例002")
15 16     def test_case_003(self):
17         print("模擬測試案例003")

需要註意的是:

  • 如果前後置方法是定義在測試類內部的,那麼作用的對象是當前測試類中的每一個測試方法,其他測試類和外部的測試方法將不會被影響。

 1 # cases/test_cases.py
 2 class TestCase:
 3  4     def setup(self):
 5         print("\n測試方法執行前做對應的操作!!!")
 6  7     def teardown(self):
 8         print("\n測試方法執行後做對應的操作!!!")
 9 10     def test_case_001(self):
11         print("模擬測試案例001")
12 13     def test_case_002(self):
14         print("模擬測試案例002")
15 16     def test_case_003(self):
17         print("模擬測試案例003")
18 19 20 class TestCase2:
21     def test_case_004(self):
22         print("模擬測試案例004")
23 24     def test_case_005(self):
25         print("模擬測試案例005")
26 27 28 def test_outer_case():
29     print("模擬測試外部的測試方法")

  • 如果前後置方法是定義在測試類外部的,那麼作用的對象是定義在外部的測試方法,測試類中的測試方法不會被影響。

 1 # cases/test_cases.py
 2 def setup():
 3     print("\n測試方法執行前做對應的操作!!!")
 4  5  6 def teardown():
 7     print("\n測試方法執行後做對應的操作!!!")
 8  9 class TestCase:
10 11     def test_case_001(self):
12         print("模擬測試案例001")
13 14     def test_case_002(self):
15         print("模擬測試案例002")
16 17     def test_case_003(self):
18         print("模擬測試案例003")
19 20 21 class TestCase2:
22     def test_case_004(self):
23         print("模擬測試案例004")
24 25     def test_case_005(self):
26         print("模擬測試案例005")
27 28 29 def test_outer_case():
30     print("模擬測試外部的測試方法")

2. 測試類級別

setup_classteardown_class 方法作用於當前的測試類,每個測試類執行之前都會先去執行 setup_class 方法,執行之後都會再去執行 teardown_class 方法。測試方法並不會受到這兩個方法的影響。

 1 # cases/test_cases.py
 2 class TestCase:
 3  4     def test_case_001(self):
 5         print("模擬測試案例001")
 6  7     def test_case_002(self):
 8         print("模擬測試案例002")
 9 10     def test_case_003(self):
11         print("模擬測試案例003")
12 13 14 class TestCase2:
15     def setup_class(self):
16         print("\n測試方法執行前做對應的操作!!!")
17 18     def teardown_class(self):
19         print("\n測試方法執行後做對應的操作!!!")
20 21     def test_case_004(self):
22         print("模擬測試案例004")
23 24     def test_case_005(self):
25         print("模擬測試案例005")

三、裝飾器實現

使用前後置函數的方式作用的對象都是一個模塊內或者是一個測試類中的全體對象,沒有辦法做到只作用於部分對象。Pytest 提供了 @pytest.fixture() 方法來實現部分用例的前後置操作。

1. 簡單使用

  • 第一步,先自定義一個生成器方法

1 def my_fixture():
2     print("前置操作")
3     yield
4     print("後置操作")
  • 第二步,添加裝飾器方法

1 import pytest
2 3 @pytest.fixture()
4 def my_fixture():
5     print("前置操作")
6     yield
7     print("後置操作")
  • 第三步,將函數名作為參數,傳遞給需要做前後置操作的測試方法。測試方法在執行前會先去執行生成器函數中 yield 的前半部分代碼;測試方法執行完成後,會去執行生成器函數中 yield 的後半部分代碼。

 1 # cases/test_cases.py
 2 import pytest
 3  4 @pytest.fixture()
 5 def my_fixture():
 6     print("前置操作")
 7     yield
 8     print("後置操作")
 9 10 class TestCase:
11 12     def test_case_001(self, my_fixture):
13         print("模擬測試案例001")
14 15     def test_case_002(self):
16         print("模擬測試案例002")
17 18     def test_case_003(self):
19         print("模擬測試案例003")

2. 相關參數詳解

2.1 autouse

值為 True 時,表示固件自動執行,即不需要在對應的測試方法中引用也會觸發,預設值為 False

 1 # cases/test_cases.py
 2 import pytest
 3  4 @pytest.fixture(autouse=True)
 5 def my_fixture():
 6     print("\n前置操作")
 7     yield
 8     print("\n後置操作")
 9 10 11 class TestCase:
12     # 並未傳入固件使用
13     def test_case_001(self):
14         print("模擬測試案例001")
15 16     def test_case_002(self):
17         print("模擬測試案例002")
18 19     def test_case_003(self):
20         print("模擬測試案例003")

2.2 scope

表示的是被 @pytest.fixture 標記的方法的作用域,有以下幾個值:

  • function:作用於測試方法級別,每個函數或方法都會調用

 1 # cases/test_cases.py
 2 import pytest
 3 
 4 @pytest.fixture(scope="function", autouse=True)
 5 def my_fixture():
 6     print("\n前置操作")
 7     yield
 8     print("\n後置操作")
 9 
10 
11 class TestCase:
12 
13     def test_case_001(self):
14         print("模擬測試案例001")
15 
16     def test_case_002(self):
17         print("模擬測試案例002")
18 
19     def test_case_003(self):
20         print("模擬測試案例003")

  • class:作用於測試類級別,測試類執行時會執行一次固件

 1 # cases/test_cases.py
 2 import pytest
 3 
 4 @pytest.fixture(scope="class", autouse=True)
 5 def my_fixture():
 6     print("\n前置操作")
 7     yield
 8     print("\n後置操作")
 9 
10 class TestCase:
11 
12     def test_case_001(self):
13         print("模擬測試案例001")
14 
15     def test_case_002(self):
16         print("模擬測試案例002")
17 
18     def test_case_003(self):
19         print("模擬測試案例003")
20 
21 class TestCase2:
22 
23     def test_case_004(self):
24         print("模擬測試案例004")
25 
26     def test_case_005(self):
27         print("模擬測試案例005")

  • module:作用於測試模塊,測試模塊(即 py 文件)執行時會執行一次固件

  • session:作用於會話,可以跨多個.py 文件,若多個模塊中的用例都調用了 fixture,只會運行一次

 1 ####################### cases/test_cases.py ########################
 2 import pytest
 3 
 4 @pytest.fixture(scope="session", autouse=True)
 5 def my_fixture():
 6     print("\n前置操作")
 7     yield
 8     print("\n後置操作")
 9 
10 class TestCase:
11 
12     def test_case_001(self):
13         print("模擬測試案例001")
14 
15     def test_case_002(self):
16         print("模擬測試案例002")
17 
18     def test_case_003(self):
19         print("模擬測試案例003")
20         
21 ####################### cases/test_cases_2.py ##############################
22 class TestCase2:
23 
24     def test_case_004(self):
25         print("模擬測試案例004")
26 
27     def test_case_005(self):
28         print("模擬測試案例005")

2.3 params

使用裝飾器方的固件,還可以進行參數傳遞。參數的類型支持以下四種:

  • 列表

  • 元組

  • 字典列表:[{},{},{}]

  • 字典元組:({},{},{})

我們先列印一下測試方法中接收的固件名的值是啥

 1 import pytest
 2 
 3 @pytest.fixture(scope="function")
 4 def my_fixture():
 5     print("一些操作......")
 6 
 7 class TestCase:
 8 
 9     def test_case_001(self, my_fixture):
10         print(f"模擬測試案例001----{my_fixture}")
11 
12     def test_case_002(self):
13         print("模擬測試案例002")
14 
15     def test_case_003(self):
16         print("模擬測試案例003")

在固件中我們嘗試返回一個值試試:

 1 import pytest
 2 
 3 @pytest.fixture(scope="function")
 4 def my_fixture():
 5     print("一些操作......")
 6     return "success"
 7 
 8 class TestCase:
 9 
10     def test_case_001(self, my_fixture):
11         print(f"模擬測試案例001----{my_fixture}")
12 
13     def test_case_002(self):
14         print("模擬測試案例002")
15 
16     def test_case_003(self):
17         print("模擬測試案例003")

可見在測試方法中傳入固件名,除了可以執行固件對應的操作,還可以拿到固件的返回值。那麼想結合 params 參數在固件中傳值就十分容易了:

 1 import pytest
 2 
 3 @pytest.fixture(scope="function", params=["aaa", "bbb", "ccc"])
 4 def my_fixture(request):  # 固定寫法,使用參數時必須接收一個request變數
 5     print("一些操作......")
 6     return request.param  # 固定寫法,返回參數
 7 
 8 class TestCase:
 9 
10     def test_case_001(self, my_fixture):
11         print(f"模擬測試案例001----{my_fixture}")
12 
13     def test_case_002(self):
14         print("模擬測試案例002")
15 
16     def test_case_003(self):
17         print("模擬測試案例003")

被標記的測試方法被執行了三次,是因為傳的參數有三個值,每執行一次就會傳一個值過去。

如果固件要執行前後置操作,就不能用 return 返回值了,要使用 yield:

 1 import pytest
 2 
 3 @pytest.fixture(scope="function", params=["aaa", "bbb", "ccc"])
 4 def my_fixture(request):  # 固定寫法,使用參數時必須接收一個request變數
 5     print("前置操作......")
 6     yield request.param  # 固定寫法,返回參數
 7     print("後置操作......")
 8 
 9 class TestCase:
10 
11     def test_case_001(self, my_fixture):
12         print(f"模擬測試案例001----{my_fixture}")
13 
14     def test_case_002(self):
15         print("模擬測試案例002")
16 
17     def test_case_003(self):
18         print("模擬測試案例003")

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在vue中父子組件傳值是必不可少的,大家必須要學會! 首先父組件向子組件傳值: 父組件:比如我們傳teacher為index,如果我們傳值變數可以使用 : 綁定我們在data中定義的變數。 子組件:為了規範一般使用對象的形式,type表示值的類型,default表示如果不傳值就預設是null. 在子 ...
  • 環境 vue2 導入 安裝npm包 echarts echarts-gl import * as echarts from "echarts" import "echarts-gl" html <div id="map-container"></div> js import GeoZJ from ' ...
  • RxEditor是一款開源企業級可視化低代碼前端,目標是可以編輯所有 HTML 基礎的組件。比如支持 React、VUE、小程式等,目前僅實現了 React 版。 RxEditor運行快照: 項目地址:https://github.com/rxdrag/rxeditor 演示地址( Vercel 部 ...
  • 如何畫好一張架構圖,要做好這件事情首先要回答的就是什麼是架構圖。我們日常工作中經常能看到各種各樣的架構圖,而且經常會發現大家對架構圖的理解各有側重。深入追究到這個問題,可能一下子還很難有一個具象的定義,如果我們把這個問題進行拆分,理解起來就會容易一點。 ...
  • 1. JPA 1.1. 性能直接受底層JDBC驅動性能的影響 1.2. 性能提升是通過改變實體類的位元組碼來實現的 1.2.1. 在類載入到JAR文件或者由JVM運行之前增強位元組碼的方法 1.2.1.1. 在編譯過程中完成的 1.2.1.2. 在實體類編譯完成後,它們會被傳遞給一個特定實現的後置處理器 ...
  • 一、前戲 在之前我們已經學會使用 pytest-html 插件生成 html 格式的測試報告: 1 # 第一步,安裝插件 2 pip install pytest-html 3 ​ 4 # 第二步,執行用例時使用 --html 參數 5 ## main 函數中執行 6 if __name__ == ...
  • MyBatis的關聯映射02 3.一對多 3.1基本介紹 mybatis – MyBatis 3 | XML 映射器 多對一關係也是一個基本的映射關係,多對一,也可以理解為一對多。例如: User--Pet:一個用戶可以有多只寵物 Dep--Emp:一個部門有多個員工 雙向的多對一關係:通過User ...
  • 背景 公司目前主要聚焦於視頻這個領域,利用視頻為媒體、文旅、會議等行業進行賦能。 既然聚焦於視頻領域,那麼視頻轉碼則是繞不開的話題。 為了降低成本,以及保證產品的核心能力,公司自建了一套轉碼系統。 轉碼服務除了儘可能多的相容業界的視頻格式外,轉碼的速度是另一個非常重要的指標。 因為視頻轉碼對用戶來說 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...