summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/managers_regress/models.py5
-rw-r--r--tests/managers_regress/tests.py8
2 files changed, 11 insertions, 2 deletions
diff --git a/tests/managers_regress/models.py b/tests/managers_regress/models.py
index c8869f1e26..99494448bd 100644
--- a/tests/managers_regress/models.py
+++ b/tests/managers_regress/models.py
@@ -129,6 +129,7 @@ class Child7(Parent):
@python_2_unicode_compatible
class RelatedModel(models.Model):
test_gfk = GenericRelation('RelationModel', content_type_field='gfk_ctype', object_id_field='gfk_id')
+ exact = models.NullBooleanField()
def __str__(self):
return force_text(self.pk)
@@ -140,8 +141,8 @@ class RelationModel(models.Model):
m2m = models.ManyToManyField(RelatedModel, related_name='test_m2m')
- gfk_ctype = models.ForeignKey(ContentType)
- gfk_id = models.IntegerField()
+ gfk_ctype = models.ForeignKey(ContentType, null=True)
+ gfk_id = models.IntegerField(null=True)
gfk = GenericForeignKey(ct_field='gfk_ctype', fk_field='gfk_id')
def __str__(self):
diff --git a/tests/managers_regress/tests.py b/tests/managers_regress/tests.py
index 0d24873a10..af507f0b75 100644
--- a/tests/managers_regress/tests.py
+++ b/tests/managers_regress/tests.py
@@ -201,3 +201,11 @@ class ManagersRegressionTests(TestCase):
t.render(Context({'related': related})),
''.join([force_text(relation.pk)] * 3),
)
+
+ def test_field_can_be_called_exact(self):
+ # Make sure related managers core filters don't include an
+ # explicit `__exact` lookup that could be interpreted as a
+ # reference to a foreign `exact` field. refs #23940.
+ related = RelatedModel.objects.create(exact=False)
+ relation = related.test_fk.create()
+ self.assertEqual(related.test_fk.get(), relation)