123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449 |
- """
- A test spanning all the capabilities of all the serializers.
- This class defines sample data and a dynamically generated
- test case that is capable of testing the capabilities of
- the serializers. This includes all valid data values, plus
- forward, backwards and self references.
- """
- import datetime
- import decimal
- try:
- from cStringIO import StringIO
- except ImportError:
- from StringIO import StringIO
- from django.conf import settings
- from django.core import serializers, management
- from django.db import transaction, DEFAULT_DB_ALIAS, connection
- from django.test import TestCase
- from django.utils.functional import curry
- from models import *
- def data_create(pk, klass, data):
- instance = klass(id=pk)
- instance.data = data
- models.Model.save_base(instance, raw=True)
- return [instance]
- def generic_create(pk, klass, data):
- instance = klass(id=pk)
- instance.data = data[0]
- models.Model.save_base(instance, raw=True)
- for tag in data[1:]:
- instance.tags.create(data=tag)
- return [instance]
- def fk_create(pk, klass, data):
- instance = klass(id=pk)
- setattr(instance, 'data_id', data)
- models.Model.save_base(instance, raw=True)
- return [instance]
- def m2m_create(pk, klass, data):
- instance = klass(id=pk)
- models.Model.save_base(instance, raw=True)
- instance.data = data
- return [instance]
- def im2m_create(pk, klass, data):
- instance = klass(id=pk)
- models.Model.save_base(instance, raw=True)
- return [instance]
- def im_create(pk, klass, data):
- instance = klass(id=pk)
- instance.right_id = data['right']
- instance.left_id = data['left']
- if 'extra' in data:
- instance.extra = data['extra']
- models.Model.save_base(instance, raw=True)
- return [instance]
- def o2o_create(pk, klass, data):
- instance = klass()
- instance.data_id = data
- models.Model.save_base(instance, raw=True)
- return [instance]
- def pk_create(pk, klass, data):
- instance = klass()
- instance.data = data
- models.Model.save_base(instance, raw=True)
- return [instance]
- def inherited_create(pk, klass, data):
- instance = klass(id=pk,**data)
-
-
-
-
-
- models.Model.save(instance)
- created = [instance]
- for klass,field in instance._meta.parents.items():
- created.append(klass.objects.get(id=pk))
- return created
- def data_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
- testcase.assertEqual(data, instance.data,
- "Objects with PK=%d not equal; expected '%s' (%s), got '%s' (%s)" % (
- pk, data, type(data), instance.data, type(instance.data))
- )
- def generic_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
- testcase.assertEqual(data[0], instance.data)
- testcase.assertEqual(data[1:], [t.data for t in instance.tags.order_by('id')])
- def fk_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
- testcase.assertEqual(data, instance.data_id)
- def m2m_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
- testcase.assertEqual(data, [obj.id for obj in instance.data.order_by('id')])
- def im2m_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
-
- def im_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
- testcase.assertEqual(data['left'], instance.left_id)
- testcase.assertEqual(data['right'], instance.right_id)
- if 'extra' in data:
- testcase.assertEqual(data['extra'], instance.extra)
- else:
- testcase.assertEqual("doesn't matter", instance.extra)
- def o2o_compare(testcase, pk, klass, data):
- instance = klass.objects.get(data=data)
- testcase.assertEqual(data, instance.data_id)
- def pk_compare(testcase, pk, klass, data):
- instance = klass.objects.get(data=data)
- testcase.assertEqual(data, instance.data)
- def inherited_compare(testcase, pk, klass, data):
- instance = klass.objects.get(id=pk)
- for key,value in data.items():
- testcase.assertEqual(value, getattr(instance,key))
- data_obj = (data_create, data_compare)
- generic_obj = (generic_create, generic_compare)
- fk_obj = (fk_create, fk_compare)
- m2m_obj = (m2m_create, m2m_compare)
- im2m_obj = (im2m_create, im2m_compare)
- im_obj = (im_create, im_compare)
- o2o_obj = (o2o_create, o2o_compare)
- pk_obj = (pk_create, pk_compare)
- inherited_obj = (inherited_create, inherited_compare)
- test_data = [
-
- (data_obj, 1, BooleanData, True),
- (data_obj, 2, BooleanData, False),
- (data_obj, 10, CharData, "Test Char Data"),
- (data_obj, 11, CharData, ""),
- (data_obj, 12, CharData, "None"),
- (data_obj, 13, CharData, "null"),
- (data_obj, 14, CharData, "NULL"),
- (data_obj, 15, CharData, None),
-
-
- (data_obj, 16, CharData, u'\xa5'),
- (data_obj, 20, DateData, datetime.date(2006,6,16)),
- (data_obj, 21, DateData, None),
- (data_obj, 30, DateTimeData, datetime.datetime(2006,6,16,10,42,37)),
- (data_obj, 31, DateTimeData, None),
- (data_obj, 40, EmailData, "hovercraft@example.com"),
- (data_obj, 41, EmailData, None),
- (data_obj, 42, EmailData, ""),
- (data_obj, 50, FileData, 'file:///foo/bar/whiz.txt'),
- (data_obj, 52, FileData, ""),
- (data_obj, 60, FilePathData, "/foo/bar/whiz.txt"),
- (data_obj, 61, FilePathData, None),
- (data_obj, 62, FilePathData, ""),
- (data_obj, 70, DecimalData, decimal.Decimal('12.345')),
- (data_obj, 71, DecimalData, decimal.Decimal('-12.345')),
- (data_obj, 72, DecimalData, decimal.Decimal('0.0')),
- (data_obj, 73, DecimalData, None),
- (data_obj, 74, FloatData, 12.345),
- (data_obj, 75, FloatData, -12.345),
- (data_obj, 76, FloatData, 0.0),
- (data_obj, 77, FloatData, None),
- (data_obj, 80, IntegerData, 123456789),
- (data_obj, 81, IntegerData, -123456789),
- (data_obj, 82, IntegerData, 0),
- (data_obj, 83, IntegerData, None),
-
- (data_obj, 90, IPAddressData, "127.0.0.1"),
- (data_obj, 91, IPAddressData, None),
- (data_obj, 100, NullBooleanData, True),
- (data_obj, 101, NullBooleanData, False),
- (data_obj, 102, NullBooleanData, None),
- (data_obj, 110, PhoneData, "212-634-5789"),
- (data_obj, 111, PhoneData, None),
- (data_obj, 120, PositiveIntegerData, 123456789),
- (data_obj, 121, PositiveIntegerData, None),
- (data_obj, 130, PositiveSmallIntegerData, 12),
- (data_obj, 131, PositiveSmallIntegerData, None),
- (data_obj, 140, SlugData, "this-is-a-slug"),
- (data_obj, 141, SlugData, None),
- (data_obj, 142, SlugData, ""),
- (data_obj, 150, SmallData, 12),
- (data_obj, 151, SmallData, -12),
- (data_obj, 152, SmallData, 0),
- (data_obj, 153, SmallData, None),
- (data_obj, 160, TextData, """This is a long piece of text.
- It contains line breaks.
- Several of them.
- The end."""),
- (data_obj, 161, TextData, ""),
- (data_obj, 162, TextData, None),
- (data_obj, 170, TimeData, datetime.time(10,42,37)),
- (data_obj, 171, TimeData, None),
- (data_obj, 180, USStateData, "MA"),
- (data_obj, 181, USStateData, None),
- (data_obj, 182, USStateData, ""),
- (data_obj, 190, XMLData, "<foo></foo>"),
- (data_obj, 191, XMLData, None),
- (data_obj, 192, XMLData, ""),
- (generic_obj, 200, GenericData, ['Generic Object 1', 'tag1', 'tag2']),
- (generic_obj, 201, GenericData, ['Generic Object 2', 'tag2', 'tag3']),
- (data_obj, 300, Anchor, "Anchor 1"),
- (data_obj, 301, Anchor, "Anchor 2"),
- (data_obj, 302, UniqueAnchor, "UAnchor 1"),
- (fk_obj, 400, FKData, 300),
- (fk_obj, 401, FKData, 500),
- (fk_obj, 402, FKData, None),
- (m2m_obj, 410, M2MData, []),
- (m2m_obj, 411, M2MData, [300,301]),
- (m2m_obj, 412, M2MData, [500,501]),
- (m2m_obj, 413, M2MData, [300,301,500,501]),
- (o2o_obj, None, O2OData, 300),
- (o2o_obj, None, O2OData, 500),
- (fk_obj, 430, FKSelfData, 431),
- (fk_obj, 431, FKSelfData, 430),
- (fk_obj, 432, FKSelfData, None),
- (m2m_obj, 440, M2MSelfData, []),
- (m2m_obj, 441, M2MSelfData, []),
- (m2m_obj, 442, M2MSelfData, [440, 441]),
- (m2m_obj, 443, M2MSelfData, [445, 446]),
- (m2m_obj, 444, M2MSelfData, [440, 441, 445, 446]),
- (m2m_obj, 445, M2MSelfData, []),
- (m2m_obj, 446, M2MSelfData, []),
- (fk_obj, 450, FKDataToField, "UAnchor 1"),
- (fk_obj, 451, FKDataToField, "UAnchor 2"),
- (fk_obj, 452, FKDataToField, None),
- (fk_obj, 460, FKDataToO2O, 300),
- (im2m_obj, 470, M2MIntermediateData, None),
-
- (im_obj, 480, Intermediate, {'right': 300, 'left': 470}),
- (im_obj, 481, Intermediate, {'right': 300, 'left': 490}),
- (im_obj, 482, Intermediate, {'right': 500, 'left': 470}),
- (im_obj, 483, Intermediate, {'right': 500, 'left': 490}),
- (im_obj, 484, Intermediate, {'right': 300, 'left': 470, 'extra': "extra"}),
- (im_obj, 485, Intermediate, {'right': 300, 'left': 490, 'extra': "extra"}),
- (im_obj, 486, Intermediate, {'right': 500, 'left': 470, 'extra': "extra"}),
- (im_obj, 487, Intermediate, {'right': 500, 'left': 490, 'extra': "extra"}),
- (im2m_obj, 490, M2MIntermediateData, []),
- (data_obj, 500, Anchor, "Anchor 3"),
- (data_obj, 501, Anchor, "Anchor 4"),
- (data_obj, 502, UniqueAnchor, "UAnchor 2"),
- (pk_obj, 601, BooleanPKData, True),
- (pk_obj, 602, BooleanPKData, False),
- (pk_obj, 610, CharPKData, "Test Char PKData"),
- (pk_obj, 640, EmailPKData, "hovercraft@example.com"),
- (pk_obj, 660, FilePathPKData, "/foo/bar/whiz.txt"),
- (pk_obj, 670, DecimalPKData, decimal.Decimal('12.345')),
- (pk_obj, 671, DecimalPKData, decimal.Decimal('-12.345')),
- (pk_obj, 672, DecimalPKData, decimal.Decimal('0.0')),
- (pk_obj, 673, FloatPKData, 12.345),
- (pk_obj, 674, FloatPKData, -12.345),
- (pk_obj, 675, FloatPKData, 0.0),
- (pk_obj, 680, IntegerPKData, 123456789),
- (pk_obj, 681, IntegerPKData, -123456789),
- (pk_obj, 682, IntegerPKData, 0),
- (pk_obj, 690, IPAddressPKData, "127.0.0.1"),
-
-
- (pk_obj, 710, PhonePKData, "212-634-5789"),
- (pk_obj, 720, PositiveIntegerPKData, 123456789),
- (pk_obj, 730, PositiveSmallIntegerPKData, 12),
- (pk_obj, 740, SlugPKData, "this-is-a-slug"),
- (pk_obj, 750, SmallPKData, 12),
- (pk_obj, 751, SmallPKData, -12),
- (pk_obj, 752, SmallPKData, 0),
- (pk_obj, 780, USStatePKData, "MA"),
- (data_obj, 800, AutoNowDateTimeData, datetime.datetime(2006,6,16,10,42,37)),
- (data_obj, 810, ModifyingSaveData, 42),
- (inherited_obj, 900, InheritAbstractModel, {'child_data':37,'parent_data':42}),
- (inherited_obj, 910, ExplicitInheritBaseModel, {'child_data':37,'parent_data':42}),
- (inherited_obj, 920, InheritBaseModel, {'child_data':37,'parent_data':42}),
- (data_obj, 1000, BigIntegerData, 9223372036854775807),
- (data_obj, 1001, BigIntegerData, -9223372036854775808),
- (data_obj, 1002, BigIntegerData, 0),
- (data_obj, 1003, BigIntegerData, None),
- (data_obj, 1004, LengthModel, 0),
- (data_obj, 1005, LengthModel, 1),
- ]
- if connection.features.interprets_empty_strings_as_nulls:
- test_data = [data for data in test_data
- if not (data[0] == data_obj and
- data[2]._meta.get_field('data').empty_strings_allowed and
- data[3] is None)]
- if connection.features.allows_primary_key_0:
- test_data.extend([
- (data_obj, 0, Anchor, "Anchor 0"),
- (fk_obj, 465, FKData, 0),
- ])
- class SerializerTests(TestCase):
- pass
- def serializerTest(format, self):
-
- objects = []
- instance_count = {}
- for (func, pk, klass, datum) in test_data:
- objects.extend(func[0](pk, klass, datum))
-
- for klass in instance_count:
- instance_count[klass] = klass.objects.count()
-
- objects.extend(Tag.objects.all())
-
- serialized_data = serializers.serialize(format, objects, indent=2)
- for obj in serializers.deserialize(format, serialized_data):
- obj.save()
-
-
- for (func, pk, klass, datum) in test_data:
- func[1](self, pk, klass, datum)
-
-
- for klass, count in instance_count.items():
- self.assertEquals(count, klass.objects.count())
- def fieldsTest(format, self):
- obj = ComplexModel(field1='first', field2='second', field3='third')
- obj.save_base(raw=True)
-
- serialized_data = serializers.serialize(format, [obj], indent=2, fields=('field1','field3'))
- result = serializers.deserialize(format, serialized_data).next()
-
- self.assertEqual(result.object.field1, 'first')
- self.assertEqual(result.object.field2, '')
- self.assertEqual(result.object.field3, 'third')
- def streamTest(format, self):
- obj = ComplexModel(field1='first',field2='second',field3='third')
- obj.save_base(raw=True)
-
- stream = StringIO()
- serializers.serialize(format, [obj], indent=2, stream=stream)
-
- string_data = serializers.serialize(format, [obj], indent=2)
-
- self.assertEqual(string_data, stream.getvalue())
- stream.close()
- def naturalKeyTest(format, self):
- book1 = {'isbn13': '978-1590597255', 'title': 'The Definitive Guide to '
- 'Django: Web Development Done Right'}
- book2 = {'isbn13':'978-1590599969', 'title': 'Practical Django Projects'}
-
- adrian = Book.objects.create(**book1)
- james = Book.objects.create(**book2)
-
- string_data = serializers.serialize(format, Book.objects.all(), indent=2,
- use_natural_keys=True)
-
-
-
- james.delete()
-
- books = list(serializers.deserialize(format, string_data))
- self.assertEqual(len(books), 2)
- self.assertEqual(books[0].object.title, book1['title'])
- self.assertEqual(books[0].object.pk, adrian.pk)
- self.assertEqual(books[1].object.title, book2['title'])
- self.assertEqual(books[1].object.pk, None)
- for format in serializers.get_serializer_formats():
- setattr(SerializerTests, 'test_' + format + '_serializer', curry(serializerTest, format))
- setattr(SerializerTests, 'test_' + format + '_serializer_fields', curry(fieldsTest, format))
- setattr(SerializerTests, 'test_' + format + '_serializer_natural_key',
- curry(naturalKeyTest, format))
- if format != 'python':
- setattr(SerializerTests, 'test_' + format + '_serializer_stream', curry(streamTest, format))
|