diff options
Diffstat (limited to 'rest_framework/tests/test_testing.py')
| -rw-r--r-- | rest_framework/tests/test_testing.py | 115 | 
1 files changed, 0 insertions, 115 deletions
| diff --git a/rest_framework/tests/test_testing.py b/rest_framework/tests/test_testing.py deleted file mode 100644 index 49d45fc2..00000000 --- a/rest_framework/tests/test_testing.py +++ /dev/null @@ -1,115 +0,0 @@ -# -- coding: utf-8 -- - -from __future__ import unicode_literals -from django.contrib.auth.models import User -from django.test import TestCase -from rest_framework.compat import patterns, url -from rest_framework.decorators import api_view -from rest_framework.response import Response -from rest_framework.test import APIClient, APIRequestFactory, force_authenticate - - -@api_view(['GET', 'POST']) -def view(request): -    return Response({ -        'auth': request.META.get('HTTP_AUTHORIZATION', b''), -        'user': request.user.username -    }) - - -urlpatterns = patterns('', -    url(r'^view/$', view), -) - - -class TestAPITestClient(TestCase): -    urls = 'rest_framework.tests.test_testing' - -    def setUp(self): -        self.client = APIClient() - -    def test_credentials(self): -        """ -        Setting `.credentials()` adds the required headers to each request. -        """ -        self.client.credentials(HTTP_AUTHORIZATION='example') -        for _ in range(0, 3): -            response = self.client.get('/view/') -            self.assertEqual(response.data['auth'], 'example') - -    def test_force_authenticate(self): -        """ -        Setting `.force_authenticate()` forcibly authenticates each request. -        """ -        user = User.objects.create_user('example', 'example@example.com') -        self.client.force_authenticate(user) -        response = self.client.get('/view/') -        self.assertEqual(response.data['user'], 'example') - -    def test_csrf_exempt_by_default(self): -        """ -        By default, the test client is CSRF exempt. -        """ -        User.objects.create_user('example', 'example@example.com', 'password') -        self.client.login(username='example', password='password') -        response = self.client.post('/view/') -        self.assertEqual(response.status_code, 200) - -    def test_explicitly_enforce_csrf_checks(self): -        """ -        The test client can enforce CSRF checks. -        """ -        client = APIClient(enforce_csrf_checks=True) -        User.objects.create_user('example', 'example@example.com', 'password') -        client.login(username='example', password='password') -        response = client.post('/view/') -        expected = {'detail': 'CSRF Failed: CSRF cookie not set.'} -        self.assertEqual(response.status_code, 403) -        self.assertEqual(response.data, expected) - - -class TestAPIRequestFactory(TestCase): -    def test_csrf_exempt_by_default(self): -        """ -        By default, the test client is CSRF exempt. -        """ -        user = User.objects.create_user('example', 'example@example.com', 'password') -        factory = APIRequestFactory() -        request = factory.post('/view/') -        request.user = user -        response = view(request) -        self.assertEqual(response.status_code, 200) - -    def test_explicitly_enforce_csrf_checks(self): -        """ -        The test client can enforce CSRF checks. -        """ -        user = User.objects.create_user('example', 'example@example.com', 'password') -        factory = APIRequestFactory(enforce_csrf_checks=True) -        request = factory.post('/view/') -        request.user = user -        response = view(request) -        expected = {'detail': 'CSRF Failed: CSRF cookie not set.'} -        self.assertEqual(response.status_code, 403) -        self.assertEqual(response.data, expected) - -    def test_invalid_format(self): -        """ -        Attempting to use a format that is not configured will raise an -        assertion error. -        """ -        factory = APIRequestFactory() -        self.assertRaises(AssertionError, factory.post, -            path='/view/', data={'example': 1}, format='xml' -        ) - -    def test_force_authenticate(self): -        """ -        Setting `force_authenticate()` forcibly authenticates the request. -        """ -        user = User.objects.create_user('example', 'example@example.com') -        factory = APIRequestFactory() -        request = factory.get('/view') -        force_authenticate(request, user=user) -        response = view(request) -        self.assertEqual(response.data['user'], 'example') | 
