【发布时间】:2015-02-23 07:54:11
【问题描述】:
我有一个带有login_required 装饰器的页面,我想测试是否使用了正确的模板。在stackoverflow上,我找到了单元测试的授权方法,但对我来说它由于某种原因不起作用。这是我的测试:
from django.test import TestCase
from django.test import Client
import base64
class TestUsingCorrectTemplates(TestCase):
def test_correct_classroom_template_used(self):
auth_headers = {'HTTP_AUTHORIZATION': 'Basic '+base64.b64encode('admin@dot.com:admin')}
c = Client()
response = c.get('/classroom/', **auth_headers)
self.assertEqual(response.status_code, 200)
self.assertTemplateUsed(response,'classroom.html')
还想提一下,使用 OpenId/AllAuth 处理的授权并且没有/login 页面,用户从起始页面/ 登录
response 变量的内容如下:
Vary: Cookie
X-Frame-Options: SAMEORIGIN
Content-Type: text/html; charset=utf-8
Location: http://testserver/?next=/classroom/
测试错误:
self.assertEqual(response.status_code, 200)
AssertionError: 302 != 200
我做错了什么?
【问题讨论】:
-
请记住,在运行测试时,您没有任何用户可以进行身份验证。您需要先将它们添加到数据库中。您可能还需要使用 Mock 来模拟您的请求和访问令牌。
-
如果您使用的是
login_required,那么在您的测试中伪造 HTTP 授权将毫无帮助。 -
那么我怎样才能让我的测试通过?
-
302 意味着您正在获得重定向,不一定是灾难——如果您跟随重定向会发生什么...?
标签: python django unit-testing python-unittest