diff options
| author | Tom Christie | 2011-12-11 10:42:37 -0800 |
|---|---|---|
| committer | Tom Christie | 2011-12-11 10:42:37 -0800 |
| commit | e2f3153b138a728c2dacb16c90f7a46a17f429c4 (patch) | |
| tree | d95d6755f787c8ab3d8c555315d514c067121bf9 /djangorestframework/tests | |
| parent | 4f42303035c094a1d0c6128f0ccce1abfa6b72f4 (diff) | |
| parent | e84bf2140c33b45d1d9d8325eeaf62a97c46495e (diff) | |
| download | django-rest-framework-e2f3153b138a728c2dacb16c90f7a46a17f429c4.tar.bz2 | |
Merge pull request #90 from jakul/xmlparser6
Lovely stuff!
Diffstat (limited to 'djangorestframework/tests')
| -rw-r--r-- | djangorestframework/tests/parsers.py | 27 | ||||
| -rw-r--r-- | djangorestframework/tests/renderers.py | 70 |
2 files changed, 95 insertions, 2 deletions
diff --git a/djangorestframework/tests/parsers.py b/djangorestframework/tests/parsers.py index deba688e..b21acd4d 100644 --- a/djangorestframework/tests/parsers.py +++ b/djangorestframework/tests/parsers.py @@ -136,6 +136,8 @@ from cgi import parse_qs from django import forms from django.test import TestCase from djangorestframework.parsers import FormParser +from djangorestframework.parsers import XMLParser +import datetime class Form(forms.Form): field1 = forms.CharField(max_length=3) @@ -153,3 +155,28 @@ class TestFormParser(TestCase): (data, files) = parser.parse(stream) self.assertEqual(Form(data).is_valid(), True) + + +class TestXMLParser(TestCase): + def setUp(self): + self.input = StringIO( + '<?xml version="1.0" encoding="utf-8"?>' + '<root>' + '<field_a>121.0</field_a>' + '<field_b>dasd</field_b>' + '<field_c></field_c>' + '<field_d>2011-12-25 12:45:00</field_d>' + '</root>' + ) + self.data = { + 'field_a': 121, + 'field_b': 'dasd', + 'field_c': None, + 'field_d': datetime.datetime(2011, 12, 25, 12, 45, 00) + + } + + def test_parse(self): + parser = XMLParser(None) + (data, files) = parser.parse(self.input) + self.assertEqual(data, self.data)
\ No newline at end of file diff --git a/djangorestframework/tests/renderers.py b/djangorestframework/tests/renderers.py index e7091c69..d6a49984 100644 --- a/djangorestframework/tests/renderers.py +++ b/djangorestframework/tests/renderers.py @@ -4,13 +4,16 @@ from django.test import TestCase from djangorestframework import status from djangorestframework.compat import View as DjangoView -from djangorestframework.renderers import BaseRenderer, JSONRenderer, YAMLRenderer -from djangorestframework.parsers import JSONParser, YAMLParser +from djangorestframework.renderers import BaseRenderer, JSONRenderer, YAMLRenderer,\ + XMLRenderer +from djangorestframework.parsers import JSONParser, YAMLParser, XMLParser from djangorestframework.mixins import ResponseMixin from djangorestframework.response import Response from djangorestframework.utils.mediatypes import add_media_type_param from StringIO import StringIO +import datetime +from decimal import Decimal DUMMYSTATUS = status.HTTP_200_OK DUMMYCONTENT = 'dummycontent' @@ -224,3 +227,66 @@ if YAMLRenderer: content = renderer.render(obj, 'application/yaml') (data, files) = parser.parse(StringIO(content)) self.assertEquals(obj, data) + + + +class XMLRendererTestCase(TestCase): + """ + Tests specific to the JSON Renderer + """ + + def test_render_string(self): + """ + Test XML rendering. + """ + renderer = XMLRenderer(None) + content = renderer.render({'field': 'astring'}, 'application/xml') + self.assertXMLContains(content, '<field>astring</field>') + + def test_render_integer(self): + """ + Test XML rendering. + """ + renderer = XMLRenderer(None) + content = renderer.render({'field': 111}, 'application/xml') + self.assertXMLContains(content, '<field>111</field>') + + def test_render_datetime(self): + """ + Test XML rendering. + """ + renderer = XMLRenderer(None) + content = renderer.render({ + 'field': datetime.datetime(2011, 12, 25, 12, 45, 00) + }, 'application/xml') + self.assertXMLContains(content, '<field>2011-12-25 12:45:00</field>') + + def test_render_float(self): + """ + Test XML rendering. + """ + renderer = XMLRenderer(None) + content = renderer.render({'field': 123.4}, 'application/xml') + self.assertXMLContains(content, '<field>123.4</field>') + + def test_render_decimal(self): + """ + Test XML rendering. + """ + renderer = XMLRenderer(None) + content = renderer.render({'field': Decimal('111.2')}, 'application/xml') + self.assertXMLContains(content, '<field>111.2</field>') + + def test_render_none(self): + """ + Test XML rendering. + """ + renderer = XMLRenderer(None) + content = renderer.render({'field': None}, 'application/xml') + self.assertXMLContains(content, '<field></field>') + + + def assertXMLContains(self, xml, string): + self.assertTrue(xml.startswith('<?xml version="1.0" encoding="utf-8"?>\n<root>')) + self.assertTrue(xml.endswith('</root>')) + self.assertTrue(string in xml, '%r not in %r' % (string, xml)) |
