diff options
| author | Tom Christie | 2012-04-11 15:28:57 +0100 |
|---|---|---|
| committer | Tom Christie | 2012-04-11 15:28:57 +0100 |
| commit | 44df8345f3ffcba141ded3a1bd993971d7199164 (patch) | |
| tree | d102b9c5faf06f599e8975a3b4346907568dd600 | |
| parent | 44b5d6120341c5fb90a0b3022d09f9ad78d9f836 (diff) | |
| parent | e53c819cc7a5567f2c29375550e9ff62ec20d472 (diff) | |
| download | django-rest-framework-44df8345f3ffcba141ded3a1bd993971d7199164.tar.bz2 | |
Merge with master
| -rw-r--r-- | AUTHORS | 1 | ||||
| -rw-r--r-- | djangorestframework/parsers.py | 2 | ||||
| -rw-r--r-- | djangorestframework/serializer.py | 29 | ||||
| -rw-r--r-- | djangorestframework/tests/serializer.py | 21 | ||||
| -rw-r--r-- | djangorestframework/utils/__init__.py | 1 | ||||
| -rw-r--r-- | docs/howto/setup.rst | 1 | ||||
| -rw-r--r-- | docs/requirements.txt | 2 | ||||
| -rw-r--r-- | examples/mixin/urls.py | 12 |
8 files changed, 38 insertions, 31 deletions
@@ -34,6 +34,7 @@ Paul Oswald <poswald> Sean C. Farley <scfarley> Daniel Izquierdo <izquierdo> Can Yavuz <tschan> +Shawn Lewis <shawnlewis> THANKS TO: diff --git a/djangorestframework/parsers.py b/djangorestframework/parsers.py index fc4450b7..0eb72f38 100644 --- a/djangorestframework/parsers.py +++ b/djangorestframework/parsers.py @@ -104,7 +104,7 @@ class YAMLParser(BaseParser): """ try: return (yaml.safe_load(stream), None) - except ValueError, exc: + except (ValueError, yaml.parser.ParserError), exc: raise ImmediateResponse( {'detail': 'YAML parse error - %s' % unicode(exc)}, status=status.HTTP_400_BAD_REQUEST) diff --git a/djangorestframework/serializer.py b/djangorestframework/serializer.py index b0c02675..5dea37e8 100644 --- a/djangorestframework/serializer.py +++ b/djangorestframework/serializer.py @@ -25,16 +25,9 @@ def _field_to_tuple(field): def _fields_to_list(fields): """ - Return a list of field names. + Return a list of field tuples. """ - return [_field_to_tuple(field)[0] for field in fields or ()] - - -def _fields_to_dict(fields): - """ - Return a `dict` of field name -> None, or tuple of fields, or Serializer class - """ - return dict([_field_to_tuple(field) for field in fields or ()]) + return [_field_to_tuple(field) for field in fields or ()] class _SkipField(Exception): @@ -110,9 +103,6 @@ class Serializer(object): self.stack = stack def get_fields(self, obj): - """ - Return the set of field names/keys to use for a model instance/dict. - """ fields = self.fields # If `fields` is not set, we use the default fields and modify @@ -123,9 +113,6 @@ class Serializer(object): exclude = self.exclude or () fields = set(default + list(include)) - set(exclude) - else: - fields = _fields_to_list(self.fields) - return fields def get_default_fields(self, obj): @@ -139,9 +126,7 @@ class Serializer(object): else: return obj.keys() - def get_related_serializer(self, key): - info = _fields_to_dict(self.fields).get(key, None) - + def get_related_serializer(self, info): # If an element in `fields` is a 2-tuple of (str, tuple) # then the second element of the tuple is the fields to # set on the related serializer @@ -175,11 +160,11 @@ class Serializer(object): """ return self.rename.get(smart_str(key), smart_str(key)) - def serialize_val(self, key, obj): + def serialize_val(self, key, obj, related_info): """ Convert a model field or dict value into a serializable representation. """ - related_serializer = self.get_related_serializer(key) + related_serializer = self.get_related_serializer(related_info) if self.depth is None: depth = None @@ -219,7 +204,7 @@ class Serializer(object): fields = self.get_fields(instance) # serialize each required field - for fname in fields: + for fname, related_info in _fields_to_list(fields): try: # we first check for a method 'fname' on self, # 'fname's signature must be 'def fname(self, instance)' @@ -237,7 +222,7 @@ class Serializer(object): continue key = self.serialize_key(fname) - val = self.serialize_val(fname, obj) + val = self.serialize_val(fname, obj, related_info) data[key] = val except _SkipField: pass diff --git a/djangorestframework/tests/serializer.py b/djangorestframework/tests/serializer.py index e8580610..834a60d0 100644 --- a/djangorestframework/tests/serializer.py +++ b/djangorestframework/tests/serializer.py @@ -104,6 +104,27 @@ class TestFieldNesting(TestCase): self.assertEqual(SerializerM2().serialize(self.m2), {'field': {'field1': u'foo'}}) self.assertEqual(SerializerM3().serialize(self.m3), {'field': {'field2': u'bar'}}) + def test_serializer_no_fields(self): + """ + Test related serializer works when the fields attr isn't present. Fix for + #178. + """ + class NestedM2(Serializer): + fields = ('field1', ) + + class NestedM3(Serializer): + fields = ('field2', ) + + class SerializerM2(Serializer): + include = [('field', NestedM2)] + exclude = ('id', ) + + class SerializerM3(Serializer): + fields = [('field', NestedM3)] + + self.assertEqual(SerializerM2().serialize(self.m2), {'field': {'field1': u'foo'}}) + self.assertEqual(SerializerM3().serialize(self.m3), {'field': {'field2': u'bar'}}) + def test_serializer_classname_nesting(self): """ Test related model serialization diff --git a/djangorestframework/utils/__init__.py b/djangorestframework/utils/__init__.py index 9d250be2..ef611a16 100644 --- a/djangorestframework/utils/__init__.py +++ b/djangorestframework/utils/__init__.py @@ -9,7 +9,6 @@ from djangorestframework.request import Request import re import xml.etree.ElementTree as ET - MSIE_USER_AGENT_REGEX = re.compile(r'^Mozilla/[0-9]+\.[0-9]+ \([^)]*; MSIE [0-9]+\.[0-9]+[a-z]?;[^)]*\)(?!.* Opera )') diff --git a/docs/howto/setup.rst b/docs/howto/setup.rst index 081c6412..f0127060 100644 --- a/docs/howto/setup.rst +++ b/docs/howto/setup.rst @@ -49,6 +49,7 @@ YAML YAML support is optional, and requires `PyYAML`_. + Login / Logout -------------- diff --git a/docs/requirements.txt b/docs/requirements.txt index 77cdf485..46a67149 100644 --- a/docs/requirements.txt +++ b/docs/requirements.txt @@ -1,6 +1,6 @@ # Documentation requires Django & Sphinx, and their dependencies... -Django==1.2.4 +Django>=1.2.4 Jinja2==2.5.5 Pygments==1.4 Sphinx==1.0.7 diff --git a/examples/mixin/urls.py b/examples/mixin/urls.py index 7a5697fd..900c532e 100644 --- a/examples/mixin/urls.py +++ b/examples/mixin/urls.py @@ -9,15 +9,15 @@ from django.conf.urls.defaults import patterns, url class ExampleView(ResponseMixin, View): """An example view using Django 1.3's class based views. - Uses djangorestframework's RendererMixin to provide support for multiple output formats.""" + Uses djangorestframework's RendererMixin to provide support for multiple + output formats.""" renderers = DEFAULT_RENDERERS def get(self, request): - url = reverse('mixin-view', request) - response = Response({'description': 'Some example content', - 'url': url}, status=200) - self.response = self.prepare_response(response) - return self.response + url = reverse('mixin-view', request=request) + response = Response(200, {'description': 'Some example content', + 'url': url}) + return self.render(response) urlpatterns = patterns('', |
