summaryrefslogtreecommitdiff
path: root/tests/lookup
diff options
context:
space:
mode:
authorSergey Fedoseev <fedoseev.sergey@gmail.com>2017-07-31 01:01:45 +0500
committerTim Graham <timograham@gmail.com>2017-07-31 13:31:04 -0400
commit0baea920c865ae2d40a4e1d9281e25327fc0dbe5 (patch)
tree02ed8e20723e8ea3949660525df88b19b4031047 /tests/lookup
parente3bd328b0f8cacea06cb94dfa63996144279df52 (diff)
Fixed #28453 -- Made __exact=None lookup use transforms.
Diffstat (limited to 'tests/lookup')
-rw-r--r--tests/lookup/models.py11
-rw-r--r--tests/lookup/tests.py7
2 files changed, 18 insertions, 0 deletions
diff --git a/tests/lookup/models.py b/tests/lookup/models.py
index 2fa5b87755..1c7ea799a6 100644
--- a/tests/lookup/models.py
+++ b/tests/lookup/models.py
@@ -43,9 +43,20 @@ class Tag(models.Model):
ordering = ('name', )
+class NulledTextField(models.TextField):
+ pass
+
+
+@NulledTextField.register_lookup
+class NulledTransform(models.Transform):
+ lookup_name = 'nulled'
+ template = 'NULL'
+
+
class Season(models.Model):
year = models.PositiveSmallIntegerField()
gt = models.IntegerField(null=True, blank=True)
+ nulled_text_field = NulledTextField(null=True)
def __str__(self):
return str(self.year)
diff --git a/tests/lookup/tests.py b/tests/lookup/tests.py
index 41270cd19f..37e98f43e2 100644
--- a/tests/lookup/tests.py
+++ b/tests/lookup/tests.py
@@ -839,3 +839,10 @@ class LookupTests(TestCase):
'<Article: Article 7>'],
ordered=False
)
+
+ def test_exact_none_transform(self):
+ """Transforms are used for __exact=None."""
+ Season.objects.create(year=1, nulled_text_field='not null')
+ self.assertFalse(Season.objects.filter(nulled_text_field__isnull=True))
+ self.assertTrue(Season.objects.filter(nulled_text_field__nulled__isnull=True))
+ self.assertTrue(Season.objects.filter(nulled_text_field__nulled__exact=None))