日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
Python中Mock到底該怎么玩?一篇文章告訴你

本文轉(zhuǎn)載自微信公眾號(hào)「AirPython」,作者星安果 。轉(zhuǎn)載本文請(qǐng)聯(lián)系A(chǔ)irPython公眾號(hào)。  

公司主營(yíng)業(yè)務(wù):網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)推出旅順口免費(fèi)做網(wǎng)站回饋大家。

 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.1 mock

在 Python 3.3 之前使用 mock,需要先安裝依賴

 
 
 
  1. # 安裝mock依賴 
  2.  
  3. pip3 install mock 

項(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 方法的返回值

 
 
 
  1. # product_impl.py 
  2.  
  3. class Product(object): 
  4.  
  5.     def __init__(self): 
  6.         pass 
  7.  
  8.     def get_product_status_by_id(self, product_id): 
  9.         """ 
  10.         通過(guò)商品id獲取產(chǎn)品信息(Mock) 
  11.         :return: 
  12.         """ 
  13.         # 待實(shí)現(xiàn)查詢數(shù)據(jù)庫(kù)的業(yè)務(wù)邏輯 
  14.         pass 
  15.  
  16.     def buy_product(self, product_id): 
  17.         """ 
  18.         購(gòu)買產(chǎn)品(真實(shí)邏輯) 
  19.         :return: 
  20.         """ 
  21.         # 產(chǎn)品信息 
  22.         # {"id":1,"name":"蘋(píng)果","num":23} 
  23.         product = self.get_product_status_by_id(product_id) 
  24.  
  25.         if product.get("num") >= 1: 
  26.             result = {"status": 0, "msg": "購(gòu)買成功!"} 
  27.         else: 
  28.             result = {"status": 1, "msg": "購(gòu)買失敗,庫(kù)存不足!"} 
  29.  
  30.         return result 

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)用并斷言
 
 
 
  1. from mock import patch 
  2. from mock_.product_impl import Product 
  3.  
  4. @patch('mock_.product_impl.Product.get_product_status_by_id') 
  5. def test_succuse(mock_get_product_status_by_id): 
  6.     # Mock方法,指定一個(gè)返回值 
  7.     mock_get_product_status_by_id.return_value = {"id": 1, "name": "蘋(píng)果", "num": 23} 
  8.  
  9.     product = Product() 
  10.  
  11.     assert product.buy_product(1).get("status") == 0 

需要注意的是,Mock 此方法的時(shí)候,必須制定該方法的完整路徑

使用 @patch.object 同樣能完成 Mock,不同的是,@patch.object 包含 2 個(gè)參數(shù)

第一個(gè)參數(shù)為該方法所在的類;第二個(gè)參數(shù)為方法名

 
 
 
  1. from mock import patch 
  2.  
  3. from mock_.product_impl import Product 
  4.  
  5. # Mock一個(gè)方法 
  6. # @patch.object:對(duì)象、方法名 
  7. @patch.object(Product, 'get_product_status_by_id') 
  8. def test_succuse(mock_get_product_status_by_id): 
  9.     # Mock方法,指定一個(gè)返回值 
  10.     mock_get_product_status_by_id.return_value = {"id": 1, "name": "蘋(píng)果", "num": 23} 
  11.  
  12.     product = Product() 
  13.  
  14.     assert product.buy_product(1).get("status") == 0 

3.2 unittest.mock

Python 3.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)用并斷言
 
 
 
  1. import unittest 
  2. from unittest import mock 
  3.  
  4. from unittest_mock.product_impl import Product 
  5.  
  6. class TestProduct(unittest.TestCase): 
  7.  
  8.     def test_success(self): 
  9.         # 成功結(jié)果 
  10.         mock_success_value = {"id": 1, "name": "蘋(píng)果", "num": 23} 
  11.  
  12.         product = Product() 
  13.  
  14.         product.get_product_status_by_id = mock.Mock(return_value=mock_success_value) 
  15.  
  16.         # 調(diào)用實(shí)際函數(shù) 
  17.         assert product.buy_product(1).get("status") == 0 
  18.  
  19. if __name__ == "__main__": 
  20.     unittest.main() 

3.3 pytest.mock

相比 unittest,pytest 由于強(qiáng)大的插件支持,用戶群體可能更大!

如果項(xiàng)目本身使用的框架是 pytest,則 Mock 更建議使用 pytest-mock 這個(gè)插件

 
 
 
  1. # pytest依賴 
  2. pip3 install pytest 

Mock 步驟如下:

  • 使用 pytest 編寫(xiě)測(cè)試方法,參數(shù)為 mocker
  • 實(shí)例化 Product 對(duì)象
  • 使用 mocker.patch() 方法對(duì) get_product_status_by_id 方法進(jìn)行 Mock,并設(shè)置返回值
  • 調(diào)用并斷言
 
 
 
  1. import pytest 
  2.  
  3. from pytest_mock_.product_impl import Product 
  4.  
  5. def test_buy_product_success(mocker): 
  6.     """ 
  7.     購(gòu)買成功Mock 
  8.     :param mocker: 
  9.     :return: 
  10.     """ 
  11.     # 實(shí)例化一個(gè)產(chǎn)品對(duì)象 
  12.     product = Product() 
  13.  
  14.     # 對(duì)Product中的方法的返回值進(jìn)行Mock 
  15.     mock_value = {"id": 1, "name": "蘋(píng)果", "num": 23} 
  16.  
  17.     # Mock方法 
  18.     # 注意:需要指定方法的完整路徑 
  19.     # mocker.patch 的第一個(gè)參數(shù)必須是模擬對(duì)象的具體路徑,第二個(gè)參數(shù)用來(lái)指定返回值 
  20.     product.get_product_status_by_id = mocker.patch("product_impl.Product.get_product_status_by_id", 
  21.                                                     return_value=mock_value) 
  22.  
  23.     # 調(diào)用購(gòu)買產(chǎn)品的方法 
  24.     result = product.buy_product(1) 
  25.  
  26.     assert result.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)行選型


網(wǎng)站欄目:Python中Mock到底該怎么玩?一篇文章告訴你
當(dāng)前地址:http://www.5511xx.com/article/dpejcej.html