summaryrefslogtreecommitdiff
path: root/tests/one_to_one
diff options
context:
space:
mode:
authorKarl Hobley <karlhobley10@gmail.com>2015-03-16 19:28:53 +0000
committerTim Graham <timograham@gmail.com>2015-03-18 19:00:09 -0400
commit81e1a35c364e5353d2bf99368ad30a4184fbb653 (patch)
tree2cbfcc6a605600d4f4c387d4c49d17dfe300b91f /tests/one_to_one
parent02d78bb1a80706d941ffc6c892cc75208eb6b782 (diff)
downloaddjango-81e1a35c364e5353d2bf99368ad30a4184fbb653.tar.gz
Fixed #24495 -- Allowed unsaved model instance assignment check to be bypassed.
Diffstat (limited to 'tests/one_to_one')
-rw-r--r--tests/one_to_one/tests.py27
1 files changed, 26 insertions, 1 deletions
diff --git a/tests/one_to_one/tests.py b/tests/one_to_one/tests.py
index d7d5793b0a..2cda25b0aa 100644
--- a/tests/one_to_one/tests.py
+++ b/tests/one_to_one/tests.py
@@ -1,6 +1,6 @@
from __future__ import unicode_literals
-from django.db import IntegrityError, connection, transaction
+from django.db import IntegrityError, connection, models, transaction
from django.test import TestCase
from .models import (
@@ -145,6 +145,31 @@ class OneToOneTests(TestCase):
% (bar, p._meta.object_name)):
p.undergroundbar = bar
+ def test_unsaved_object_check_override(self):
+ """
+ #24495 - Assigning an unsaved object to a OneToOneField
+ should be allowed when the allow_unsaved_instance_assignment
+ attribute has been set to True.
+ """
+ class UnsavedOneToOneField(models.OneToOneField):
+ # A OneToOneField which can point to an unsaved object
+ allow_unsaved_instance_assignment = True
+
+ class Band(models.Model):
+ name = models.CharField(max_length=50)
+
+ class BandManager(models.Model):
+ band = UnsavedOneToOneField(Band)
+ first_name = models.CharField(max_length=50)
+ last_name = models.CharField(max_length=50)
+
+ band = Band(name='The Beatles')
+ manager = BandManager(first_name='Brian', last_name='Epstein')
+ # This should not raise an exception as the OneToOneField between
+ # manager and band has allow_unsaved_instance_assignment=True.
+ manager.band = band
+ self.assertEqual(manager.band, band)
+
def test_reverse_relationship_cache_cascade(self):
"""
Regression test for #9023: accessing the reverse relationship shouldn't