Skip to content

Commit a68e78b

Browse files
Add test integrated with middleware
1 parent dbd057b commit a68e78b

File tree

1 file changed

+37
-0
lines changed

1 file changed

+37
-0
lines changed

tests/test_middleware.py

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
2+
from django.conf.urls import patterns, url
3+
from django.contrib.auth.models import User
4+
from rest_framework.authentication import TokenAuthentication
5+
from rest_framework.authtoken.models import Token
6+
from rest_framework.test import APITestCase
7+
from rest_framework.views import APIView
8+
9+
10+
urlpatterns = patterns(
11+
'',
12+
url(r'^$', APIView.as_view(authentication_classes=(TokenAuthentication,))),
13+
)
14+
15+
16+
class MyMiddleware(object):
17+
18+
def process_response(self, request, response):
19+
assert hasattr(request, 'user'), '`user` is not set on request'
20+
assert request.user.is_authenticated(), '`user` is not authenticated'
21+
return response
22+
23+
24+
class TestMiddleware(APITestCase):
25+
26+
urls = 'tests.test_middleware'
27+
28+
def test_middleware_can_access_user_when_processing_response(self):
29+
user = User.objects.create_user('john', '[email protected]', 'password')
30+
key = 'abcd1234'
31+
Token.objects.create(key=key, user=user)
32+
33+
with self.settings(
34+
MIDDLEWARE_CLASSES=('tests.test_middleware.MyMiddleware',)
35+
):
36+
auth = 'Token ' + key
37+
self.client.get('/', HTTP_AUTHORIZATION=auth)

0 commit comments

Comments
 (0)