aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework
diff options
context:
space:
mode:
authorTom Christie2012-10-15 04:50:28 -0700
committerTom Christie2012-10-15 04:50:28 -0700
commite88ca9637bd4f49659dd80ca7afd0f38adf07746 (patch)
tree2cf1ca191bd1136664e12ac898eb8ebe67410b32 /rest_framework
parent41dd63b3b0abcb615768fe2774cbdf10b9ba1cf0 (diff)
parentc94272650915eef368cdc5d157644884c3eecccb (diff)
downloaddjango-rest-framework-e88ca9637bd4f49659dd80ca7afd0f38adf07746.tar.bz2
Merge pull request #295 from ulmus/restframework2
Added TextField to serializer
Diffstat (limited to 'rest_framework')
-rw-r--r--rest_framework/fields.py7
-rw-r--r--rest_framework/serializers.py4
-rw-r--r--rest_framework/tests/serializer.py29
3 files changed, 40 insertions, 0 deletions
diff --git a/rest_framework/fields.py b/rest_framework/fields.py
index bb9a523d..5d13bd55 100644
--- a/rest_framework/fields.py
+++ b/rest_framework/fields.py
@@ -409,6 +409,13 @@ class BooleanField(WritableField):
return False
raise ValidationError(self.error_messages['invalid'] % value)
+class TextField(WritableField):
+ type_name = 'TextField'
+
+ def from_native(self, value):
+ if isinstance(value, basestring) or value is None:
+ return value
+ return smart_unicode(value)
class CharField(WritableField):
type_name = 'CharField'
diff --git a/rest_framework/serializers.py b/rest_framework/serializers.py
index 06330017..13f8cde2 100644
--- a/rest_framework/serializers.py
+++ b/rest_framework/serializers.py
@@ -377,10 +377,14 @@ class ModelSerializer(Serializer):
field_mapping = {
models.FloatField: FloatField,
models.IntegerField: IntegerField,
+ models.PositiveIntegerField: IntegerField,
+ models.SmallIntegerField: IntegerField,
+ models.PositiveSmallIntegerField: IntegerField,
models.DateTimeField: DateTimeField,
models.DateField: DateField,
models.EmailField: EmailField,
models.CharField: CharField,
+ models.TextField: CharField,
models.CommaSeparatedIntegerField: CharField,
models.BooleanField: BooleanField,
}
diff --git a/rest_framework/tests/serializer.py b/rest_framework/tests/serializer.py
index 256987ad..7208d6a5 100644
--- a/rest_framework/tests/serializer.py
+++ b/rest_framework/tests/serializer.py
@@ -28,6 +28,26 @@ class CommentSerializer(serializers.Serializer):
return instance
+class LongText(object):
+ def __init__(self, content):
+ self.content = content
+
+ def __eq__(self, other):
+ return all([getattr(self, attr) == getattr(other, attr)
+ for attr in ('content',)])
+
+
+class LongTextSerializer(serializers.Serializer):
+ content = serializers.TextField()
+
+ def restore_object(self, data, instance=None):
+ if instance is None:
+ return LongText(**data)
+ for key, val in data.items():
+ setattr(instance, key, val)
+ return instance
+
+
class BasicTests(TestCase):
def setUp(self):
self.comment = Comment(
@@ -82,6 +102,7 @@ class ValidationTests(TestCase):
'content': 'x' * 1001,
'created': datetime.datetime(2012, 1, 1)
}
+ self.long_text = LongText('test test test test')
def test_create(self):
serializer = CommentSerializer(self.data)
@@ -102,6 +123,14 @@ class ValidationTests(TestCase):
self.assertEquals(serializer.is_valid(), False)
self.assertEquals(serializer.errors, {'email': [u'This field is required.']})
+ def test_update_long_text(self):
+ data = {
+ 'content' : 'Lorem ipsum dolor sit amet.'
+ }
+ serializer = LongTextSerializer(data, self.long_text)
+ self.assertEquals(serializer.is_valid(), True)
+ self.assertEquals(data['content'], self.long_text.content)
+
class MetadataTests(TestCase):
def test_empty(self):