Fixed #4558 -- Modified XML serializer to handle whitespace better around None tags. Thanks to Bill Fenner <fenner@gmail.com> for the report and fix.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@5727 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Russell Keith-Magee 2007-07-20 12:07:58 +00:00
parent 0827f4ac7e
commit 3fef1f4c8d
3 changed files with 30 additions and 2 deletions

View File

@ -171,7 +171,7 @@ class Deserializer(base.Deserializer):
elif field.rel and isinstance(field.rel, models.ManyToOneRel): elif field.rel and isinstance(field.rel, models.ManyToOneRel):
data[field.attname] = self._handle_fk_field_node(field_node, field) data[field.attname] = self._handle_fk_field_node(field_node, field)
else: else:
if len(field_node.childNodes) == 1 and field_node.childNodes[0].nodeName == 'None': if field_node.getElementsByTagName('None'):
value = None value = None
else: else:
value = field.to_python(getInnerText(field_node).strip()) value = field.to_python(getInnerText(field_node).strip())
@ -185,7 +185,7 @@ class Deserializer(base.Deserializer):
Handle a <field> node for a ForeignKey Handle a <field> node for a ForeignKey
""" """
# Check if there is a child node named 'None', returning None if so. # Check if there is a child node named 'None', returning None if so.
if len(node.childNodes) == 1 and node.childNodes[0].nodeName == 'None': if node.getElementsByTagName('None'):
return None return None
else: else:
return field.rel.to._meta.get_field(field.rel.field_name).to_python( return field.rel.to._meta.get_field(field.rel.field_name).to_python(

View File

@ -0,0 +1,11 @@
<?xml version="1.0" encoding="utf-8"?>
<django-objects version="1.0">
<object pk="1" model="fixtures_regress.stuff">
<field type="CharField" name="name">
<None/>
</field>
<field to="auth.user" name="owner" rel="ManyToOneRel">
<None/>
</field>
</object>
</django-objects>

View File

@ -1,4 +1,5 @@
from django.db import models from django.db import models
from django.contrib.auth.models import User
class Animal(models.Model): class Animal(models.Model):
name = models.CharField(maxlength=150) name = models.CharField(maxlength=150)
@ -14,6 +15,13 @@ class Plant(models.Model):
# For testing when upper case letter in app name; regression for #4057 # For testing when upper case letter in app name; regression for #4057
db_table = "Fixtures_regress_plant" db_table = "Fixtures_regress_plant"
class Stuff(models.Model):
name = models.CharField(maxlength=20, null=True)
owner = models.ForeignKey(User, null=True)
def __unicode__(self):
return unicode(self.name) + u' is owned by ' + unicode(self.owner)
__test__ = {'API_TESTS':""" __test__ = {'API_TESTS':"""
>>> from django.core import management >>> from django.core import management
@ -26,4 +34,13 @@ __test__ = {'API_TESTS':"""
>>> animal = Animal(name='Platypus', latin_name='Ornithorhynchus anatinus') >>> animal = Animal(name='Platypus', latin_name='Ornithorhynchus anatinus')
>>> animal.save() >>> animal.save()
###############################################
# Regression test for ticket #4558 -- pretty printing of XML fixtures
# doesn't affect parsing of None values.
# Load a pretty-printed XML fixture with Nulls.
>>> management.load_data(['pretty.xml'], verbosity=0)
>>> Stuff.objects.all()
[<Stuff: None is owned by None>]
"""} """}