Python中的Mock
1.前言
微服务架构下,由于各类服务开发进度的不一致,导致联调工作经常会存在不确定性,进而导致项目延期
在实际工作中,为了保证项目进度,我们经常需要针对部分未完成模块及不稳定模块采用Mock方式,以验证已开发完的模块
本篇文章将介绍Python实现Mock的几种常见方式
2.Mock介绍
Mock测试:在测试验证过程中,对于那些尚未完成或不稳定的对象,用一个虚拟对象来替代,以便测试的测试方法
因此,这个虚拟的对象是Mock对象,Mock对象是真实对象在调试期间的代替品
它的优势包含:
·前、后端并行开发
·模拟无法访问的资源
·隔离系统,避免脏数据干扰测试结果
3.1mock
在Python3.3之前使用mock,需要先安装依赖
#安装mock依赖
pip3installmock
项目地址:
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方法的返回值。
#product_impl.py
classProduct(object):
def__init__(self):
pass
defget_product_status_by_id(self,product_id):
"""
通过商品id获取产品信息(Mock)
:return:
"""
#待实现查询数据库的业务逻辑
pass
defbuy_product(self,product_id):
"""
购买产品(真实逻辑)
:return:
"""
#产品信息
#{"id":1,"name":"苹果","num":23}
product=self.get_product_status_by_id(product_id)
ifproduct.get("num")>=1:
result={"status":0,"msg":"购买成功!"}
else:
result={"status":1,"msg":"购买失败,库存不足!"}
returnresult
Mock的步骤如下:
·导入使用mock中的patch方法
·作为测试方法的装饰器,对get_product_status_by_id方法进行Mock,方法参数为Mock对象
·测试方法中,对该Mock对象设置一个返回值
·调用并断言
frommockimportpatch
frommock_.product_implimportProduct
@patch('mock_.product_impl.Product.get_product_status_by_id')
deftest_succuse(mock_get_product_status_by_id):
#Mock方法,指定一个返回值
mock_get_product_status_by_id.return_value={"id":1,"name":"苹果","num":23}
product=Product()
assertproduct.buy_product(1).get("status")==0
需要注意的是,Mock此方法的时候,必须制定该方法的完整路径
使用@patch.object同样能完成Mock,不同的是,@patch.object包含2个参数
第一个参数为该方法所在的类;第二个参数为方法名
frommockimportpatch
frommock_.product_implimportProduct
#Mock一个方法
#@patch.object:对象、方法名
@patch.object(Product,'get_product_status_by_id')
deftest_succuse(mock_get_product_status_by_id):
#Mock方法,指定一个返回值
mock_get_product_status_by_id.return_value={"id":1,"name":"苹果","num":23}
product=Product()
assertproduct.buy_product(1).get("status")==0
3.2unittest.mock
Python3.3之后,mock作为标准库,已经内置到unittest中了
还是以3.1的场景为例,使用unittest编写一个测试用例
Mock步骤如下:
·导入unittest框架中的mock文件
·实例化Product对象
·mock.Mock(return_value=*)方法
·对get_product_status_by_id方法进行Mock
·调用并断言
importunittest
fromunittestimportmock
fromunittest_mock.product_implimportProduct
classTestProduct(unittest.TestCase):
deftest_success(self):
#成功结果
mock_success_value={"id":1,"name":"苹果","num":23}
product=Product()
product.get_product_status_by_id=mock.Mock(return_value=mock_success_value)
#调用实际函数
assertproduct.buy_product(1).get("status")==0
if__name__=="__main__":
unittest.main()
3.3pytest.mock
相比unittest,pytest由于强大的插件支持,用户群体可能更大!
如果项目本身使用的框架是pytest,则Mock更建议使用pytest-mock这个插件
#pytest依赖
pip3installpytest
Mock步骤如下:
·使用pytest编写测试方法,参数为mocker
·实例化Product对象
·使用mocker.patch()方法对get_product_status_by_id方法进行Mock,并设置返回值
·调用并断言
importpytest
frompytest_mock_.product_implimportProduct
deftest_buy_product_success(mocker):
"""
购买成功Mock
:parammocker:
:return:
"""
#实例化一个产品对象
product=Product()
#对Product中的方法的返回值进行Mock
mock_value={"id":1,"name":"苹果","num":23}
#Mock方法
#注意:需要指定方法的完整路径
#mocker.patch的第一个参数必须是模拟对象的具体路径,第二个参数用来指定返回值
product.get_product_status_by_id=mocker.patch("product_impl.Product.get_product_status_by_id",
return_value=mock_value)
#调用购买产品的方法
result=product.buy_product(1)
assertresult.get("status")==0
需要注意的是,mocker.patch方法第一个参数必须是Mock对象的完整路径
4.最后
文中对Python中常见的Mock方案进行了讲解,实际应用中,建议根据项目实际情况进行选型
以上内容为大家介绍了Python中的Mock,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:千锋教育。http://www.mobiletrain.org/
猜你喜欢LIKE
相关推荐HOT
更多>>python中的filter函数功能是什么?
python中的filter函数功能是什么?在python中,面对众多的数据,我们要过滤筛选出我们需要的数据。python中的filter函数就是起到了过滤筛选的作...详情>>
2023-11-10 20:37:27pythontime模块是什么
pythontime模块是什么在python中使用时间,就免不了和time模块打交道,另外两个模块这个暂时先不做介绍。做time模块的使用上,我们可以用它来对...详情>>
2023-11-10 15:53:16python是什么编程语言
python是什么编程语言1、说明是一种面向对象、解释型计算机程序设计语言,由GuidovanRossum于1989年底发明,第一个公开发行版发行于1991年。Pyt...详情>>
2023-11-10 15:21:05python异常处理的两种技巧
python异常处理的两种技巧1、传递异常有时我们会在捕捉到一个异常后重新引发它(传递异常),实现起来很简单,使用不带参数的raise语句即可。deff...详情>>
2023-11-10 14:49:39热门推荐
python中的filter函数功能是什么?
沸python delattr函数如何使用?
热python中pdb模块怎么用?
热Python如何截图保存?
新python中缺少module怎么办?
python strftime和strptime的不同分析
python time.strptime的格式化
python中@contextmanager是什么?
python对象的三要素是什么
pythonGIL在Python多线程的应用
python如何对多个CSV文件进行读取
pythonif嵌套命令如何理解?
python对列表进行永久性或临时排序的方法
python生成器调用方法引发异常