亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Pytest?Fixture參數(shù)講解及使用

 更新時間:2023年01月10日 09:58:56   作者:測試之道.  
這篇文章主要介紹了Pytest之Fixture參數(shù)詳解及使用,本文結(jié)合實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

Fixture參數(shù)詳解及使用

Fixture的調(diào)用方式:

@pytest.fixture(scope = "function",params=None,autouse=False,ids=None,name=None)

參數(shù)詳解:
1、SCOPE

用于控制Fixture的作用范圍
作用類似于Pytest的setup/teardown
默認取值為function(函數(shù)級別),控制范圍的排序為:session > module > class > function

取值范圍 說明
function函數(shù)級 每一個函數(shù)或方法都會調(diào)用
class函數(shù)級 模塊級 每一個.py文件調(diào)用一次
module模塊級 每一個.py文件調(diào)用一次
session會話級 每次會話只需要運行一次,會話內(nèi)所有方法及類,模塊都共享這個方法

作用范圍舉例:

scope = “function”
語法:

@pytest.fixture() 
#或者
@pytest.fixture(scope='function')

場景一:做為參數(shù)傳入

import pytest
# fixture函數(shù)(類中) 作為多個參數(shù)傳入
@pytest.fixture()
def login():
    print("打開瀏覽器")
    a = "account"
    return a
    
@pytest.fixture()
def logout():
    print("關(guān)閉瀏覽器")

class TestLogin:
    #傳入lonin fixture
    def test_001(self, login):
        print("001傳入了loging fixture")
        assert login == "account"

    #傳入logout fixture
    def test_002(self, logout):
        print("002傳入了logout fixture")

    def test_003(self, login, logout):
        print("003傳入了兩個fixture")

    def test_004(self):
        print("004未傳入仍何fixture哦")

if __name__ == '__main__':
    pytest.main()

運行結(jié)果:

從運行結(jié)果可以看出,fixture做為參數(shù)傳入時,會在執(zhí)行函數(shù)之前執(zhí)行該fixture函數(shù)。再將值傳入測試函數(shù)做為參數(shù)使用,這個場景多用于登錄

場景二、Fixture的相互調(diào)用
代碼:

import pytest
# fixtrue作為參數(shù),互相調(diào)用傳入
@pytest.fixture()
def account():
    a = "account"
    print("第一層fixture")
    return a
    
#Fixture的相互調(diào)用一定是要在測試類里調(diào)用這層fixture才會生次,普通函數(shù)單獨調(diào)用是不生效的
@pytest.fixture()   
def login(account):
    print("第二層fixture")

class TestLogin:
    def test_1(self, login):
        print("直接使用第二層fixture,返回值為{}".format(login))

    def test_2(self, account):
        print("只調(diào)用account fixture,返回值為{}".format(account))
if __name__ == '__main__':
    pytest.main()

運行結(jié)果:

注:

1.即使fixture之間支持相互調(diào)用,但普通函數(shù)直接使用fixture是不支持的,一定是在測試函數(shù)內(nèi)調(diào)用才會逐級調(diào)用生效
2.有多層fixture調(diào)用時,最先執(zhí)行的是最后一層fixture,而不是先執(zhí)行傳入測試函數(shù)的fixture
3.上層fixture的值不會自動return,這里就類似函數(shù)相互調(diào)用一樣的邏輯

scope = “class”:

**當測試類內(nèi)的每一個測試方法都調(diào)用了fixture,fixture只在該class下所有測試用例執(zhí)行前執(zhí)行一次

**測試類下面只有一些測試方法使用了fixture函數(shù)名,這樣的話,fixture只在該class下第一個使用fixture函數(shù)的測試用例位置開始算,后面所有的測試用例執(zhí)行前只執(zhí)行一次。而該位置之前的測試用例就不管。
語法

@pytest.fixture(scope='class')

場景一、

import pytest
# fixture作用域 scope = 'class'
@pytest.fixture(scope='class')
def login():
    print("scope為class")

class TestLogin:
    def test_1(self, login):
        print("用例1")

    def test_2(self, login):
        print("用例2")

    def test_3(self, login):
        print("用例3")
if __name__ == '__main__':
    pytest.main()

運行結(jié)果:

場景二、

import pytest
@pytest.fixture(scope='class')
def login():
    a = '123'
    print("輸入賬號密碼登陸")

class TestLogin:
    def test_1(self):
        print("用例1")

    def test_2(self, login):
        print("用例2")

    def test_3(self, login):
        print("用例3")

    def test_4(self):
        print("用例4")

if __name__ == '__main__':
    pytest.main()

運行結(jié)果:

scope = “module”:與class相同,只從.py文件開始引用fixture的位置生效

import pytest
# fixture scope = 'module'
@pytest.fixture(scope='module')
def login():
    print("fixture范圍為module")


def test_01():
    print("用例01")


def test_02(login):
    print("用例02")


class TestLogin():
    def test_1(self):
        print("用例1")

    def test_2(self):
        print("用例2")

    def test_3(self):
        print("用例3")

if __name__ == '__main__':
    pytest.main()

運行結(jié)果:

scope = “session”:用法將在conftest.py文章內(nèi)詳細介紹
session的作用范圍是針對.py級別的,module是對當前.py生效,seesion是對多個.py文件生效
session只作用于一個.py文件時,作用相當于module
所以session多數(shù)與contest.py文件一起使用,做為全局Fixture
2、params:

Fixture的可選形參列表,支持列表傳入
默認None,每個param的值
fixture都會去調(diào)用執(zhí)行一次,類似for循環(huán)

可與參數(shù)ids一起使用,作為每個參數(shù)的標識,詳見ids
被Fixture裝飾的函數(shù)要調(diào)用是采用:Request.param(固定寫法,如下圖)
舉個栗子:

3、ids:

用例標識ID
與params配合使用,一對一關(guān)系

舉個栗子:
未配置ids之前,用例:

配置了IDS后:

4、autouse:
默認False
若為True,剛每個測試函數(shù)都會自動調(diào)用該fixture,無需傳入fixture函數(shù)名

由此我們可以總結(jié)出調(diào)用fixture的三種方式:
  1.函數(shù)或類里面方法直接傳fixture的函數(shù)參數(shù)名稱
  2.使用裝飾器@pytest.mark.usefixtures()修飾
  3.autouse=True自動調(diào)用,無需傳仍何參數(shù),作用范圍跟著scope走(謹慎使用)
讓我們來看一下,當autouse=ture的效果:

5、Name:

fixture的重命名
通常來說使用 fixture 的測試函數(shù)會將 fixture 的函數(shù)名作為參數(shù)傳遞,但是 pytest 也允許將fixture重命名
如果使用了name,那只能將name傳如,函數(shù)名不再生效
調(diào)用方法:@pytest.mark.usefixtures(‘fixture1’,‘fixture2’)
舉栗:

import pytest
@pytest.fixture(name="new_fixture")
def test_name():
    pass
    
#使用name參數(shù)后,傳入重命名函數(shù),執(zhí)行成功
def test_1(new_fixture):
    print("使用name參數(shù)后,傳入重命名函數(shù),執(zhí)行成功")

#使用name參數(shù)后,仍傳入函數(shù)名稱,會失敗
def test_2(test_name):
    print("使用name參數(shù)后,仍傳入函數(shù)名稱,會失敗")

運行結(jié)果:

到此這篇關(guān)于Pytest之Fixture參數(shù)詳解及使用的文章就介紹到這了,更多相關(guān)Pytest Fixture使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python函數(shù)和模塊的使用詳情

    Python函數(shù)和模塊的使用詳情

    這篇文章主要介紹了Python函數(shù)和模塊的使用詳情,文章基于python的相關(guān)資料展開主題的具體介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-04-04
  • Python用函數(shù)思想完成哥德巴赫猜想代碼分析

    Python用函數(shù)思想完成哥德巴赫猜想代碼分析

    在本篇文章里小編給大家整理的是一篇關(guān)于Python用函數(shù)思想完成哥德巴赫猜想代碼分析,有興趣的朋友們可以參考下。
    2021-06-06
  • keras導入weights方式

    keras導入weights方式

    這篇文章主要介紹了keras導入weights方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • python pandas dataframe多列篩選方式

    python pandas dataframe多列篩選方式

    這篇文章主要介紹了python pandas dataframe多列篩選方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 詳解Python驗證碼識別

    詳解Python驗證碼識別

    這幾天在寫一個程序的時候需要識別驗證碼,因為程序是Python寫的自然打算用Python進行驗證碼的識別。下面把實現(xiàn)思路分享在腳本之家平臺,感興趣的朋友可以參考下
    2016-01-01
  • Flask運用Xterm實現(xiàn)交互終端的示例詳解

    Flask運用Xterm實現(xiàn)交互終端的示例詳解

    Xterm是一個基于X Window System的終端仿真器(Terminal Emulator),Xterm最初由MIT開發(fā),它允許用戶在X Window環(huán)境下運行文本終端程序,本文給大家介紹了Flask運用Xterm實現(xiàn)交互終端的示例詳解,文中有詳細的代碼講解,需要的朋友可以參考下
    2023-11-11
  • python實現(xiàn)kmp算法的實例代碼

    python實現(xiàn)kmp算法的實例代碼

    這篇文章主要介紹了python實現(xiàn)kmp算法的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • python按照list中字典的某key去重的示例代碼

    python按照list中字典的某key去重的示例代碼

    這篇文章主要介紹了python按照list中字典的某key去重的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-10-10
  • Python多線程使用方法詳細講解

    Python多線程使用方法詳細講解

    這篇文章主要介紹了Python中的多線程實例,一個CPU,將時間切成一片一片的,CPU輪轉(zhuǎn)著去處理一件一件的事情,到了規(guī)定的時間片就處理下一件事情,更多的相關(guān)內(nèi)容需要的小伙伴可以參考下面文章詳細
    2022-10-10
  • 基于django channel實現(xiàn)websocket的聊天室的方法示例

    基于django channel實現(xiàn)websocket的聊天室的方法示例

    這篇文章主要介紹了基于基于django channel實現(xiàn)websocket的聊天室的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04

最新評論