diff options
| author | Xavier Ordoquy | 2014-06-23 14:02:45 +0200 | 
|---|---|---|
| committer | Xavier Ordoquy | 2014-06-23 14:02:45 +0200 | 
| commit | 2489e38a06f575aa144644eee683bd87f20186ef (patch) | |
| tree | fc52fd2280d3ef6d0dc69d53a3771ee5f499ab29 /tests | |
| parent | 15c2c58b43a00ec29af99e0478b70eea57560fce (diff) | |
| parent | e11f41ebc4ef088a5849771dfda5a7fba4f82904 (diff) | |
| download | django-rest-framework-2489e38a06f575aa144644eee683bd87f20186ef.tar.bz2 | |
Merge remote-tracking branch 'origin/master' into 2.4.0
Conflicts:
	.travis.yml
	docs/api-guide/viewsets.md
	rest_framework/serializers.py
	rest_framework/throttling.py
	tests/test_generics.py
	tests/test_serializers.py
	tox.ini
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/models.py | 3 | ||||
| -rw-r--r-- | tests/test_fields.py | 24 | ||||
| -rw-r--r-- | tests/test_generics.py | 74 | ||||
| -rw-r--r-- | tests/test_serializers.py | 5 | ||||
| -rw-r--r-- | tests/test_views.py | 16 | 
5 files changed, 114 insertions, 8 deletions
| diff --git a/tests/models.py b/tests/models.py index 0256697a..e171d3bd 100644 --- a/tests/models.py +++ b/tests/models.py @@ -151,7 +151,8 @@ class ForeignKeySource(RESTFrameworkModel):  class NullableForeignKeySource(RESTFrameworkModel):      name = models.CharField(max_length=100)      target = models.ForeignKey(ForeignKeyTarget, null=True, blank=True, -                               related_name='nullable_sources') +                               related_name='nullable_sources', +                               verbose_name='Optional target object')  # OneToOne diff --git a/tests/test_fields.py b/tests/test_fields.py index e65a2fb3..73b15641 100644 --- a/tests/test_fields.py +++ b/tests/test_fields.py @@ -4,6 +4,7 @@ General serializer field tests.  from __future__ import unicode_literals  import datetime +import re  from decimal import Decimal  from uuid import uuid4  from django.core import validators @@ -103,6 +104,16 @@ class BasicFieldTests(TestCase):          keys = list(field.to_native(ret).keys())          self.assertEqual(keys, ['c', 'b', 'a', 'z']) +    def test_widget_html_attributes(self): +        """ +        Make sure widget_html() renders the correct attributes +        """ +        r = re.compile('(\S+)=["\']?((?:.(?!["\']?\s+(?:\S+)=|[>"\']))+.)["\']?') +        form = TimeFieldModelSerializer().data +        attributes = r.findall(form.fields['clock'].widget_html()) +        self.assertIn(('name', 'clock'), attributes) +        self.assertIn(('id', 'clock'), attributes) +  class DateFieldTest(TestCase):      """ @@ -312,7 +323,7 @@ class DateTimeFieldTest(TestCase):              f.from_native('04:61:59')          except validators.ValidationError as e:              self.assertEqual(e.messages, ["Datetime has wrong format. Use one of these formats instead: " -                                          "YYYY-MM-DDThh:mm[:ss[.uuuuuu]][+HHMM|-HHMM|Z]"]) +                                          "YYYY-MM-DDThh:mm[:ss[.uuuuuu]][+HH:MM|-HH:MM|Z]"])          else:              self.fail("ValidationError was not properly raised") @@ -326,7 +337,7 @@ class DateTimeFieldTest(TestCase):              f.from_native('04 -- 31')          except validators.ValidationError as e:              self.assertEqual(e.messages, ["Datetime has wrong format. Use one of these formats instead: " -                                          "YYYY-MM-DDThh:mm[:ss[.uuuuuu]][+HHMM|-HHMM|Z]"]) +                                          "YYYY-MM-DDThh:mm[:ss[.uuuuuu]][+HH:MM|-HH:MM|Z]"])          else:              self.fail("ValidationError was not properly raised") @@ -706,6 +717,15 @@ class ChoiceFieldTests(TestCase):          f = serializers.ChoiceField(required=False, choices=SAMPLE_CHOICES)          self.assertEqual(f.choices, models.fields.BLANK_CHOICE_DASH + SAMPLE_CHOICES) +    def test_blank_choice_display(self): +        blank = 'No Preference' +        f = serializers.ChoiceField( +            required=False, +            choices=SAMPLE_CHOICES, +            blank_display_value=blank, +        ) +        self.assertEqual(f.choices, [('', blank)] + SAMPLE_CHOICES) +      def test_invalid_choice_model(self):          s = ChoiceFieldModelSerializer(data={'choice': 'wrong_value'})          self.assertFalse(s.is_valid()) diff --git a/tests/test_generics.py b/tests/test_generics.py index 4389994a..36832aff 100644 --- a/tests/test_generics.py +++ b/tests/test_generics.py @@ -5,6 +5,7 @@ from django.test import TestCase  from rest_framework import generics, renderers, serializers, status  from rest_framework.test import APIRequestFactory  from tests.models import BasicModel, Comment, SlugBasedModel +from tests.models import ForeignKeySource, ForeignKeyTarget  from rest_framework.compat import six  factory = APIRequestFactory() @@ -28,6 +29,13 @@ class InstanceView(generics.RetrieveUpdateDestroyAPIView):          return queryset.exclude(text='filtered out') +class FKInstanceView(generics.RetrieveUpdateDestroyAPIView): +    """ +    FK: example description for OPTIONS. +    """ +    model = ForeignKeySource + +  class SlugSerializer(serializers.ModelSerializer):      slug = serializers.Field()  # read only @@ -407,6 +415,72 @@ class TestInstanceView(TestCase):          self.assertFalse(self.objects.filter(id=999).exists()) +class TestFKInstanceView(TestCase): +    def setUp(self): +        """ +        Create 3 BasicModel instances. +        """ +        items = ['foo', 'bar', 'baz'] +        for item in items: +            t = ForeignKeyTarget(name=item) +            t.save() +            ForeignKeySource(name='source_' + item, target=t).save() + +        self.objects = ForeignKeySource.objects +        self.data = [ +            {'id': obj.id, 'name': obj.name} +            for obj in self.objects.all() +        ] +        self.view = FKInstanceView.as_view() + +    def test_options_root_view(self): +        """ +        OPTIONS requests to ListCreateAPIView should return metadata +        """ +        request = factory.options('/999') +        with self.assertNumQueries(1): +            response = self.view(request, pk=999).render() +        expected = { +            'name': 'Fk Instance', +            'description': 'FK: example description for OPTIONS.', +            'renders': [ +                'application/json', +                'text/html' +            ], +            'parses': [ +                'application/json', +                'application/x-www-form-urlencoded', +                'multipart/form-data' +            ], +            'actions': { +                'PUT': { +                    'id': { +                        'type': 'integer', +                        'required': False, +                        'read_only': True, +                        'label': 'ID' +                    }, +                    'name': { +                        'type': 'string', +                        'required': True, +                        'read_only': False, +                        'label': 'name', +                        'max_length': 100 +                    }, +                    'target': { +                        'type': 'field', +                        'required': True, +                        'read_only': False, +                        'label': 'Target', +                        'help_text': 'Target' +                    } +                } +            } +        } +        self.assertEqual(response.status_code, status.HTTP_200_OK) +        self.assertEqual(response.data, expected) + +  class TestOverriddenGetObject(TestCase):      """      Test cases for a RetrieveUpdateDestroyAPIView that does NOT use the diff --git a/tests/test_serializers.py b/tests/test_serializers.py index 67547783..2e276f15 100644 --- a/tests/test_serializers.py +++ b/tests/test_serializers.py @@ -3,6 +3,7 @@ from django.test import TestCase  from rest_framework.serializers import _resolve_model  from tests.models import BasicModel +from rest_framework.compat import six  class ResolveModelTests(TestCase): @@ -19,6 +20,10 @@ class ResolveModelTests(TestCase):          resolved_model = _resolve_model('tests.BasicModel')          self.assertEqual(resolved_model, BasicModel) +    def test_resolve_unicode_representation(self): +        resolved_model = _resolve_model(six.text_type('tests.BasicModel')) +        self.assertEqual(resolved_model, BasicModel) +      def test_resolve_non_django_model(self):          with self.assertRaises(ValueError):              _resolve_model(TestCase) diff --git a/tests/test_views.py b/tests/test_views.py index 65c7e50e..77b113ee 100644 --- a/tests/test_views.py +++ b/tests/test_views.py @@ -1,5 +1,6 @@  from __future__ import unicode_literals +import sys  import copy  from django.test import TestCase  from rest_framework import status @@ -11,6 +12,11 @@ from rest_framework.views import APIView  factory = APIRequestFactory() +if sys.version_info[:2] >= (3, 4): +    JSON_ERROR = 'JSON parse error - Expecting value:' +else: +    JSON_ERROR = 'JSON parse error - No JSON object could be decoded' +  class BasicView(APIView):      def get(self, request, *args, **kwargs): @@ -48,7 +54,7 @@ def sanitise_json_error(error_dict):      of json.      """      ret = copy.copy(error_dict) -    chop = len('JSON parse error - No JSON object could be decoded') +    chop = len(JSON_ERROR)      ret['detail'] = ret['detail'][:chop]      return ret @@ -61,7 +67,7 @@ class ClassBasedViewIntegrationTests(TestCase):          request = factory.post('/', 'f00bar', content_type='application/json')          response = self.view(request)          expected = { -            'detail': 'JSON parse error - No JSON object could be decoded' +            'detail': JSON_ERROR          }          self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)          self.assertEqual(sanitise_json_error(response.data), expected) @@ -76,7 +82,7 @@ class ClassBasedViewIntegrationTests(TestCase):          request = factory.post('/', form_data)          response = self.view(request)          expected = { -            'detail': 'JSON parse error - No JSON object could be decoded' +            'detail': JSON_ERROR          }          self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)          self.assertEqual(sanitise_json_error(response.data), expected) @@ -90,7 +96,7 @@ class FunctionBasedViewIntegrationTests(TestCase):          request = factory.post('/', 'f00bar', content_type='application/json')          response = self.view(request)          expected = { -            'detail': 'JSON parse error - No JSON object could be decoded' +            'detail': JSON_ERROR          }          self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)          self.assertEqual(sanitise_json_error(response.data), expected) @@ -105,7 +111,7 @@ class FunctionBasedViewIntegrationTests(TestCase):          request = factory.post('/', form_data)          response = self.view(request)          expected = { -            'detail': 'JSON parse error - No JSON object could be decoded' +            'detail': JSON_ERROR          }          self.assertEqual(response.status_code, status.HTTP_400_BAD_REQUEST)          self.assertEqual(sanitise_json_error(response.data), expected) | 
