summaryrefslogtreecommitdiff
path: root/tests/serializers/test_data.py
diff options
context:
space:
mode:
Diffstat (limited to 'tests/serializers/test_data.py')
-rw-r--r--tests/serializers/test_data.py216
1 files changed, 136 insertions, 80 deletions
diff --git a/tests/serializers/test_data.py b/tests/serializers/test_data.py
index 91cad48e0f..330e5016e4 100644
--- a/tests/serializers/test_data.py
+++ b/tests/serializers/test_data.py
@@ -15,18 +15,62 @@ from django.db import connection, models
from django.test import TestCase
from .models import (
- Anchor, AutoNowDateTimeData, BigIntegerData, BinaryData, BooleanData,
- BooleanPKData, CharData, CharPKData, DateData, DatePKData, DateTimeData,
- DateTimePKData, DecimalData, DecimalPKData, EmailData, EmailPKData,
- ExplicitInheritBaseModel, FileData, FilePathData, FilePathPKData, FKData,
- FKDataToField, FKDataToO2O, FKSelfData, FKToUUID, FloatData, FloatPKData,
- GenericData, GenericIPAddressData, GenericIPAddressPKData,
- InheritAbstractModel, InheritBaseModel, IntegerData, IntegerPKData,
- Intermediate, LengthModel, M2MData, M2MIntermediateData, M2MSelfData,
- ModifyingSaveData, O2OData, PositiveBigIntegerData, PositiveIntegerData,
- PositiveIntegerPKData, PositiveSmallIntegerData,
- PositiveSmallIntegerPKData, SlugData, SlugPKData, SmallData, SmallPKData,
- Tag, TextData, TimeData, UniqueAnchor, UUIDData, UUIDDefaultData,
+ Anchor,
+ AutoNowDateTimeData,
+ BigIntegerData,
+ BinaryData,
+ BooleanData,
+ BooleanPKData,
+ CharData,
+ CharPKData,
+ DateData,
+ DatePKData,
+ DateTimeData,
+ DateTimePKData,
+ DecimalData,
+ DecimalPKData,
+ EmailData,
+ EmailPKData,
+ ExplicitInheritBaseModel,
+ FileData,
+ FilePathData,
+ FilePathPKData,
+ FKData,
+ FKDataToField,
+ FKDataToO2O,
+ FKSelfData,
+ FKToUUID,
+ FloatData,
+ FloatPKData,
+ GenericData,
+ GenericIPAddressData,
+ GenericIPAddressPKData,
+ InheritAbstractModel,
+ InheritBaseModel,
+ IntegerData,
+ IntegerPKData,
+ Intermediate,
+ LengthModel,
+ M2MData,
+ M2MIntermediateData,
+ M2MSelfData,
+ ModifyingSaveData,
+ O2OData,
+ PositiveBigIntegerData,
+ PositiveIntegerData,
+ PositiveIntegerPKData,
+ PositiveSmallIntegerData,
+ PositiveSmallIntegerPKData,
+ SlugData,
+ SlugPKData,
+ SmallData,
+ SmallPKData,
+ Tag,
+ TextData,
+ TimeData,
+ UniqueAnchor,
+ UUIDData,
+ UUIDDefaultData,
)
from .tests import register_tests
@@ -55,7 +99,7 @@ def generic_create(pk, klass, data):
def fk_create(pk, klass, data):
instance = klass(id=pk)
- setattr(instance, 'data_id', data)
+ setattr(instance, "data_id", data)
models.Model.save_base(instance, raw=True)
return [instance]
@@ -75,10 +119,10 @@ def im2m_create(pk, klass, data):
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']
+ 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]
@@ -110,6 +154,7 @@ def inherited_create(pk, klass, data):
created.append(klass.objects.get(id=pk))
return created
+
# A set of functions that can be used to compare
# test data objects of various kinds
@@ -118,25 +163,36 @@ def data_compare(testcase, pk, klass, data):
instance = klass.objects.get(id=pk)
if klass == BinaryData and data is not None:
testcase.assertEqual(
- bytes(data), bytes(instance.data),
- "Objects with PK=%d not equal; expected '%s' (%s), got '%s' (%s)" % (
- pk, repr(bytes(data)), type(data), repr(bytes(instance.data)),
+ bytes(data),
+ bytes(instance.data),
+ "Objects with PK=%d not equal; expected '%s' (%s), got '%s' (%s)"
+ % (
+ pk,
+ repr(bytes(data)),
+ type(data),
+ repr(bytes(instance.data)),
type(instance.data),
- )
+ ),
)
else:
testcase.assertEqual(
- data, instance.data,
- "Objects with PK=%d not equal; expected '%s' (%s), got '%s' (%s)" % (
- pk, data, type(data), instance, type(instance.data),
- )
+ data,
+ instance.data,
+ "Objects with PK=%d not equal; expected '%s' (%s), got '%s' (%s)"
+ % (
+ pk,
+ data,
+ type(data),
+ instance,
+ 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')])
+ testcase.assertEqual(data[1:], [t.data for t in instance.tags.order_by("id")])
def fk_compare(testcase, pk, klass, data):
@@ -146,7 +202,7 @@ def fk_compare(testcase, pk, klass, data):
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')])
+ testcase.assertEqual(data, [obj.id for obj in instance.data.order_by("id")])
def im2m_compare(testcase, pk, klass, data):
@@ -156,10 +212,10 @@ def im2m_compare(testcase, pk, klass, data):
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)
+ 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)
@@ -209,7 +265,7 @@ test_data = [
(data_obj, 15, CharData, None),
# (We use something that will fit into a latin1 database encoding here,
# because that is still the default used on many system setups.)
- (data_obj, 16, CharData, '\xa5'),
+ (data_obj, 16, CharData, "\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)),
@@ -217,15 +273,15 @@ test_data = [
(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, 50, FileData, "file:///foo/bar/whiz.txt"),
# (data_obj, 51, FileData, None),
(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, 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),
@@ -251,38 +307,36 @@ test_data = [
(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.
+ (
+ data_obj,
+ 160,
+ TextData,
+ """This is a long piece of text.
It contains line breaks.
Several of them.
-The end."""),
+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),
-
- (generic_obj, 200, GenericData, ['Generic Object 1', 'tag1', 'tag2']),
- (generic_obj, 201, GenericData, ['Generic Object 2', 'tag2', 'tag3']),
-
+ (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), # Post reference
(fk_obj, 401, FKData, 500), # Pre reference
(fk_obj, 402, FKData, None), # Empty reference
-
(m2m_obj, 410, M2MData, []), # Empty set
(m2m_obj, 411, M2MData, [300, 301]), # Post reference
(m2m_obj, 412, M2MData, [500, 501]), # Pre reference
(m2m_obj, 413, M2MData, [300, 301, 500, 501]), # Pre and Post reference
-
(o2o_obj, None, O2OData, 300), # Post reference
(o2o_obj, None, O2OData, 500), # Pre reference
-
(fk_obj, 430, FKSelfData, 431), # Pre reference
(fk_obj, 431, FKSelfData, 430), # Post reference
(fk_obj, 432, FKSelfData, None), # Empty reference
-
(m2m_obj, 440, M2MSelfData, []),
(m2m_obj, 441, M2MSelfData, []),
(m2m_obj, 442, M2MSelfData, [440, 441]),
@@ -290,31 +344,24 @@ The end."""),
(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),
-
# testing post- and pre-references and extra fields
- (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"}),
-
+ (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"),
@@ -323,9 +370,9 @@ The end."""),
(pk_obj, 640, EmailPKData, "hovercraft@example.com"),
# (pk_obj, 650, FilePKData, 'file:///foo/bar/whiz.txt'),
(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, 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),
@@ -349,14 +396,16 @@ The end."""),
(pk_obj, 791, UUIDData, uuid_obj),
(fk_obj, 792, FKToUUID, uuid_obj),
(pk_obj, 793, UUIDDefaultData, uuid_obj),
-
(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}),
-
+ (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),
@@ -370,10 +419,15 @@ The end."""),
# when field.empty_strings_allowed is True and the value is None; skip these
# tests.
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)]
+ 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
+ )
+ ]
class SerializerDataTests(TestCase):
@@ -385,10 +439,12 @@ def serializerTest(self, format):
# NO_AUTO_VALUE_ON_ZERO SQL mode since it won't let you create an object
# with an autoincrement primary key of 0.
if connection.features.allows_auto_pk_0:
- test_data.extend([
- (data_obj, 0, Anchor, 'Anchor 0'),
- (fk_obj, 465, FKData, 0),
- ])
+ test_data.extend(
+ [
+ (data_obj, 0, Anchor, "Anchor 0"),
+ (fk_obj, 465, FKData, 0),
+ ]
+ )
# Create all the objects defined in the test data
objects = []
@@ -421,4 +477,4 @@ def serializerTest(self, format):
self.assertEqual(count, klass.objects.count())
-register_tests(SerializerDataTests, 'test_%s_serializer', serializerTest)
+register_tests(SerializerDataTests, "test_%s_serializer", serializerTest)