網站首頁 編程語言 正文
簡介:
fixture區別于unnitest的傳統單元測試(setup/teardown)有顯著改進:
1.有獨立的命名,并通過聲明它們從測試函數、模塊、類或整個項目中的使用來激活。
2.按模塊化的方式實現,每個fixture都可以互相調用。
3.fixture的范圍從簡單的單元測試到復雜的功能測試,可以對fixture配置參數,或者跨函數function,類class,模塊module或整個測試session范圍。
fixture的功能
fixture是pytest特有的功能,用以在測試執行前和執行后進行必要的準備和清理工作。使用pytest.fixture標識,定義在函數前面。在你編寫測試函數的時候,你可以將此函數名稱做為傳入參數,pytest將會以依賴注入方式,將該函數的返回值作為測試函數的傳入參數。
主要的目的是為了提供一種可靠和可重復性的手段去運行那些最基本的測試內容。
從功能上看來,與setup、teardown相似,但是優勢明顯:
命名方式靈活,不局限于setup和teardown這幾個命名
conftest.py 配置里可以實現數據共享,不需要import就能自動找到一些配置
scope="module" 每一個.py文件調用一次
scope="session" 可以實現多個.py跨文件使用一個session來完成多個用例
特點及優勢
1、命令靈活:對于setup.teardown,可以不起這兩個名字
2、數據共享:在conftest.py配置里寫的方法可以實現數據共享,不需要import導入,可以跨文件共享
3、scope的層次及神奇的yield組合相當于各種setup和teardown
4、實現參數化
基本用法
@pytest.fixture()
import pytest
@pytest.fixture()
def login():
print("完成登錄操作")
def test_search():
print("搜索功能,此方法不需要完成登錄即可執行")
def test_cart(login):
print("加入購物車,需要完成登錄才可以")
fixture在自動化中的應用--作用域
@pytest.fixture(scope='module')
取值 |
范圍 |
說明 |
function |
函數級 |
每個函數或方法都會調用 |
class |
類級別 |
每個測試類只運行一次 |
module |
模塊級別 |
每一個.py文件只調用一次 |
package |
包級 |
沒一個python包至調用一次 |
session |
會話級 |
每次會話只需要運行一次,會話內所有方法及類、模塊都共享這個方法 |
import pytest
@pytest.fixture(scope='module')
def login():
print("完成登錄操作")
def test_search(login):
print("搜索功能,此方法不需要完成登錄即可執行")
def test_cart(login):
print("加入購物車,需要完成登錄才可以")
fixture在自動化中的應用-yield關鍵字
場景:你已經可以將測試方法【前要執行的或依賴的】解決了,測試方法后銷毀清除數據的要如何進行呢?
解決:通過在fixture函數中加入yield關鍵字,yield是調用第一次返回結果,第二次執行他下面的語句返回。
步驟:在@pytest.fixture(scope=module),在登錄的方法中加yield,之后加銷毀清楚的步驟。
import pytest
@pytest.fixture(scope='module')
def login():
# setup操作
print("完成登錄操作")
token = 1
yield token # 相當于return的操作
# teardown操作
print("完成登出操作")
def test_search(login):
# print("搜索功能,此方法不需要完成登錄即可執行")
print(f"token = {login}")
def test_cart(login):
# print("加入購物車,需要完成登錄才可以")
print(f"token = {login}")
fixture在自動化中的應用--數據共享
場景:與其他測試工程師合作一起開發時,公共的模塊要在不同的文件中,要在大家都能訪問到的地方
解決:使用conftest.py這個文件進行數據共享,并且他可以放在不同位置騎著不同的范圍共享作用
前提:
conftest文件名是不能換的
放在項目下是全局的數據共享的地方
執行:
系統執行到參數login時,先從本模塊中查找是否有這個名字的變量
之后在conftest.py中找是否有
步驟:
將登錄模塊帶@pytest.fixture寫在conftest.py中
fixture在自動化中的應用-自動應用
場景:不想原測試方法有任何改動,或全部都自動實現自動應用,沒特例,也都不需要返回值時可以選擇自動應用
解決:使用fixture中參數autouse=True實現
步驟:在方法上面加@pytest.fixture(autouse=True)
fixture在自動化中的應用-參數化
場景:測試離不開數據,為了數據靈活,一般數據都是用過參數傳的
解決:fixture通過固定參數requests傳遞
步驟:在fixture中增加@pytest.fixture(params=[1,2,3,'tom'])
在方法參數寫request,方法體里面使用request.param接收參數
import pytest
@pytest.fixture(params=[1, 2, 3, "測試"])
def login(request):
print(f"數據名稱為:{request.param}")
return request.param
def test_search(login):
print(f"{login}")
原文鏈接:https://blog.csdn.net/weixin_50464533/article/details/129164873
- 上一篇:沒有了
- 下一篇:沒有了
相關推薦
- 2022-10-02 React構建組件的幾種方式及區別_React
- 2022-09-16 Oracle查看表空間使用率以及爆滿解決方案詳解_oracle
- 2022-06-07 victoriaMetrics庫布隆過濾器初始化及使用詳解_Golang
- 2022-03-14 軟件文檔編寫規范(技術文件編寫規范)
- 2022-06-22 Android?ViewPager實現頁面左右切換效果_Android
- 2022-08-12 C#實現簡單的字符串加密_C#教程
- 2022-05-09 輕量級ORM框架Dapper應用之實現DTO_實用技巧
- 2022-07-07 Pandas提高數據分析效率的13個技巧匯總_python
- 欄目分類
-
- 最近更新
-
- 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同步修改后的遠程分支