/
models.py
114 lines (69 loc) · 3.63 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import django
from django.db import models
from django.db.models.signals import pre_save
from django.utils import timezone
from dirtyfields import DirtyFieldsMixin
from dirtyfields.compare import timezone_support_compare
from tests.utils import is_postgresql_env_with_json_field
class TestModel(DirtyFieldsMixin, models.Model):
"""A simple test model to test dirty fields mixin with"""
boolean = models.BooleanField(default=True)
characters = models.CharField(blank=True, max_length=80)
class TestModelWithDecimalField(DirtyFieldsMixin, models.Model):
decimal_field = models.DecimalField(decimal_places=2, max_digits=10)
class TestModelWithForeignKey(DirtyFieldsMixin, models.Model):
fkey = models.ForeignKey(TestModel)
class TestMixedFieldsModel(DirtyFieldsMixin, models.Model):
fkey = models.ForeignKey(TestModel)
characters = models.CharField(blank=True, max_length=80)
class TestModelWithOneToOneField(DirtyFieldsMixin, models.Model):
o2o = models.OneToOneField(TestModel)
class TestModelWithNonEditableFields(DirtyFieldsMixin, models.Model):
dt = models.DateTimeField(auto_now_add=True)
characters = models.CharField(blank=True, max_length=80,
editable=False)
boolean = models.BooleanField(default=True)
class TestModelWithSelfForeignKey(DirtyFieldsMixin, models.Model):
fkey = models.ForeignKey("self", blank=True, null=True)
class OrdinaryTestModel(models.Model):
boolean = models.BooleanField(default=True)
characters = models.CharField(blank=True, max_length=80)
class OrdinaryTestModelWithForeignKey(models.Model):
fkey = models.ForeignKey(OrdinaryTestModel)
class SubclassModel(TestModel):
pass
class TestExpressionModel(DirtyFieldsMixin, models.Model):
counter = models.IntegerField(default=0)
class TestDatetimeModel(DirtyFieldsMixin, models.Model):
compare_function = (timezone_support_compare, {})
datetime_field = models.DateTimeField(default=timezone.now)
class TestCurrentDatetimeModel(DirtyFieldsMixin, models.Model):
compare_function = (timezone_support_compare, {'timezone_to_set': timezone.get_current_timezone()})
datetime_field = models.DateTimeField(default=timezone.now)
class TestM2MModel(DirtyFieldsMixin, models.Model):
m2m_field = models.ManyToManyField(TestModel)
ENABLE_M2M_CHECK = True
class TestM2MModelWithoutM2MModeEnabled(DirtyFieldsMixin, models.Model):
m2m_field = models.ManyToManyField(TestModel)
class TestModelWithCustomPK(DirtyFieldsMixin, models.Model):
custom_primary_key = models.CharField(max_length=80, primary_key=True)
class TestM2MModelWithCustomPKOnM2M(DirtyFieldsMixin, models.Model):
m2m_field = models.ManyToManyField(TestModelWithCustomPK)
class TestModelWithPreSaveSignal(DirtyFieldsMixin, models.Model):
data = models.CharField(max_length=255)
data_updated_on_presave = models.CharField(max_length=255, blank=True, null=True)
@staticmethod
def pre_save(instance, *args, **kwargs):
dirty_fields = instance.get_dirty_fields()
# only works for case2
if 'data' in dirty_fields:
if 'specific_value' in instance.data:
instance.data_updated_on_presave = 'presave_value'
pre_save.connect(TestModelWithPreSaveSignal.pre_save, sender=TestModelWithPreSaveSignal)
class TestModelWithoutM2MCheck(DirtyFieldsMixin, models.Model):
characters = models.CharField(blank=True, max_length=80)
ENABLE_M2M_CHECK = False
if is_postgresql_env_with_json_field():
from django.contrib.postgres.fields import JSONField
class TestModelWithJSONField(DirtyFieldsMixin, models.Model):
json_field = JSONField()