本文介绍: 通过上述代码,提供pytest中mock的2中方法:第一种中的第一个参数是通过object的方式进行查找关于Mock_weather的类,然后在找到下面的需要mock的对象方法名称,第2个参数表示mock的值。第二中方法中的第一个参数是通过完整的路径进行找到需要mock的对象,第2个参数是mock的值。通过执行发现,两种方法都是可以mock成功的。这里的mock和unittest的mock基本上都是一样的,唯一的区别在于pytest.mock需要导入mock对象的详细路径。
这里的mock和unittest的mock基本上都是一样的,唯一的区别在于pytest.mock需要导入mock对象的详细路径。
# weateher_r.py
class Mock_weather():
def weather(self):
'''天气接口'''
pass
def weather_result(self):
'''模拟天气接口'''
result = self.weather()
if result['result'] == '雪':
print('下雪了!!!')
elif result['result'] == '雨':
print('下雨了!!!')
elif result['result'] == '晴天':
print('晴天!!!!')
else:
print('返回值错误!')
return result['status']
先将需要模拟的天气接口,以及需要模拟的场景的代码写好,然后在进行遵循pytest的用例规范进行书写关于mock的测试用例
# test_01.py
import pytest
from test_01.weather_r import Mock_weather
def test_01(mocker):
# 实例化
p = Mock_weather()
moke_value = {'result': "雪", 'status': '下雪了!'}
# 通过object的方式进行查找需要mock的对象
p.weather = mocker.patch.object(Mock_weather, "weather", return_value=moke_value)
result =p.weather_result()
assert result=='下雪了!'
def test_02(mocker):
# 实例化
product = Mock_weather()
# Mock的返回值
mock_value = {'result': "雨", 'status': '下雨了!'}
# 第一个参数必须是模拟mock对象的完整路径
product.weather = mocker.patch('test_01.weather_r.Mock_weather.weather',return_value=mock_value)
result = product.weather_result()
assert result=='下雨了!'
if __name__ == '__main__':
pytest.main(['-vs'])
通过上述代码,提供pytest中mock的2中方法:第一种中的第一个参数是通过object的方式进行查找关于Mock_weather的类,然后在找到下面的需要mock的对象方法名称,第2个参数表示mock的值。
第二中方法中的第一个参数是通过完整的路径进行找到需要mock的对象,第2个参数是mock的值。通过执行发现,两种方法都是可以mock成功的
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!
原文地址:https://blog.csdn.net/NHB234567/article/details/134736330
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_24618.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。