mirror of
https://github.com/django/django.git
synced 2025-10-23 21:59:11 +00:00
Fixed #10811 -- Made assigning unsaved objects to FK, O2O, and GFK raise ValueError.
This prevents silent data loss. Thanks Aymeric Augustin for the initial patch and Loic Bistuer for the review.
This commit is contained in:
committed by
Tim Graham
parent
4f72e5f03a
commit
5643a3b51b
@@ -3,7 +3,7 @@ from __future__ import unicode_literals
|
||||
from django.db import transaction, IntegrityError
|
||||
from django.test import TestCase
|
||||
|
||||
from .models import (Place, Restaurant, Waiter, ManualPrimaryKey, RelatedModel,
|
||||
from .models import (Place, Restaurant, Bar, Waiter, ManualPrimaryKey, RelatedModel,
|
||||
MultiModel)
|
||||
|
||||
|
||||
@@ -128,3 +128,20 @@ class OneToOneTests(TestCase):
|
||||
with self.assertRaises(IntegrityError):
|
||||
with transaction.atomic():
|
||||
mm.save()
|
||||
|
||||
def test_unsaved_object(self):
|
||||
"""
|
||||
#10811 -- Assigning an unsaved object to a OneToOneField
|
||||
should raise an exception.
|
||||
"""
|
||||
place = Place(name='User', address='London')
|
||||
with self.assertRaisesMessage(ValueError,
|
||||
'Cannot assign "%r": "%s" instance isn\'t saved in the database.'
|
||||
% (place, Restaurant.place.field.rel.to._meta.object_name)):
|
||||
Restaurant.objects.create(place=place, serves_hot_dogs=True, serves_pizza=False)
|
||||
bar = Bar()
|
||||
p = Place(name='User', address='London')
|
||||
with self.assertRaisesMessage(ValueError,
|
||||
'Cannot assign "%r": "%s" instance isn\'t saved in the database.'
|
||||
% (bar, p._meta.object_name)):
|
||||
p.bar = bar
|
||||
|
Reference in New Issue
Block a user