2010-04-15 12:41:08 +00:00
|
|
|
import datetime
|
2011-10-13 21:34:56 +00:00
|
|
|
|
2015-01-28 12:35:27 +00:00
|
|
|
from django.db import DJANGO_VERSION_PICKLE_KEY, models
|
2017-01-26 19:58:33 +00:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2010-03-27 15:54:31 +00:00
|
|
|
|
2011-10-13 21:34:56 +00:00
|
|
|
|
2013-03-29 12:32:21 +00:00
|
|
|
def standalone_number():
|
2010-04-21 16:34:33 +00:00
|
|
|
return 1
|
|
|
|
|
2013-11-02 21:34:05 +00:00
|
|
|
|
2017-01-19 07:39:46 +00:00
|
|
|
class Numbers:
|
2010-04-21 16:34:33 +00:00
|
|
|
@staticmethod
|
2013-03-29 12:32:21 +00:00
|
|
|
def get_static_number():
|
2010-04-21 16:34:33 +00:00
|
|
|
return 2
|
2010-04-15 12:41:08 +00:00
|
|
|
|
2013-11-02 21:34:05 +00:00
|
|
|
|
2014-06-06 11:10:20 +00:00
|
|
|
class PreviousDjangoVersionQuerySet(models.QuerySet):
|
|
|
|
def __getstate__(self):
|
2017-01-21 13:13:44 +00:00
|
|
|
state = super().__getstate__()
|
2015-04-01 23:15:27 +00:00
|
|
|
state[DJANGO_VERSION_PICKLE_KEY] = '1.0'
|
2014-06-06 11:10:20 +00:00
|
|
|
return state
|
|
|
|
|
|
|
|
|
|
|
|
class MissingDjangoVersionQuerySet(models.QuerySet):
|
|
|
|
def __getstate__(self):
|
2017-01-21 13:13:44 +00:00
|
|
|
state = super().__getstate__()
|
2014-06-06 11:10:20 +00:00
|
|
|
del state[DJANGO_VERSION_PICKLE_KEY]
|
|
|
|
return state
|
|
|
|
|
|
|
|
|
2010-03-27 15:54:31 +00:00
|
|
|
class Group(models.Model):
|
|
|
|
name = models.CharField(_('name'), max_length=100)
|
2014-06-06 11:10:20 +00:00
|
|
|
objects = models.Manager()
|
|
|
|
previous_django_version_objects = PreviousDjangoVersionQuerySet.as_manager()
|
|
|
|
missing_django_version_objects = MissingDjangoVersionQuerySet.as_manager()
|
2010-03-27 15:54:31 +00:00
|
|
|
|
2013-11-02 21:34:05 +00:00
|
|
|
|
2010-03-27 15:54:31 +00:00
|
|
|
class Event(models.Model):
|
2014-12-24 13:58:32 +00:00
|
|
|
title = models.CharField(max_length=100)
|
2015-07-22 14:43:21 +00:00
|
|
|
group = models.ForeignKey(Group, models.CASCADE)
|
2010-04-15 12:41:08 +00:00
|
|
|
|
2013-11-02 21:34:05 +00:00
|
|
|
|
2010-04-15 12:41:08 +00:00
|
|
|
class Happening(models.Model):
|
|
|
|
when = models.DateTimeField(blank=True, default=datetime.datetime.now)
|
2015-07-16 01:18:07 +00:00
|
|
|
name = models.CharField(blank=True, max_length=100, default="test")
|
2010-04-21 16:34:33 +00:00
|
|
|
number1 = models.IntegerField(blank=True, default=standalone_number)
|
2016-12-01 10:38:01 +00:00
|
|
|
number2 = models.IntegerField(blank=True, default=Numbers.get_static_number)
|
2017-10-19 01:43:53 +00:00
|
|
|
event = models.OneToOneField(Event, models.CASCADE, null=True)
|
2013-05-21 09:57:24 +00:00
|
|
|
|
2013-11-02 21:34:05 +00:00
|
|
|
|
2017-01-19 07:39:46 +00:00
|
|
|
class Container:
|
2013-05-21 09:57:24 +00:00
|
|
|
# To test pickling we need a class that isn't defined on module, but
|
|
|
|
# is still available from app-cache. So, the Container class moves
|
|
|
|
# SomeModel outside of module level
|
|
|
|
class SomeModel(models.Model):
|
|
|
|
somefield = models.IntegerField()
|
|
|
|
|
2013-11-02 21:34:05 +00:00
|
|
|
|
2013-05-21 09:57:24 +00:00
|
|
|
class M2MModel(models.Model):
|
|
|
|
groups = models.ManyToManyField(Group)
|
2019-12-11 14:25:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
class AbstractEvent(Event):
|
|
|
|
class Meta:
|
|
|
|
abstract = True
|
|
|
|
ordering = ['title']
|
|
|
|
|
|
|
|
|
|
|
|
class MyEvent(AbstractEvent):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
|
|
class Edition(models.Model):
|
|
|
|
event = models.ForeignKey('MyEvent', on_delete=models.CASCADE)
|