我正在尝试测试受保护的视图。未经身份验证的用户将重定向到登录页面。当我运行测试时,它会引发django.cose.exceptions.PermissionDenied
,这很正常,但是如何编写而不会失败,又如何测试重定向是否正确?
这就是我所做的。
class TestProtectedRegistrationListView:
"""
Verify registration views are protected from unauthenticated access.
"""
def test_access_url(
self, user: settings.AUTH_USER_MODEL, request_factory: RequestFactory
):
view = RegistrationListView.as_view()
request = request_factory.get("/admin_staff/registrations")
request.user = user
resp = view(request)
assert resp == PermissionDenied
答案 0 :(得分:0)
以下是感兴趣的解决方案(@wencakisa正确建议):
def test_authenticated_non_staff(self, rf):
req = rf.get(reverse("dashboard.staff:lang-create"))
user = UserFactory()
assert False is user.is_staff
req.user = user
with pytest.raises(PermissionDenied):
views.LangCreateView.as_view()(req)
为了记忆并回答我自己的愚蠢评论,测试响应status_code
没有任何意义,因为我们提出了例外情况。