Python中的Mock
1.前言
微服務(wù)架構(gòu)下,由于各類服務(wù)開(kāi)發(fā)進(jìn)度的不一致,導(dǎo)致聯(lián)調(diào)工作經(jīng)常會(huì)存在不確定性,進(jìn)而導(dǎo)致項(xiàng)目延期
在實(shí)際工作中,為了保證項(xiàng)目進(jìn)度,我們經(jīng)常需要針對(duì)部分未完成模塊及不穩(wěn)定模塊采用Mock方式,以驗(yàn)證已開(kāi)發(fā)完的模塊
本篇文章將介紹Python實(shí)現(xiàn)Mock的幾種常見(jiàn)方式
2.Mock介紹
Mock測(cè)試:在測(cè)試驗(yàn)證過(guò)程中,對(duì)于那些尚未完成或不穩(wěn)定的對(duì)象,用一個(gè)虛擬對(duì)象來(lái)替代,以便測(cè)試的測(cè)試方法
因此,這個(gè)虛擬的對(duì)象是Mock對(duì)象,Mock對(duì)象是真實(shí)對(duì)象在調(diào)試期間的代替品
它的優(yōu)勢(shì)包含:
·前、后端并行開(kāi)發(fā)
·模擬無(wú)法訪問(wèn)的資源
·隔離系統(tǒng),避免臟數(shù)據(jù)干擾測(cè)試結(jié)果
3.1mock
在Python3.3之前使用mock,需要先安裝依賴
#安裝mock依賴
pip3installmock
項(xiàng)目地址:
https://github.com/testing-cabal/mock
假設(shè)Product類中有2個(gè)方法
·get_product_status_by_id
·buy_product
其中,get_product_status_by_id方法還沒(méi)有實(shí)現(xiàn);buy_product方法依賴于get_product_status_by_id方法的返回值。
#product_impl.py
classProduct(object):
def__init__(self):
pass
defget_product_status_by_id(self,product_id):
"""
通過(guò)商品id獲取產(chǎn)品信息(Mock)
:return:
"""
#待實(shí)現(xiàn)查詢數(shù)據(jù)庫(kù)的業(yè)務(wù)邏輯
pass
defbuy_product(self,product_id):
"""
購(gòu)買(mǎi)產(chǎn)品(真實(shí)邏輯)
:return:
"""
#產(chǎn)品信息
#{"id":1,"name":"蘋(píng)果","num":23}
product=self.get_product_status_by_id(product_id)
ifproduct.get("num")>=1:
result={"status":0,"msg":"購(gòu)買(mǎi)成功!"}
else:
result={"status":1,"msg":"購(gòu)買(mǎi)失敗,庫(kù)存不足!"}
returnresult
Mock的步驟如下:
·導(dǎo)入使用mock中的patch方法
·作為測(cè)試方法的裝飾器,對(duì)get_product_status_by_id方法進(jìn)行Mock,方法參數(shù)為Mock對(duì)象
·測(cè)試方法中,對(duì)該Mock對(duì)象設(shè)置一個(gè)返回值
·調(diào)用并斷言
frommockimportpatch
frommock_.product_implimportProduct
@patch('mock_.product_impl.Product.get_product_status_by_id')
deftest_succuse(mock_get_product_status_by_id):
#Mock方法,指定一個(gè)返回值
mock_get_product_status_by_id.return_value={"id":1,"name":"蘋(píng)果","num":23}
product=Product()
assertproduct.buy_product(1).get("status")==0
需要注意的是,Mock此方法的時(shí)候,必須制定該方法的完整路徑
使用@patch.object同樣能完成Mock,不同的是,@patch.object包含2個(gè)參數(shù)
第一個(gè)參數(shù)為該方法所在的類;第二個(gè)參數(shù)為方法名
frommockimportpatch
frommock_.product_implimportProduct
#Mock一個(gè)方法
#@patch.object:對(duì)象、方法名
@patch.object(Product,'get_product_status_by_id')
deftest_succuse(mock_get_product_status_by_id):
#Mock方法,指定一個(gè)返回值
mock_get_product_status_by_id.return_value={"id":1,"name":"蘋(píng)果","num":23}
product=Product()
assertproduct.buy_product(1).get("status")==0
3.2unittest.mock
Python3.3之后,mock作為標(biāo)準(zhǔn)庫(kù),已經(jīng)內(nèi)置到unittest中了
還是以3.1的場(chǎng)景為例,使用unittest編寫(xiě)一個(gè)測(cè)試用例
Mock步驟如下:
·導(dǎo)入unittest框架中的mock文件
·實(shí)例化Product對(duì)象
·mock.Mock(return_value=*)方法
·對(duì)get_product_status_by_id方法進(jìn)行Mock
·調(diào)用并斷言
importunittest
fromunittestimportmock
fromunittest_mock.product_implimportProduct
classTestProduct(unittest.TestCase):
deftest_success(self):
#成功結(jié)果
mock_success_value={"id":1,"name":"蘋(píng)果","num":23}
product=Product()
product.get_product_status_by_id=mock.Mock(return_value=mock_success_value)
#調(diào)用實(shí)際函數(shù)
assertproduct.buy_product(1).get("status")==0
if__name__=="__main__":
unittest.main()
3.3pytest.mock
相比unittest,pytest由于強(qiáng)大的插件支持,用戶群體可能更大!
如果項(xiàng)目本身使用的框架是pytest,則Mock更建議使用pytest-mock這個(gè)插件
#pytest依賴
pip3installpytest
Mock步驟如下:
·使用pytest編寫(xiě)測(cè)試方法,參數(shù)為mocker
·實(shí)例化Product對(duì)象
·使用mocker.patch()方法對(duì)get_product_status_by_id方法進(jìn)行Mock,并設(shè)置返回值
·調(diào)用并斷言
importpytest
frompytest_mock_.product_implimportProduct
deftest_buy_product_success(mocker):
"""
購(gòu)買(mǎi)成功Mock
:parammocker:
:return:
"""
#實(shí)例化一個(gè)產(chǎn)品對(duì)象
product=Product()
#對(duì)Product中的方法的返回值進(jìn)行Mock
mock_value={"id":1,"name":"蘋(píng)果","num":23}
#Mock方法
#注意:需要指定方法的完整路徑
#mocker.patch的第一個(gè)參數(shù)必須是模擬對(duì)象的具體路徑,第二個(gè)參數(shù)用來(lái)指定返回值
product.get_product_status_by_id=mocker.patch("product_impl.Product.get_product_status_by_id",
return_value=mock_value)
#調(diào)用購(gòu)買(mǎi)產(chǎn)品的方法
result=product.buy_product(1)
assertresult.get("status")==0
需要注意的是,mocker.patch方法第一個(gè)參數(shù)必須是Mock對(duì)象的完整路徑
4.最后
文中對(duì)Python中常見(jiàn)的Mock方案進(jìn)行了講解,實(shí)際應(yīng)用中,建議根據(jù)項(xiàng)目實(shí)際情況進(jìn)行選型
以上內(nèi)容為大家介紹了Python中的Mock,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://www.mobiletrain.org/

猜你喜歡LIKE
相關(guān)推薦HOT
更多>>
python中的filter函數(shù)功能是什么?
python中的filter函數(shù)功能是什么?在python中,面對(duì)眾多的數(shù)據(jù),我們要過(guò)濾篩選出我們需要的數(shù)據(jù)。python中的filter函數(shù)就是起到了過(guò)濾篩選的作...詳情>>
2023-11-10 20:37:27
pythontime模塊是什么
pythontime模塊是什么在python中使用時(shí)間,就免不了和time模塊打交道,另外兩個(gè)模塊這個(gè)暫時(shí)先不做介紹。做time模塊的使用上,我們可以用它來(lái)對(duì)...詳情>>
2023-11-10 15:53:16
python是什么編程語(yǔ)言
python是什么編程語(yǔ)言1、說(shuō)明是一種面向?qū)ο蟆⒔忉屝陀?jì)算機(jī)程序設(shè)計(jì)語(yǔ)言,由GuidovanRossum于1989年底發(fā)明,第一個(gè)公開(kāi)發(fā)行版發(fā)行于1991年。Pyt...詳情>>
2023-11-10 15:21:05
python異常處理的兩種技巧
python異常處理的兩種技巧1、傳遞異常有時(shí)我們會(huì)在捕捉到一個(gè)異常后重新引發(fā)它(傳遞異常),實(shí)現(xiàn)起來(lái)很簡(jiǎn)單,使用不帶參數(shù)的raise語(yǔ)句即可。deff...詳情>>
2023-11-10 14:49:39熱門(mén)推薦
python中的filter函數(shù)功能是什么?
沸python delattr函數(shù)如何使用?
熱python中pdb模塊怎么用?
熱Python如何截圖保存?
新python?中缺少module怎么辦?
python strftime和strptime的不同分析
python time.strptime的格式化
python中@contextmanager是什么?
python對(duì)象的三要素是什么
pythonGIL在Python多線程的應(yīng)用
python如何對(duì)多個(gè)CSV文件進(jìn)行讀取
pythonif嵌套命令如何理解?
python對(duì)列表進(jìn)行永久性或臨時(shí)排序的方法
python生成器調(diào)用方法引發(fā)異常
技術(shù)干貨







快速通道 更多>>
-
課程介紹
點(diǎn)擊獲取大綱 -
就業(yè)前景
查看就業(yè)薪資 -
學(xué)習(xí)費(fèi)用
了解課程價(jià)格 -
優(yōu)惠活動(dòng)
領(lǐng)取優(yōu)惠券 -
學(xué)習(xí)資源
領(lǐng)3000G教程 -
師資團(tuán)隊(duì)
了解師資團(tuán)隊(duì) -
實(shí)戰(zhàn)項(xiàng)目
獲取項(xiàng)目源碼 -
開(kāi)班地區(qū)
查看來(lái)校路線