2019-06-09 07:56:37 +07:00
|
|
|
import json
|
2009-05-28 05:46:09 +00:00
|
|
|
import os
|
|
|
|
import tempfile
|
2014-07-15 10:35:29 +01:00
|
|
|
import uuid
|
2008-03-20 06:56:23 +00:00
|
|
|
|
2015-01-28 07:35:27 -05:00
|
|
|
from django.contrib.contenttypes.fields import (
|
|
|
|
GenericForeignKey, GenericRelation,
|
|
|
|
)
|
2015-01-06 19:16:35 -05:00
|
|
|
from django.contrib.contenttypes.models import ContentType
|
2015-01-28 07:35:27 -05:00
|
|
|
from django.core.files.storage import FileSystemStorage
|
2019-06-09 07:56:37 +07:00
|
|
|
from django.core.serializers.json import DjangoJSONEncoder
|
2015-01-28 07:35:27 -05:00
|
|
|
from django.db import models
|
2019-08-20 08:54:41 +01:00
|
|
|
from django.db.models.fields.files import ImageFieldFile
|
2019-03-23 17:04:39 +01:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2009-05-28 05:46:09 +00:00
|
|
|
|
2015-01-28 07:35:27 -05:00
|
|
|
try:
|
|
|
|
from PIL import Image
|
|
|
|
except ImportError:
|
|
|
|
Image = None
|
|
|
|
|
2009-05-28 05:46:09 +00:00
|
|
|
|
2008-03-20 06:56:23 +00:00
|
|
|
class Foo(models.Model):
|
|
|
|
a = models.CharField(max_length=10)
|
2008-07-30 00:18:49 +00:00
|
|
|
d = models.DecimalField(max_digits=5, decimal_places=3)
|
2008-03-20 06:56:23 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2008-03-20 06:56:23 +00:00
|
|
|
def get_foo():
|
2015-07-16 08:00:29 -04:00
|
|
|
return Foo.objects.get(id=1).pk
|
2008-03-20 06:56:23 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2008-03-20 06:56:23 +00:00
|
|
|
class Bar(models.Model):
|
|
|
|
b = models.CharField(max_length=10)
|
2017-03-04 15:47:49 +01:00
|
|
|
a = models.ForeignKey(Foo, models.CASCADE, default=get_foo, related_name='bars')
|
2008-03-20 06:56:23 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2008-07-27 07:22:39 +00:00
|
|
|
class Whiz(models.Model):
|
|
|
|
CHOICES = (
|
|
|
|
('Group 1', (
|
2013-10-20 00:33:10 +01:00
|
|
|
(1, 'First'),
|
|
|
|
(2, 'Second'),
|
2013-10-18 10:02:43 +01:00
|
|
|
)
|
2008-07-27 07:22:39 +00:00
|
|
|
),
|
|
|
|
('Group 2', (
|
2013-10-20 00:33:10 +01:00
|
|
|
(3, 'Third'),
|
|
|
|
(4, 'Fourth'),
|
2013-10-18 10:02:43 +01:00
|
|
|
)
|
2008-07-30 00:18:49 +00:00
|
|
|
),
|
2013-10-03 13:44:10 -04:00
|
|
|
(0, 'Other'),
|
2019-03-23 17:04:39 +01:00
|
|
|
(5, _('translated')),
|
2008-07-27 07:22:39 +00:00
|
|
|
)
|
|
|
|
c = models.IntegerField(choices=CHOICES, null=True)
|
2009-05-28 05:46:09 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2019-01-04 14:03:53 -06:00
|
|
|
class WhizDelayed(models.Model):
|
|
|
|
c = models.IntegerField(choices=(), null=True)
|
|
|
|
|
|
|
|
|
|
|
|
# Contrived way of adding choices later.
|
|
|
|
WhizDelayed._meta.get_field('c').choices = Whiz.CHOICES
|
|
|
|
|
|
|
|
|
2014-07-27 23:39:40 +02:00
|
|
|
class WhizIter(models.Model):
|
2017-11-13 23:11:07 +05:00
|
|
|
c = models.IntegerField(choices=iter(Whiz.CHOICES), null=True)
|
2014-07-27 23:39:40 +02:00
|
|
|
|
|
|
|
|
|
|
|
class WhizIterEmpty(models.Model):
|
2017-11-13 23:11:07 +05:00
|
|
|
c = models.CharField(choices=iter(()), blank=True, max_length=1)
|
2014-07-27 23:39:40 +02:00
|
|
|
|
|
|
|
|
2019-01-04 14:03:53 -06:00
|
|
|
class Choiceful(models.Model):
|
|
|
|
no_choices = models.IntegerField(null=True)
|
|
|
|
empty_choices = models.IntegerField(choices=(), null=True)
|
|
|
|
with_choices = models.IntegerField(choices=[(1, 'A')], null=True)
|
|
|
|
empty_choices_bool = models.BooleanField(choices=())
|
|
|
|
empty_choices_text = models.TextField(choices=())
|
|
|
|
|
|
|
|
|
2008-11-12 00:35:24 +00:00
|
|
|
class BigD(models.Model):
|
2017-05-10 17:33:46 +02:00
|
|
|
d = models.DecimalField(max_digits=32, decimal_places=30)
|
2008-07-30 00:18:49 +00:00
|
|
|
|
2014-03-12 20:34:05 +02:00
|
|
|
|
2014-03-10 15:17:57 +00:00
|
|
|
class FloatModel(models.Model):
|
|
|
|
size = models.FloatField()
|
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2008-12-02 18:40:40 +00:00
|
|
|
class BigS(models.Model):
|
2009-05-28 05:46:09 +00:00
|
|
|
s = models.SlugField(max_length=255)
|
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2015-04-15 16:28:49 -06:00
|
|
|
class UnicodeSlugField(models.Model):
|
|
|
|
s = models.SlugField(max_length=255, allow_unicode=True)
|
|
|
|
|
|
|
|
|
2017-07-13 13:55:23 +02:00
|
|
|
class AutoModel(models.Model):
|
|
|
|
value = models.AutoField(primary_key=True)
|
|
|
|
|
|
|
|
|
|
|
|
class BigAutoModel(models.Model):
|
|
|
|
value = models.BigAutoField(primary_key=True)
|
|
|
|
|
|
|
|
|
|
|
|
class SmallAutoModel(models.Model):
|
|
|
|
value = models.SmallAutoField(primary_key=True)
|
|
|
|
|
|
|
|
|
2014-03-03 20:12:42 -05:00
|
|
|
class SmallIntegerModel(models.Model):
|
|
|
|
value = models.SmallIntegerField()
|
|
|
|
|
|
|
|
|
|
|
|
class IntegerModel(models.Model):
|
|
|
|
value = models.IntegerField()
|
|
|
|
|
|
|
|
|
|
|
|
class BigIntegerModel(models.Model):
|
2009-12-17 15:10:38 +00:00
|
|
|
value = models.BigIntegerField()
|
2013-10-03 13:44:10 -04:00
|
|
|
null_value = models.BigIntegerField(null=True, blank=True)
|
|
|
|
|
2009-05-28 05:46:09 +00:00
|
|
|
|
2019-10-16 09:32:12 -03:00
|
|
|
class PositiveBigIntegerModel(models.Model):
|
|
|
|
value = models.PositiveBigIntegerField()
|
|
|
|
|
|
|
|
|
2014-03-03 20:12:42 -05:00
|
|
|
class PositiveSmallIntegerModel(models.Model):
|
|
|
|
value = models.PositiveSmallIntegerField()
|
|
|
|
|
|
|
|
|
|
|
|
class PositiveIntegerModel(models.Model):
|
|
|
|
value = models.PositiveIntegerField()
|
|
|
|
|
|
|
|
|
2010-01-09 22:05:10 +00:00
|
|
|
class Post(models.Model):
|
|
|
|
title = models.CharField(max_length=100)
|
|
|
|
body = models.TextField()
|
2010-03-10 07:42:25 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2010-03-10 07:42:25 +00:00
|
|
|
class NullBooleanModel(models.Model):
|
2017-05-06 10:56:28 -04:00
|
|
|
nbfield = models.BooleanField(null=True, blank=True)
|
2010-03-10 07:42:25 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2010-04-01 15:10:53 +00:00
|
|
|
class BooleanModel(models.Model):
|
2016-03-21 21:06:54 -04:00
|
|
|
bfield = models.BooleanField()
|
2010-04-09 12:39:08 +00:00
|
|
|
string = models.CharField(max_length=10, default='abc')
|
2010-03-10 07:42:25 +00:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2014-03-12 23:43:45 +02:00
|
|
|
class DateTimeModel(models.Model):
|
|
|
|
d = models.DateField()
|
|
|
|
dt = models.DateTimeField()
|
|
|
|
t = models.TimeField()
|
|
|
|
|
|
|
|
|
2014-07-24 13:57:24 +01:00
|
|
|
class DurationModel(models.Model):
|
|
|
|
field = models.DurationField()
|
|
|
|
|
|
|
|
|
2015-01-02 02:47:49 +01:00
|
|
|
class NullDurationModel(models.Model):
|
|
|
|
field = models.DurationField(null=True)
|
|
|
|
|
|
|
|
|
2013-09-29 15:56:04 -04:00
|
|
|
class PrimaryKeyCharModel(models.Model):
|
|
|
|
string = models.CharField(max_length=10, primary_key=True)
|
|
|
|
|
|
|
|
|
2012-10-26 00:25:59 +01:00
|
|
|
class FksToBooleans(models.Model):
|
2014-04-26 10:18:45 -07:00
|
|
|
"""Model with FKs to models with {Null,}BooleanField's, #15040"""
|
2015-07-22 09:43:21 -05:00
|
|
|
bf = models.ForeignKey(BooleanModel, models.CASCADE)
|
|
|
|
nbf = models.ForeignKey(NullBooleanModel, models.CASCADE)
|
2012-10-26 00:25:59 +01:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2013-09-29 15:56:04 -04:00
|
|
|
class FkToChar(models.Model):
|
|
|
|
"""Model with FK to a model with a CharField primary key, #19299"""
|
2015-07-22 09:43:21 -05:00
|
|
|
out = models.ForeignKey(PrimaryKeyCharModel, models.CASCADE)
|
2013-09-29 15:56:04 -04:00
|
|
|
|
|
|
|
|
2011-08-13 11:53:42 +00:00
|
|
|
class RenamedField(models.Model):
|
2013-10-03 13:44:10 -04:00
|
|
|
modelname = models.IntegerField(name="fieldname", choices=((1, 'One'),))
|
|
|
|
|
2011-08-13 11:53:42 +00:00
|
|
|
|
2012-09-01 18:32:27 +02:00
|
|
|
class VerboseNameField(models.Model):
|
|
|
|
id = models.AutoField("verbose pk", primary_key=True)
|
|
|
|
field1 = models.BigIntegerField("verbose field1")
|
2013-08-11 21:19:09 +01:00
|
|
|
field2 = models.BooleanField("verbose field2", default=False)
|
2012-09-01 18:32:27 +02:00
|
|
|
field3 = models.CharField("verbose field3", max_length=10)
|
2016-12-31 10:30:41 -05:00
|
|
|
field4 = models.DateField("verbose field4")
|
|
|
|
field5 = models.DateTimeField("verbose field5")
|
|
|
|
field6 = models.DecimalField("verbose field6", max_digits=6, decimal_places=1)
|
|
|
|
field7 = models.EmailField("verbose field7")
|
|
|
|
field8 = models.FileField("verbose field8", upload_to="unused")
|
|
|
|
field9 = models.FilePathField("verbose field9")
|
|
|
|
field10 = models.FloatField("verbose field10")
|
2014-03-21 10:54:53 -04:00
|
|
|
# Don't want to depend on Pillow in this test
|
2015-02-05 13:25:34 -05:00
|
|
|
# field_image = models.ImageField("verbose field")
|
2016-12-31 10:30:41 -05:00
|
|
|
field11 = models.IntegerField("verbose field11")
|
|
|
|
field12 = models.GenericIPAddressField("verbose field12", protocol="ipv4")
|
2021-01-13 21:28:09 +01:00
|
|
|
field13 = models.PositiveIntegerField("verbose field13")
|
|
|
|
field14 = models.PositiveSmallIntegerField("verbose field14")
|
|
|
|
field15 = models.SlugField("verbose field15")
|
|
|
|
field16 = models.SmallIntegerField("verbose field16")
|
|
|
|
field17 = models.TextField("verbose field17")
|
|
|
|
field18 = models.TimeField("verbose field18")
|
|
|
|
field19 = models.URLField("verbose field19")
|
|
|
|
field20 = models.UUIDField("verbose field20")
|
|
|
|
field21 = models.DurationField("verbose field21")
|
2012-09-01 18:32:27 +02:00
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2015-01-05 21:32:25 +11:00
|
|
|
class GenericIPAddress(models.Model):
|
|
|
|
ip = models.GenericIPAddressField(null=True, protocol='ipv4')
|
|
|
|
|
|
|
|
|
2014-05-16 14:25:45 +02:00
|
|
|
###############################################################################
|
|
|
|
# These models aren't used in any test, just here to ensure they validate
|
|
|
|
# successfully.
|
|
|
|
|
2011-11-12 19:53:56 +00:00
|
|
|
# See ticket #16570.
|
|
|
|
class DecimalLessThanOne(models.Model):
|
|
|
|
d = models.DecimalField(max_digits=3, decimal_places=3)
|
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2014-05-16 14:25:45 +02:00
|
|
|
# See ticket #18389.
|
|
|
|
class FieldClassAttributeModel(models.Model):
|
|
|
|
field_class = models.CharField
|
|
|
|
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
|
2012-12-13 22:11:06 +01:00
|
|
|
class DataModel(models.Model):
|
|
|
|
short_data = models.BinaryField(max_length=10, default=b'\x08')
|
|
|
|
data = models.BinaryField()
|
|
|
|
|
2010-10-01 02:02:58 +00:00
|
|
|
###############################################################################
|
|
|
|
# FileField
|
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2010-10-01 02:02:58 +00:00
|
|
|
class Document(models.Model):
|
2016-09-20 22:31:23 +01:00
|
|
|
myfile = models.FileField(upload_to='unused', unique=True)
|
2010-10-01 02:02:58 +00:00
|
|
|
|
2016-11-12 20:41:23 +03:30
|
|
|
|
2009-05-28 05:46:09 +00:00
|
|
|
###############################################################################
|
|
|
|
# ImageField
|
|
|
|
|
2014-03-21 10:54:53 -04:00
|
|
|
# If Pillow available, do these tests.
|
2009-05-28 05:46:09 +00:00
|
|
|
if Image:
|
|
|
|
class TestImageFieldFile(ImageFieldFile):
|
|
|
|
"""
|
|
|
|
Custom Field File class that records whether or not the underlying file
|
|
|
|
was opened.
|
|
|
|
"""
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
self.was_opened = False
|
2017-01-21 18:43:44 +05:30
|
|
|
super().__init__(*args, **kwargs)
|
2013-10-03 13:44:10 -04:00
|
|
|
|
2009-05-28 05:46:09 +00:00
|
|
|
def open(self):
|
|
|
|
self.was_opened = True
|
2017-01-21 18:43:44 +05:30
|
|
|
super().open()
|
2009-05-28 05:46:09 +00:00
|
|
|
|
2019-08-20 08:54:41 +01:00
|
|
|
class TestImageField(models.ImageField):
|
2009-05-28 05:46:09 +00:00
|
|
|
attr_class = TestImageFieldFile
|
|
|
|
|
|
|
|
# Set up a temp directory for file storage.
|
2015-02-21 18:56:36 +01:00
|
|
|
temp_storage_dir = tempfile.mkdtemp()
|
2009-05-28 05:46:09 +00:00
|
|
|
temp_storage = FileSystemStorage(temp_storage_dir)
|
|
|
|
temp_upload_to_dir = os.path.join(temp_storage.location, 'tests')
|
|
|
|
|
|
|
|
class Person(models.Model):
|
|
|
|
"""
|
|
|
|
Model that defines an ImageField with no dimension fields.
|
|
|
|
"""
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
mugshot = TestImageField(storage=temp_storage, upload_to='tests')
|
|
|
|
|
2015-12-02 23:55:50 +00:00
|
|
|
class AbstractPersonWithHeight(models.Model):
|
2009-05-28 05:46:09 +00:00
|
|
|
"""
|
2013-10-03 13:44:10 -04:00
|
|
|
Abstract model that defines an ImageField with only one dimension field
|
|
|
|
to make sure the dimension update is correctly run on concrete subclass
|
|
|
|
instance post-initialization.
|
2009-05-28 05:46:09 +00:00
|
|
|
"""
|
|
|
|
mugshot = TestImageField(storage=temp_storage, upload_to='tests',
|
|
|
|
height_field='mugshot_height')
|
|
|
|
mugshot_height = models.PositiveSmallIntegerField()
|
|
|
|
|
2013-10-03 13:44:10 -04:00
|
|
|
class Meta:
|
|
|
|
abstract = True
|
|
|
|
|
2015-12-02 23:55:50 +00:00
|
|
|
class PersonWithHeight(AbstractPersonWithHeight):
|
2013-10-03 13:44:10 -04:00
|
|
|
"""
|
2015-12-02 23:55:50 +00:00
|
|
|
Concrete model that subclass an abstract one with only on dimension
|
2013-10-03 13:44:10 -04:00
|
|
|
field.
|
|
|
|
"""
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
|
2009-05-28 05:46:09 +00:00
|
|
|
class PersonWithHeightAndWidth(models.Model):
|
|
|
|
"""
|
|
|
|
Model that defines height and width fields after the ImageField.
|
|
|
|
"""
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
mugshot = TestImageField(storage=temp_storage, upload_to='tests',
|
|
|
|
height_field='mugshot_height',
|
|
|
|
width_field='mugshot_width')
|
|
|
|
mugshot_height = models.PositiveSmallIntegerField()
|
|
|
|
mugshot_width = models.PositiveSmallIntegerField()
|
|
|
|
|
|
|
|
class PersonDimensionsFirst(models.Model):
|
|
|
|
"""
|
|
|
|
Model that defines height and width fields before the ImageField.
|
|
|
|
"""
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
mugshot_height = models.PositiveSmallIntegerField()
|
|
|
|
mugshot_width = models.PositiveSmallIntegerField()
|
|
|
|
mugshot = TestImageField(storage=temp_storage, upload_to='tests',
|
|
|
|
height_field='mugshot_height',
|
|
|
|
width_field='mugshot_width')
|
|
|
|
|
|
|
|
class PersonTwoImages(models.Model):
|
|
|
|
"""
|
|
|
|
Model that:
|
|
|
|
* Defines two ImageFields
|
|
|
|
* Defines the height/width fields before the ImageFields
|
2015-12-02 23:55:50 +00:00
|
|
|
* Has a nullable ImageField
|
2009-05-28 05:46:09 +00:00
|
|
|
"""
|
|
|
|
name = models.CharField(max_length=50)
|
|
|
|
mugshot_height = models.PositiveSmallIntegerField()
|
|
|
|
mugshot_width = models.PositiveSmallIntegerField()
|
|
|
|
mugshot = TestImageField(storage=temp_storage, upload_to='tests',
|
|
|
|
height_field='mugshot_height',
|
|
|
|
width_field='mugshot_width')
|
|
|
|
headshot_height = models.PositiveSmallIntegerField(
|
2013-10-20 00:33:10 +01:00
|
|
|
blank=True, null=True)
|
2009-05-28 05:46:09 +00:00
|
|
|
headshot_width = models.PositiveSmallIntegerField(
|
2013-10-20 00:33:10 +01:00
|
|
|
blank=True, null=True)
|
2009-05-28 05:46:09 +00:00
|
|
|
headshot = TestImageField(blank=True, null=True,
|
|
|
|
storage=temp_storage, upload_to='tests',
|
|
|
|
height_field='headshot_height',
|
|
|
|
width_field='headshot_width')
|
|
|
|
|
2015-01-06 19:16:35 -05:00
|
|
|
|
2019-06-09 07:56:37 +07:00
|
|
|
class CustomJSONDecoder(json.JSONDecoder):
|
|
|
|
def __init__(self, object_hook=None, *args, **kwargs):
|
|
|
|
return super().__init__(object_hook=self.as_uuid, *args, **kwargs)
|
|
|
|
|
|
|
|
def as_uuid(self, dct):
|
|
|
|
if 'uuid' in dct:
|
|
|
|
dct['uuid'] = uuid.UUID(dct['uuid'])
|
|
|
|
return dct
|
|
|
|
|
|
|
|
|
|
|
|
class JSONModel(models.Model):
|
|
|
|
value = models.JSONField()
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
required_db_features = {'supports_json_field'}
|
|
|
|
|
|
|
|
|
|
|
|
class NullableJSONModel(models.Model):
|
|
|
|
value = models.JSONField(blank=True, null=True)
|
|
|
|
value_custom = models.JSONField(
|
|
|
|
encoder=DjangoJSONEncoder,
|
|
|
|
decoder=CustomJSONDecoder,
|
|
|
|
null=True,
|
|
|
|
)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
required_db_features = {'supports_json_field'}
|
|
|
|
|
|
|
|
|
2020-11-15 22:43:47 +00:00
|
|
|
class RelatedJSONModel(models.Model):
|
|
|
|
value = models.JSONField()
|
|
|
|
json_model = models.ForeignKey(NullableJSONModel, models.CASCADE)
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
required_db_features = {'supports_json_field'}
|
|
|
|
|
|
|
|
|
2015-01-06 19:16:35 -05:00
|
|
|
class AllFieldsModel(models.Model):
|
|
|
|
big_integer = models.BigIntegerField()
|
|
|
|
binary = models.BinaryField()
|
|
|
|
boolean = models.BooleanField(default=False)
|
|
|
|
char = models.CharField(max_length=10)
|
|
|
|
date = models.DateField()
|
|
|
|
datetime = models.DateTimeField()
|
|
|
|
decimal = models.DecimalField(decimal_places=2, max_digits=2)
|
|
|
|
duration = models.DurationField()
|
|
|
|
email = models.EmailField()
|
|
|
|
file_path = models.FilePathField()
|
|
|
|
floatf = models.FloatField()
|
|
|
|
integer = models.IntegerField()
|
|
|
|
generic_ip = models.GenericIPAddressField()
|
|
|
|
positive_integer = models.PositiveIntegerField()
|
|
|
|
positive_small_integer = models.PositiveSmallIntegerField()
|
|
|
|
slug = models.SlugField()
|
|
|
|
small_integer = models.SmallIntegerField()
|
|
|
|
text = models.TextField()
|
|
|
|
time = models.TimeField()
|
|
|
|
url = models.URLField()
|
|
|
|
uuid = models.UUIDField()
|
|
|
|
|
2019-08-20 08:54:41 +01:00
|
|
|
fo = models.ForeignObject(
|
2015-01-06 19:16:35 -05:00
|
|
|
'self',
|
2015-07-22 09:43:21 -05:00
|
|
|
on_delete=models.CASCADE,
|
2019-02-19 01:32:33 -05:00
|
|
|
from_fields=['positive_integer'],
|
2015-01-06 19:16:35 -05:00
|
|
|
to_fields=['id'],
|
|
|
|
related_name='reverse'
|
|
|
|
)
|
2019-08-20 08:54:41 +01:00
|
|
|
fk = models.ForeignKey(
|
2015-01-06 19:16:35 -05:00
|
|
|
'self',
|
2015-07-22 09:43:21 -05:00
|
|
|
models.CASCADE,
|
2015-01-06 19:16:35 -05:00
|
|
|
related_name='reverse2'
|
|
|
|
)
|
2019-08-20 08:54:41 +01:00
|
|
|
m2m = models.ManyToManyField('self')
|
|
|
|
oto = models.OneToOneField('self', models.CASCADE)
|
2015-01-06 19:16:35 -05:00
|
|
|
|
|
|
|
object_id = models.PositiveIntegerField()
|
2015-07-22 09:43:21 -05:00
|
|
|
content_type = models.ForeignKey(ContentType, models.CASCADE)
|
2015-01-06 19:16:35 -05:00
|
|
|
gfk = GenericForeignKey()
|
|
|
|
gr = GenericRelation(DataModel)
|
|
|
|
|
|
|
|
|
2017-08-31 09:34:44 -04:00
|
|
|
class ManyToMany(models.Model):
|
|
|
|
m2m = models.ManyToManyField('self')
|
|
|
|
|
|
|
|
|
2009-05-28 05:46:09 +00:00
|
|
|
###############################################################################
|
2014-07-15 10:35:29 +01:00
|
|
|
|
|
|
|
|
|
|
|
class UUIDModel(models.Model):
|
|
|
|
field = models.UUIDField()
|
|
|
|
|
|
|
|
|
|
|
|
class NullableUUIDModel(models.Model):
|
|
|
|
field = models.UUIDField(blank=True, null=True)
|
|
|
|
|
|
|
|
|
|
|
|
class PrimaryKeyUUIDModel(models.Model):
|
|
|
|
id = models.UUIDField(primary_key=True, default=uuid.uuid4)
|
2015-02-12 01:28:24 -05:00
|
|
|
|
|
|
|
|
2015-02-14 19:37:12 +00:00
|
|
|
class RelatedToUUIDModel(models.Model):
|
2015-07-22 09:43:21 -05:00
|
|
|
uuid_fk = models.ForeignKey('PrimaryKeyUUIDModel', models.CASCADE)
|
2015-05-13 02:34:56 +05:30
|
|
|
|
|
|
|
|
|
|
|
class UUIDChild(PrimaryKeyUUIDModel):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class UUIDGrandchild(UUIDChild):
|
|
|
|
pass
|