diff options
| author | Karl Hobley <karlhobley10@gmail.com> | 2015-03-16 19:28:53 +0000 |
|---|---|---|
| committer | Tim Graham <timograham@gmail.com> | 2015-03-18 19:00:09 -0400 |
| commit | 81e1a35c364e5353d2bf99368ad30a4184fbb653 (patch) | |
| tree | 2cbfcc6a605600d4f4c387d4c49d17dfe300b91f /tests/one_to_one | |
| parent | 02d78bb1a80706d941ffc6c892cc75208eb6b782 (diff) | |
| download | django-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.py | 27 |
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 |
