test_client/wclient.py
import json
import requests
client = requests.session()
def setup():
response = REST_CLIENT.post(
"https://placeholder.com",
auth=(placeholder, placeholder),
data={"grant_type": "client_credentials"},
)
status_code = response.status_code
if status_code in OK_STATUS:
payload = json.loads(response.content, object_pairs_hook=OrderedDict)
else:
payload = response.text
msg = (
"Status Code %s" % status_code
)
logger.error(msg)
raise ValueError(msg)
return payload["access_token"]
测试文件: 测试客户端/测试客户端.py
import mock
import wclient
@mock.patch("test_client.wclient")
def test_taxes_pitney_bowes_setup_success(resp):
resp.return_value.post.return_value.status_code = "200"
wclient.pitney_bowes_setup()
Status Code <MagicMock name='REST_CLIENT.post().status_code' id='4868492200'>
如何使用mock.patch()模拟模块的方法和属性?我已经阅读了几页堆栈溢出帖子,但我对强制执行魔法模拟的所有不同方法感到困惑。
我尝试过嘲笑:
resp.return_value.post.return_value.status_code
resp.return_value.post.return_value.status_code.return_value
resp.post.return_value.status_code
resp.post.return_value.status_code.return_value
resp.post.status_code
resp.post.status_code.return_value
我认为实际进行模拟的方法有很多种(请参阅Python 中的模拟方法调用中的许多方法)。 我喜欢这样做并且发现简单模拟很容易的方式是:
对于函数:
@patch('module.print', lambda x: None)
对于属性:
@patch('module.cwd', os.path.join(os.getcwd(), "folder"))
这篇博文可能对您有帮助:https://medium.com/uckey/how-mock-patch-decorator-works-in-python-37acd8b78ae。
如果您有更多问题,请告诉我。
编辑: 要添加多个模拟,只需添加另一个属性:
import wclient
@mock.patch("test_client.wclient")
@mock.patch("another_attribute", "value")
@mock.patch("another_function", lambda x, y: x + y)
def test_taxes_pitney_bowes_setup_success(resp):
resp.return_value.post.return_value.status_code = "200"
wclient.pitney_bowes_setup()
同样的情况,有什么解决办法吗?