chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

python學(xué)習(xí):三個(gè)測(cè)試庫(kù)的裝飾器實(shí)現(xiàn)思路

454398 ? 來(lái)源:Python貓公眾號(hào) ? 作者:豌豆花下貓 ? 2020-09-27 11:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Python 中實(shí)現(xiàn)參數(shù)化測(cè)試的幾個(gè)庫(kù),并留下一個(gè)問(wèn)題:

它們是如何做到把一個(gè)方法變成多個(gè)方法,并且將每個(gè)方法與相應(yīng)的參數(shù)綁定起來(lái)的呢?

我們?cè)偬釤捯幌拢瓎?wèn)題等于是:在一個(gè)類中,如何使用裝飾器把一個(gè)類方法變成多個(gè)類方法(或者產(chǎn)生類似的效果)?

# 帶有一個(gè)方法的測(cè)試類
class TestClass:
    def test_func(self):
        pass

# 使用裝飾器,生成多個(gè)類方法
class TestClass:
    def test_func1(self):
        pass
    def test_func2(self):
        pass
    def test_func3(self):
        pass

Python 中裝飾器的本質(zhì)就是移花接木,用一個(gè)新的方法來(lái)替代被裝飾的方法。在實(shí)現(xiàn)參數(shù)化的過(guò)程中,我們介紹過(guò)的幾個(gè)庫(kù)到底用了什么手段/秘密武器呢?

1、ddt 如何實(shí)現(xiàn)參數(shù)化?

先回顧一下上篇文章中 ddt 庫(kù)的寫(xiě)法:

import unittest
from ddt import ddt,data,unpack
@ddt
class MyTest(unittest.TestCase):
    @data((3, 1), (-1, 0), (1.2, 1.0))
    @unpack
    def test(self, first, second):
        pass

ddt 可提供 4 個(gè)裝飾器:1 個(gè)加在類上的 @ddt,還有 3 個(gè)加在類方法上的 @data、@unpack 和 @file_data(前文未提及)。

先看看加在類方法上的三個(gè)裝飾器的作用:

# ddt 版本(win):1.2.1
def data(*values):
    global index_len
    index_len = len(str(len(values)))
    return idata(values)

def idata(iterable):
    def wrapper(func):
        setattr(func, DATA_ATTR, iterable)
        return func
    return wrapper

def unpack(func):
    setattr(func, UNPACK_ATTR, True)
    return func

def file_data(value):
    def wrapper(func):
        setattr(func, FILE_ATTR, value)
        return func
    return wrapper

它們的共同作用是在類方法上 setattr() 添加屬性。至于這些屬性在什么時(shí)候使用?下面看看加在類上的 @ddt 裝飾器源碼:

第一層 for 循環(huán)遍歷了所有的類方法,然后是 if/elif 兩條分支,分別對(duì)應(yīng) DATA_ATTR/FILE_ATTR,即對(duì)應(yīng)參數(shù)的兩種來(lái)源:數(shù)據(jù)(@data)和文件(@file_data)。

elif 分支有解析文件的邏輯,之后跟處理數(shù)據(jù)相似,所以我們把它略過(guò),主要看前面的 if 分支。這部分的邏輯很清晰,主要完成的任務(wù)如下:
? 遍歷類方法的參數(shù)鍵值對(duì)
? 根據(jù)原方法及參數(shù)對(duì),創(chuàng)建新的方法名
? 獲取原方法的文檔字符串
? 對(duì)元組和列表類型的參數(shù)作解包
? 在測(cè)試類上添加新的測(cè)試方法,并綁定參數(shù)與文檔字符串

分析源碼,可以看出,@data、@unpack 和 @file_data 這三個(gè)裝飾器主要是設(shè)置屬性并傳參,而 @ddt 裝飾器才是核心的處理邏輯。

這種將裝飾器分散(分別加在類與類方法上),再組合使用的方案,很不優(yōu)雅。為什么就不能統(tǒng)一起來(lái)使用呢?后面我們會(huì)分析它的難言之隱,先按下不表,看看其它的實(shí)現(xiàn)方案是怎樣的?

2、parameterized 如何實(shí)現(xiàn)參數(shù)化?

先回顧一下上篇文章中 parameterized 庫(kù)的寫(xiě)法:

import unittest
from parameterized import parameterized
class MyTest(unittest.TestCase):
    @parameterized.expand([(3,1), (-1,0), (1.5,1.0)])
    def test_values(self, first, second):
        self.assertTrue(first > second)

它提供了一個(gè)裝飾器類 @parameterized,源碼如下(版本 0.7.1),主要做了一些初始的校驗(yàn)和參數(shù)解析,并非我們關(guān)注的重點(diǎn),略過(guò)。

我們主要關(guān)注這個(gè)裝飾器類的 expand() 方法,它的文檔注釋中寫(xiě)到:

A "brute force" method of parameterizing test cases. Creates new test cases and injects them into the namespace that the wrapped function is being defined in. Useful for parameterizing tests in subclasses of 'UnitTest', where Nose test generators don't work.

關(guān)鍵的兩個(gè)動(dòng)作是:“creates new test cases(創(chuàng)建新的測(cè)試單元)”和“inject them into the namespace…(注入到原方法的命名空間)”。

關(guān)于第一點(diǎn),它跟 ddt 是相似的,只是一些命名風(fēng)格上的差異,以及參數(shù)的解析及綁定不同,不值得太關(guān)注。

最不同的則是,怎么令新的測(cè)試方法生效?

parameterized 使用的是一種“注入”的方式:

inspect 是個(gè)功能強(qiáng)大的標(biāo)準(zhǔn)庫(kù),在此用于獲取程序調(diào)用棧的信息。前三句代碼的目的是取出 f_locals,它的含義是“l(fā)ocal namespace seen by this frame”,此處 f_locals 指的就是類的局部命名空間。

說(shuō)到局部命名空間,你可能會(huì)想到 locals(),但是,我們之前有文章提到過(guò)“l(fā)ocals() 與 globals() 的讀寫(xiě)問(wèn)題”,locals() 是可讀不可寫(xiě)的,所以這段代碼才用了 f_locals。

3、pytest 如何實(shí)現(xiàn)參數(shù)化?

按慣例先看看上篇文章中的寫(xiě)法:

import pytest
@pytest.mark.parametrize("first,second", [(3,1), (-1,0), (1.5,1.0)])
def test_values(first, second):
    assert(first > second)

首先看到“mark”,pytest 里內(nèi)置了一些標(biāo)簽,例如 parametrize、timeout、skipif、xfail、tryfirst、trylast 等,還支持用戶自定義的標(biāo)簽,可以設(shè)置執(zhí)行條件、分組篩選執(zhí)行,以及修改原測(cè)試行為等等。

用法也是非常簡(jiǎn)單的,然而,其源碼可復(fù)雜多了。我們這里只關(guān)注 parametrize,先看看核心的一段代碼:

根據(jù)傳入的參數(shù)對(duì),它復(fù)制了原測(cè)試方法的調(diào)用信息,存入待調(diào)用的列表里。跟前面分析的兩個(gè)庫(kù)不同,它并沒(méi)有在此創(chuàng)建新的測(cè)試方法,而是復(fù)用了已有的方法。在 parametrize() 所屬的 Metafunc 類往上查找,可以追蹤到 _calls 列表的使用位置:

最終是在 Function 類中執(zhí)行:

好玩的是,在這里我們可以看到幾行神注釋……

閱讀(粗淺涉獵) pytest 的源碼,真的是自討苦吃……不過(guò),依稀大致可以看出,它在實(shí)現(xiàn)參數(shù)化時(shí),使用的是生成器的方案,遍歷一個(gè)參數(shù)則調(diào)用一次測(cè)試方法,而前面的 ddt 和 parameterized 則是一次性把所有參數(shù)解析完,生成 n 個(gè)新的測(cè)試方法,再交給測(cè)試框架去調(diào)度。

對(duì)比一下,前兩個(gè)庫(kù)的思路很清晰,而且由于其設(shè)計(jì)單純是為了實(shí)現(xiàn)參數(shù)化,不像 pytest 有什么標(biāo)記和過(guò)多的抽象設(shè)計(jì),所以更易讀易懂。前兩個(gè)庫(kù)發(fā)揮了 Python 的動(dòng)態(tài)特性,設(shè)置類屬性或者注入局部命名空間,而 pytest 倒像是從什么靜態(tài)語(yǔ)言中借鑒的思路,略顯笨拙。

4、最后小結(jié)

回到標(biāo)題中的問(wèn)題“如何將一個(gè)方法變?yōu)槎鄠€(gè)方法?”除了在參數(shù)化測(cè)試中,不知還有哪些場(chǎng)景會(huì)有此訴求?歡迎留言討論。

本文分析了三個(gè)測(cè)試庫(kù)的裝飾器實(shí)現(xiàn)思路,通過(guò)閱讀源碼,我們可以發(fā)現(xiàn)它們各有千秋,這個(gè)發(fā)現(xiàn)本身還挺有意思。在使用裝飾器時(shí),表面看它們差異不大,但是真功夫的細(xì)節(jié)都隱藏在底下。

源碼分析的意義在于探究其所以然,在這次探究之旅中,讀者們可有什么收獲???

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Function
    +關(guān)注

    關(guān)注

    0

    文章

    14

    瀏覽量

    10332
  • python
    +關(guān)注

    關(guān)注

    58

    文章

    4882

    瀏覽量

    90287
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    強(qiáng)強(qiáng)聯(lián)合:imc FAMOS內(nèi)嵌Python接口,提高分析效率!

    德國(guó)知名車廠工程師首選將Python和imcFAMOS結(jié)合起來(lái)用于分析測(cè)試和測(cè)量數(shù)據(jù)——這是否有意義?事實(shí)上這非常有意義。Python和imcFAMOS可以很好地相互補(bǔ)充。Python
    的頭像 發(fā)表于 03-18 09:05 ?448次閱讀
    強(qiáng)強(qiáng)聯(lián)合:imc FAMOS內(nèi)嵌<b class='flag-5'>Python</b>接口,提高分析效率!

    導(dǎo)熱系數(shù)越高越好?關(guān)于導(dǎo)熱硅膠片的三個(gè)認(rèn)知誤區(qū)

    。本文將揭示三個(gè)最常見(jiàn)的認(rèn)知偏差,幫助您做出更明智的選擇。 誤區(qū)一:導(dǎo)熱系數(shù)越高,散熱效果就一定越好 這可能是最具迷惑性的誤區(qū)。理論上,導(dǎo)熱系數(shù)越高,材料傳導(dǎo)熱量的能力越強(qiáng)。然而在實(shí)際應(yīng)用中,散熱
    發(fā)表于 03-12 13:49

    如何在 Vision Five 2 上安裝 python 庫(kù)?

    這可能是一個(gè)完全愚蠢的問(wèn)題,但我如何在 Vision Five 2 上安裝 python 庫(kù)。 使用該命令后,它給了我這個(gè)錯(cuò)誤。 默認(rèn)為用戶安裝,因?yàn)槠胀ㄕ军c(diǎn)包不可寫(xiě) 錯(cuò)誤:找不到滿足要求
    發(fā)表于 03-06 07:51

    無(wú)法去除 Python VisionFive.i2c 庫(kù)的終端輸出?

    燒的官方最新八月份的 debian 12 的系統(tǒng)。 根據(jù)這個(gè)案例安裝好了 python 環(huán)境和 VisionFive 庫(kù)。 執(zhí)行下面這條代碼: import VisionFive.i2c
    發(fā)表于 02-25 06:13

    駿馬奔騰,芯向未來(lái):SiC功率器件的“三個(gè)必然”與丙午馬年的產(chǎn)業(yè)躍遷

    駿馬奔騰,芯向未來(lái):SiC功率器件的“三個(gè)必然”與丙午馬年的產(chǎn)業(yè)躍遷 日期: 2026年 丙午馬年 除夕 主題: 傾佳電子楊茜“三個(gè)必然”戰(zhàn)略論斷與基本半導(dǎo)體碳化硅技術(shù)的產(chǎn)業(yè)替代邏輯 關(guān)鍵詞
    的頭像 發(fā)表于 02-15 10:33 ?130次閱讀
    駿馬奔騰,芯向未來(lái):SiC功率器件的“<b class='flag-5'>三個(gè)</b>必然”與丙午馬年的產(chǎn)業(yè)躍遷

    altium designer 如何畫(huà)短路兩個(gè)或者三個(gè)網(wǎng)絡(luò)的封裝?

    如何我畫(huà)了一個(gè)天線,有3個(gè)引腳,TX1,TX2,GND, 但實(shí)際上這三個(gè)引腳是連在一起的。我導(dǎo)入pcb后,會(huì)報(bào)DRC警告,這個(gè)該怎么解決?
    發(fā)表于 02-12 19:30

    Python運(yùn)行本地Web服務(wù)并實(shí)現(xiàn)遠(yuǎn)程訪問(wèn)

    本文介紹使用Python搭建本地Web服務(wù)并結(jié)合 ZeroNews 實(shí)現(xiàn)公網(wǎng)訪問(wèn)。
    的頭像 發(fā)表于 02-06 11:39 ?304次閱讀
    <b class='flag-5'>Python</b>運(yùn)行本地Web服務(wù)并<b class='flag-5'>實(shí)現(xiàn)</b>遠(yuǎn)程訪問(wèn)

    三個(gè)經(jīng)典開(kāi)關(guān)電源實(shí)際問(wèn)題解析

    下面三個(gè)關(guān)于多路輸出電源連續(xù)工作模式的問(wèn)題,測(cè)試一下您的電源設(shè)計(jì)知識(shí)。然后核對(duì)您的答案。
    的頭像 發(fā)表于 01-22 16:08 ?3290次閱讀
    <b class='flag-5'>三個(gè)</b>經(jīng)典開(kāi)關(guān)電源實(shí)際問(wèn)題解析

    束管式光纜最簡(jiǎn)單三個(gè)步驟

    束管式光纜的安裝或施工可簡(jiǎn)化為以下三個(gè)核心步驟,確保光纖傳輸性能穩(wěn)定且操作高效: 第一步:路由規(guī)劃與準(zhǔn)備 路徑勘察 確定光纜敷設(shè)路線,避開(kāi)強(qiáng)電磁干擾源(如高壓線)、尖銳物體或易受外力破壞的區(qū)域(如
    的頭像 發(fā)表于 01-07 10:12 ?420次閱讀

    京東關(guān)鍵詞搜索商品列表的Python爬蟲(chóng)實(shí)戰(zhàn)

    京東關(guān)鍵詞搜索商品列表 Python 爬蟲(chóng)實(shí)戰(zhàn) 你想要實(shí)現(xiàn)京東關(guān)鍵詞搜索商品的爬蟲(chóng),我會(huì)從 合規(guī)聲明、環(huán)境準(zhǔn)備、頁(yè)面分析、代碼實(shí)現(xiàn)、反爬優(yōu)化 五個(gè)方面展開(kāi),幫助你完成實(shí)戰(zhàn)項(xiàng)目。 一、前
    的頭像 發(fā)表于 01-04 10:16 ?1194次閱讀

    Python調(diào)用API教程

    個(gè)不同系統(tǒng)之間的信息交互。在這篇文章中,我們將詳細(xì)介紹Python調(diào)用API的方法和技巧。 一、用Requests庫(kù)發(fā)送HTTP請(qǐng)求 使用Python調(diào)用API的第一步是發(fā)送HTTP
    的頭像 發(fā)表于 11-03 09:15 ?1148次閱讀

    未來(lái)工業(yè)AI發(fā)展的三個(gè)必然階段

    與優(yōu)化 能力的深層革命。 未來(lái)十年,工業(yè)AI的發(fā)展將經(jīng)歷三個(gè)清晰的階段:? 智能輔助 → 智能決策 → 自主優(yōu)化 。這次進(jìn)化,構(gòu)成了工業(yè)從“人控機(jī)器”到“機(jī)器共智”的核心路徑。 一、第一階段:智能輔助(AI for Assistance) 時(shí)間窗口:
    的頭像 發(fā)表于 10-27 15:47 ?573次閱讀
    未來(lái)工業(yè)AI發(fā)展的<b class='flag-5'>三個(gè)</b>必然階段

    termux如何搭建python游戲

    模擬,支持通過(guò)APT包管理安裝軟件。搭建Python游戲開(kāi)發(fā)環(huán)境前需完成以下基礎(chǔ)配置: 1. 更換國(guó)內(nèi)源 為提升下載速度,需替換Termux默認(rèn)源為清華源,執(zhí)行以下命令: ```bash
    發(fā)表于 08-29 07:06

    怎么結(jié)合嵌入式,Linux,和FPGA三個(gè)方向達(dá)到一個(gè)均衡發(fā)展?

    在嵌入式領(lǐng)域,不少人都懷揣著讓嵌入式、Linux 和 FPGA 三個(gè)方向實(shí)現(xiàn)均衡發(fā)展的夢(mèng)想,然而實(shí)踐中卻面臨諸多挑戰(zhàn)。就像備受矚目的全棧工程師稚暉君,他從大學(xué)玩單片機(jī)起步,憑借將智能算法融入嵌入式而
    的頭像 發(fā)表于 06-25 10:08 ?1003次閱讀
    怎么結(jié)合嵌入式,Linux,和FPGA<b class='flag-5'>三個(gè)</b>方向達(dá)到一<b class='flag-5'>個(gè)</b>均衡發(fā)展?

    18個(gè)常用的強(qiáng)化學(xué)習(xí)算法整理:從基礎(chǔ)方法到高級(jí)模型的理論技術(shù)與代碼實(shí)現(xiàn)

    本來(lái)轉(zhuǎn)自:DeepHubIMBA本文系統(tǒng)講解從基本強(qiáng)化學(xué)習(xí)方法到高級(jí)技術(shù)(如PPO、A3C、PlaNet等)的實(shí)現(xiàn)原理與編碼過(guò)程,旨在通過(guò)理論結(jié)合代碼的方式,構(gòu)建對(duì)強(qiáng)化學(xué)習(xí)算法的全面理解。為確保內(nèi)容
    的頭像 發(fā)表于 04-23 13:22 ?1756次閱讀
    18<b class='flag-5'>個(gè)</b>常用的強(qiáng)化<b class='flag-5'>學(xué)習(xí)</b>算法整理:從基礎(chǔ)方法到高級(jí)模型的理論技術(shù)與代碼<b class='flag-5'>實(shí)現(xiàn)</b>