Aar*_*ron 17 python django mocking
我正在使用Michael Foord编写的模拟库来帮助我测试django应用程序.
我想测试我正在设置我的查询,但我认为我不需要实际访问数据库,所以我试图模拟查询.
我可以很好地模拟查询的第一部分,但是当我链接其他内容时,我没有得到我想要的结果.
功能:
@staticmethod def get_policies(policy_holder, current_user): if current_user.agency: return Policy.objects.filter(policy_holder=policy_holder, version__agency=current_user.agency).distinct() else: return Policy.objects.filter(policy_holder=policy_holder)
和我的测试:第一个断言通过,第二个断言失败.
def should_get_policies_for_agent__user(self): with mock.patch.object(policy_models.Policy, "objects") as query_mock: user_mock = mock.Mock() user_mock.agency = "1234" policy_models.Policy.get_policies("policy_holder", user_mock) self.assertEqual(query_mock.method_calls, [("filter", (), { 'policy_holder': "policy_holder", 'version__agency': user_mock.agency, })]) self.assertTrue(query_mock.distinct.called)
我很确定问题是初始query_mock在调用.filter()之后返回一个新的模拟,但我不知道如何捕获新的模拟并确保调用.distinct().
有没有更好的方法来测试我想要的东西?我正在努力确保调用正确的查询.
Mat*_*son 21
每个模拟对象都保留在调用它时返回的模拟对象.您可以使用模拟对象的return_value属性来获取它.
以你为例,
self.assertTrue(query_mock.distinct.called)
Run Code Online (Sandbox Code Playgroud)
在你的mock上没有调用distinct,它是在你的mock的filter方法的返回值上调用的,所以你可以断言,通过这样做调用distinct:
self.assertTrue(query_mock.filter.return_value.distinct.called)
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
3807 次 |
最近记录: |