pytest官方文檔解讀fixtures的調(diào)用方式
pytest官方文檔fixtures調(diào)用
既然fixtures是給執(zhí)行測試做準(zhǔn)備工作的,那么pytest如何知道哪些測試函數(shù) 或者 fixtures要用到哪一個fixtures呢?說白了,就是fixtures的調(diào)用。
一、測試函數(shù)聲明傳參請求fixture
測試函數(shù)通過將fixture聲明為參數(shù)來請求fixture。
def test_my_fruit_in_basket(my_fruit, fruit_basket): # 這是一個測試函數(shù) assert my_fruit in fruit_basket
參考上一章出現(xiàn)的示例,測試函數(shù)test_my_fruit_in_basket通過傳入my_fruit, fruit_basket來調(diào)用這2個fixture。
當(dāng)pytest運(yùn)行測試函數(shù)時,它會查看該測試函數(shù)中的參數(shù),然后搜索與這些參數(shù)具有相同名稱的fixture。一旦pytest找到這些對象,它就會運(yùn)行這些fixture。
二、fixture中的返回值傳遞給測試函數(shù)
此外,如果fixture中還有返回的內(nèi)容,pytest可以拿到,并將這些對象作為參數(shù)傳遞給測試函數(shù)。舉個例子:
class Fruit: def __init__(self, name): self.name = name self.cubed = False def cube(self): self.cubed = True class FruitSalad: def __init__(self, *fruit_bowl): self.fruit = fruit_bowl self._cube_fruit() def _cube_fruit(self): for fruit in self.fruit: fruit.cube() # Arrange @pytest.fixture def fruit_bowl(): return [Fruit("apple"), Fruit("banana")] def test_fruit_salad(fruit_bowl): # Act # 這里接收到fixture函數(shù)fruit_bowl的返回值, # 也就是[Fruit("apple"), Fruit("banana")],并使用 fruit_salad = FruitSalad(*fruit_bowl) # Assert # python內(nèi)置函數(shù)all(),用于判斷給定的可迭代參數(shù) iterable 中的所有元素是否都為 TRUE, # 如果是返回 True,否則返回 False assert all(fruit.cubed for fruit in fruit_salad.fruit)
ps:其實(shí)這里可以寫幾行非常簡單的代碼說明意思,不過突然覺得看點(diǎn)稍微繞的代碼也沒啥壞處。
可能python不太熟悉的朋友會覺得官方示例比較晦澀,其實(shí)我們重點(diǎn)不是關(guān)注這個,而且弄明白這里面的傳遞關(guān)系:
- 首先,測試函數(shù)test_fruit_salad 請求fruit_bowl(也就是 def test_fruit_salad(fruit_bowl):)
- 此時,pytest將會執(zhí)行這個fixture函數(shù)fruit_bowl,并將返回的對象作為fruit_bowl參數(shù)傳遞給測試函數(shù)test_fruit_salad。
這就是當(dāng)一個fixture被請求調(diào)用的時候,發(fā)生的事情。
如果上面的fixture函數(shù)做的事情換做我們自己手動來執(zhí)行,應(yīng)該是這樣的:
# 上面的2個類不變 ... def fruit_bowl(): return [Fruit("apple"), Fruit("banana")] def test_fruit_salad(fruit_bowl): # Act fruit_salad = FruitSalad(*fruit_bowl) # Assert assert all(fruit.cubed for fruit in fruit_salad.fruit) # Arrange bowl = fruit_bowl() test_fruit_salad(fruit_bowl=bowl)
相信看到這里,大家應(yīng)該對fixture的調(diào)用過程已經(jīng)了解。
如果覺得官方代碼示例有些晦澀,那么這里再附上一個簡易版的:
import pytest # Arrange @pytest.fixture def fruit_bowl(): return ["蘋果", "香蕉"] def test_fruit_salad(fruit_bowl): # Act fruit_salad = fruit_bowl[0] + fruit_bowl[1] # Assert assert fruit_salad == "蘋果香蕉"
接下來,繼續(xù)跟著官方文檔解讀fixture的特點(diǎn):fixture調(diào)用別的fixture、fixture的復(fù)用性。
以上就是pytest官方文檔解讀fixtures的調(diào)用方式的詳細(xì)內(nèi)容,更多關(guān)于pytest官方文檔fixtures調(diào)用的資料請關(guān)注腳本之家其它相關(guān)文章!
- pytest解讀fixtures中yield與addfinalizer區(qū)別
- pytest解讀fixtures之Teardown處理yield和addfinalizer方案
- pytest官方文檔解讀fixtures
- pytest官方文檔解讀fixtures的autouse
- pytest解讀一次請求多個fixtures及多次請求
- pytest官方文檔解讀fixtures調(diào)用fixtures及fixture復(fù)用性
- pytest解讀fixture有效性及跨文件共享fixtures
- pytest?fixtures函數(shù)及測試函數(shù)的參數(shù)化解讀
- pytest fixtures裝飾器的使用和如何控制用例的執(zhí)行順序
- Pytest中Fixtures的高級用法
相關(guān)文章
Python實(shí)現(xiàn)統(tǒng)計給定字符串中重復(fù)模式最高子串功能示例
這篇文章主要介紹了Python實(shí)現(xiàn)統(tǒng)計給定字符串中重復(fù)模式最高子串功能,涉及Python針對字符串的遍歷、排序、切片、運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下2018-05-05Python之random.sample()和numpy.random.choice()的優(yōu)缺點(diǎn)說明
這篇文章主要介紹了Python之random.sample()和numpy.random.choice()的優(yōu)缺點(diǎn)說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06django自定義非主鍵自增字段類型詳解(auto increment field)
這篇文章主要介紹了django自定義非主鍵自增字段類型詳解(auto increment field),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03pygame學(xué)習(xí)筆記(1):矩形、圓型畫圖實(shí)例
這篇文章主要介紹了pygame學(xué)習(xí)筆記(1):矩形、圓型畫圖實(shí)例,本文講解了pygame窗口、窗口退出、pygame中的顏色、圓形、矩形及一個完整實(shí)例,需要的朋友可以參考下2015-04-04python 批量修改 labelImg 生成的xml文件的方法
這篇文章主要介紹了python 批量修改 labelImg 生成的xml文件的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09將pytorch的網(wǎng)絡(luò)等轉(zhuǎn)移到cuda
這篇文章主要介紹了將pytorch的網(wǎng)絡(luò)等轉(zhuǎn)移到cuda的實(shí)現(xiàn),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-06-06使用Matplotlib繪制不同顏色的帶箭頭的線實(shí)例
這篇文章主要介紹了使用Matplotlib繪制不同顏色的帶箭頭的線實(shí)例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04