我想嘲笑以下CanonPerson
模型
def compute(self, is_send_emails, test_email_address):
cpses = CanonPerson.objects.filter(persons__vpd=6,
persons__country="United States",
persons__role__icontains=';IX;').prefetch_related("persons").using("global")
for cp in cpses:
...
我很遗憾如何模仿CanonPerson.objects.filter
给我一个可交换的集合,以便我可以继续。
这是我到目前为止所做的:
def test_X_count(self):
with mock.patch('apps.dbank.models.CanonPerson.objects.filter') as canon_patch:
mock_cp = mock.MagicMock(spec=CanonPerson)
mock_person = mock.MagicMock(spec=Person)
mock_person.vpd = 6
mock_cp.country = "United States"
mock_cp.role = ";IX;"
mock_cp.persons.add(mock_person)
canon_patch.objects.filter.return_value = [mock_cp] // ???
oi = OptinInvites()
oi.compute(False, None)
oi.get_most_recent_email.assert_called_once_with(1)
在计算功能中,我可以看到cpses
是MagicMock类型。
但是它不可迭代,后面有for loop
,只是跳过它。
我想通过将返回值设置为[mock_cp]
我会创建一个可迭代列表吗?
答案 0 :(得分:6)
您将返回值指定给canon_patch
的行略有错误。你在哪里:
canon_patch.objects.filter.return_value = [mock_cp]
应该是:
canon_patch.return_value = [mock_cp]
canon_patch
已经是' objects.filter'的模拟。
如果您拨打[mock_cp]
,则原始行会返回CanonPerson.objects.filter.objects.filter()
。
如果您确实想要修补CanonPerson
模型,那么您的补丁线应如下所示:
with mock.patch('apps.dbank.models.CanonPerson') as canon_patch:
您可能还会发现需要在正在使用的位置模拟它,而不是从中导入它的位置。因此,假设您在名为CanonPerson
的模块中使用my_module
,则测试中的修补程序代码可能如下所示:
with mock.patch('my_module.CanonPerson') as canon_patch: