国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Python 中 Mock 到底該怎么玩?一篇文章告訴你

開發 后端
微服務架構下,由于各類服務開發進度的不一致,導致聯調工作經常會存在不確定性,進而導致項目延期,在實際工作中,為了保證項目進度,我們經常需要針對部分未完成模塊及不穩定模塊采用 Mock 方式,以驗證已開發完的模塊。 本篇文章將介紹 Python 實現 Mock 的幾種常見方式

[[377066]]

本文轉載自微信公眾號「AirPython」,作者星安果 。轉載本文請聯系AirPython公眾號。  

 1. 前言

微服務架構下,由于各類服務開發進度的不一致,導致聯調工作經常會存在不確定性,進而導致項目延期

在實際工作中,為了保證項目進度,我們經常需要針對部分未完成模塊及不穩定模塊采用 Mock 方式,以驗證已開發完的模塊

本篇文章將介紹 Python 實現 Mock 的幾種常見方式

2. Mock 介紹

Mock 測試:在測試驗證過程中,對于那些尚未完成或不穩定的對象,用一個虛擬對象來替代,以便測試的測試方法

因此,這個虛擬的對象是 Mock 對象,Mock 對象是真實對象在調試期間的代替品

它的優勢包含:

  • 前、后端并行開發
  • 模擬無法訪問的資源
  • 隔離系統,避免臟數據干擾測試結果

3.1 mock

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

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

項目地址:

https://github.com/testing-cabal/mock

假設 Product 類中有 2 個方法

  • get_product_status_by_id
  • buy_product

其中,get_product_status_by_id 方法還沒有實現;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.         通過商品id獲取產品信息(Mock) 
  11.         :return
  12.         ""
  13.         # 待實現查詢數據庫的業務邏輯 
  14.         pass 
  15.  
  16.     def buy_product(self, product_id): 
  17.         ""
  18.         購買產品(真實邏輯) 
  19.         :return
  20.         ""
  21.         # 產品信息 
  22.         # {"id":1,"name":"蘋果","num":23} 
  23.         product = self.get_product_status_by_id(product_id) 
  24.  
  25.         if product.get("num") >= 1: 
  26.             result = {"status": 0, "msg""購買成功!"
  27.         else
  28.             result = {"status": 1, "msg""購買失敗,庫存不足!"
  29.  
  30.         return result 

Mock 的步驟如下:

  • 導入使用 mock 中的 patch 方法
  • 作為測試方法的裝飾器,對 get_product_status_by_id 方法進行 Mock,方法參數為 Mock 對象
  • 測試方法中,對該 Mock 對象設置一個返回值
  • 調用并斷言
  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方法,指定一個返回值 
  7.     mock_get_product_status_by_id.return_value = {"id": 1, "name""蘋果""num": 23} 
  8.  
  9.     product = Product() 
  10.  
  11.     assert product.buy_product(1).get("status") == 0 

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

使用 @patch.object 同樣能完成 Mock,不同的是,@patch.object 包含 2 個參數

第一個參數為該方法所在的類;第二個參數為方法名

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

3.2 unittest.mock

Python 3.3 之后,mock 作為標準庫,已經內置到 unittest 中了

還是以 3.1 的場景為例,使用 unittest 編寫一個測試用例

Mock 步驟如下:

  • 導入 unittest 框架中的 mock 文件
  • 實例化 Product 對象
  • mock.Mock(return_value=*) 方法
  • 對 get_product_status_by_id 方法進行 Mock
  • 調用并斷言
  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.         # 成功結果 
  10.         mock_success_value = {"id": 1, "name""蘋果""num": 23} 
  11.  
  12.         product = Product() 
  13.  
  14.         product.get_product_status_by_id = mock.Mock(return_value=mock_success_value) 
  15.  
  16.         # 調用實際函數 
  17.         assert product.buy_product(1).get("status") == 0 
  18.  
  19. if __name__ == "__main__"
  20.     unittest.main() 

3.3 pytest.mock

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

如果項目本身使用的框架是 pytest,則 Mock 更建議使用 pytest-mock 這個插件

  1. # pytest依賴 
  2. pip3 install pytest 

Mock 步驟如下:

  • 使用 pytest 編寫測試方法,參數為 mocker
  • 實例化 Product 對象
  • 使用 mocker.patch() 方法對 get_product_status_by_id 方法進行 Mock,并設置返回值
  • 調用并斷言
  1. import pytest 
  2.  
  3. from pytest_mock_.product_impl import Product 
  4.  
  5. def test_buy_product_success(mocker): 
  6.     ""
  7.     購買成功Mock 
  8.     :param mocker: 
  9.     :return
  10.     ""
  11.     # 實例化一個產品對象 
  12.     product = Product() 
  13.  
  14.     # 對Product中的方法的返回值進行Mock 
  15.     mock_value = {"id": 1, "name""蘋果""num": 23} 
  16.  
  17.     # Mock方法 
  18.     # 注意:需要指定方法的完整路徑 
  19.     # mocker.patch 的第一個參數必須是模擬對象的具體路徑,第二個參數用來指定返回值 
  20.     product.get_product_status_by_id = mocker.patch("product_impl.Product.get_product_status_by_id"
  21.                                                     return_value=mock_value) 
  22.  
  23.     # 調用購買產品的方法 
  24.     result = product.buy_product(1) 
  25.  
  26.     assert result.get("status") == 0 

需要注意的是,mocker.patch 方法第一個參數必須是 Mock 對象的完整路徑

4. 最后

文中對 Python 中常見的 Mock 方案進行了講解,實際應用中,建議根據項目實際情況進行選型

 

責任編輯:武曉燕 來源: AirPython
相關推薦

2022-02-18 00:13:53

JavaScript編程語言數組

2021-11-04 10:34:02

JavaScript繼承編程

2019-07-28 20:15:07

2023-11-01 15:52:35

2019-08-13 09:00:01

內網外網通信

2019-10-17 19:15:22

jQueryJavaScript前端

2020-11-13 08:14:28

JavaScript

2021-02-19 19:35:53

SVG 形狀元素

2023-06-21 00:10:17

JSONWeb服務器JavaScript

2020-10-09 08:15:11

JsBridge

2021-02-24 10:14:04

PythonClassPython基礎

2021-05-18 09:00:28

Pythonclass

2021-11-17 10:11:08

PythonLogging模塊

2021-11-10 09:19:41

PythonShutil模塊

2019-09-24 14:19:12

PythonC語言文章

2021-05-15 09:18:04

Python進程

2019-09-11 08:52:24

MVCMVPMVVM

2021-02-17 20:40:22

SVG圖像模式

2021-03-02 18:35:27

SVG開發空間

2019-02-26 15:22:14

MySQL命令數據庫
點贊
收藏

51CTO技術棧公眾號

国产福利小视频在线观看| 欧美一区二区影视| 久久奇米777| 精品欧美日韩精品| 波多野结衣av一区二区全免费观看| 精品国产污污免费网站入口| 日本不卡一区二区三区| 成年女人在线看片| 国产情侣第一页| 久久国产精品免费视频| 久久久精品日韩欧美| 成人香蕉社区| 国产国产国产国产国产国产| 91精品久久久久久久久久久| 在线看日本不卡| 国产毛片一区| 九色porny自拍视频在线观看| 18视频在线观看娇喘| 亚洲美女自拍视频| 91麻豆蜜桃一区二区三区| 国产劲爆久久| 午夜免费性福利| 成人动漫视频在线观看完整版| 欧美日韩激情一区二区三区| 日本成人在线视频网站| 在线播放成人| 麻豆电影传媒二区| 成人国产一区二区| 亚洲国产精品字幕| 91麻豆免费在线观看| 国产va免费精品观看精品视频 | 丝袜+亚洲+另类+欧美+变态| 亚洲字幕在线观看| 精品人伦一区二区色婷婷| 不卡av在线免费观看| 亚洲精品播放| 国产黄色在线网站| 日本精品www| 91最新在线免费观看| 亚洲韩国青草视频| 国产精品久久久久国产精品日日| 欧美成人高清| 国产另类xxxxhd高清| 美女免费免费看网站| 久久伊人一区| 欧美精品免费播放| 欧美亚洲动漫精品| bt欧美亚洲午夜电影天堂| 欧美岛国激情| 日韩免费电影| 在线看三级网站视频| www.亚洲一区二区| 国产精品美乳在线观看| 日韩精品亚洲视频| 亚洲无人区一区| 久久99久久久欧美国产| 九九免费精品视频在线观看| 国产探花在线观看| 国内在线高清免费视频| 一区二区精品免费视频| 国产精品扒开腿爽爽爽视频| 亚洲成人精品视频在线观看| 亚洲美女在线国产| 国产自产视频一区二区三区| 欧美中文一区二区| 另类中文字幕国产精品| 精品久久久久一区二区三区| 久久综合色视频| 国产精品国产三级欧美二区| 欧美老少配视频| 91麻豆精品91久久久久同性| 日韩一区在线看| 国内欧美视频一区二区| 亚洲国产精品日韩专区av有中文| 欧美高清你懂的| 尤物视频在线免费观看| 日本超碰在线观看| 特级黄色录像片| 亚洲字幕一区二区| 精品中文字幕视频| 亚洲高清久久久久久| 欧美日韩在线看| 久久久久国产精品厨房| 免费高清视频精品| 亚洲91久久| 高清欧美性猛交xxxx黑人猛| 在线女人免费视频| 欧美性天天影视| 香蕉视频色版| 欧美日韩大尺度| 天天干天天色天天爽| 国产视频在线观看一区| 欧美一区二区三区免费观看| 亚洲视频在线观看视频| 91精品国产色综合久久ai换脸| 亚洲一区二区在线视频| 久久综合九色综合97_久久久| 日韩成人一区二区三区在线观看| 欧美韩日高清| 日韩成人av在线资源| 亚洲成人a级片| 24小时免费看片在线观看| 男人的天堂av高清在线| 激情六月丁香| 免费观看成人网| 国产成人亚洲综合无码| 日韩国产精品一区二区三区| 91在线播放视频| 国产精品一区二区久久精品| 国内精品久久久久影院 日本资源 国内精品久久久久伊人av | 轻点好疼好大好爽视频| 蜜桃精品久久久久久久免费影院| 国产精品丝袜白浆摸在线| 欧美黑人性视频| 三级精品视频久久久久| 日韩极品精品视频免费观看| 欧美色综合天天久久综合精品| 亚洲一区二区三区三| 国产精品国产三级国产| 91蜜桃视频在线| 成人激情综合网站| 国产成人av电影免费在线观看| 久久99精品久久久久久久久久久久| 性娇小13――14欧美| 亚洲国产国产亚洲一二三| 亚洲综合自拍| 中文乱码免费一区二区三区下载| 久久综合电影| 欧美大黑bbbbbbbbb在线| 日韩精品午夜| 日韩一区二区在线免费| 成人黄色小视频| 日韩在线精品| 99久久.com| 亚洲精品国产偷自在线观看| 国产精品久久久久久久| 日本道不卡免费一区| 欧美精品一二| 亚洲啊v在线观看| 欧美日韩理论| 亚洲精品韩国| 美日韩精品视频| 美女在线观看视频一区二区| 激情综合网av| www.日本不卡| 久久理论电影网| 国产精品视频九色porn| 最新热久久免费视频| 亚洲一线二线三线视频| 亚洲福利一二三区| 色综合天天综合狠狠| 欧美日韩精品一区二区三区蜜桃 | 中文字幕一区二区三区四区五区人 | 久久9999免费视频| 精品成人18| 超碰地址久久| 午夜a一级毛片亚洲欧洲| 欧美日韩在线网站| 国产精品mm| 美女黄色成人网| 国产成人亚洲综合a∨婷婷图片| 99久久综合99久久综合网站| 国产精品美日韩| 性感美女久久精品| 51久久夜色精品国产麻豆| 亚洲高清久久网| 久久中文字幕视频| 国产精品久久久久9999| 国产亚洲自拍偷拍| 亚洲av综合色区| 香蕉视频网站入口| 色视频www在线播放国产| 天堂а√在线官网| 成人欧美大片| 日韩在线精品强乱中文字幕| 不卡av一区二区| 国产乱码精品| www.欧美色图| 亚洲国产美女搞黄色| 91精品国产色综合久久不卡蜜臀 | 不卡影院一区二区| www.成人69.com| 国产高清视频在线观看| 国产中文在线播放| 日本亚洲视频| 欧美高清视频手机在在线| 日日噜噜夜夜狠狠视频欧美人 | 亚洲一区二区三区精品在线观看| 成人免费性视频| 日本调教视频在线观看| 日韩欧美小视频| 天堂久久午夜av| 欧美视频二区欧美影视| 日韩成人a**站| 美腿丝袜亚洲三区| 国产欧美一区二区在线观看| 欧美亚洲国产怡红院影院| 日韩中文字在线| 51国产成人精品午夜福中文下载| 六月婷婷激情网|