Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Fixed #11120 -- Corrected handling of inlines attached to inherited c…
…lasses, broken by r10756. Thanks to George Song and Michael Strickland for the simultaneous reports. git-svn-id: http://code.djangoproject.com/svn/django/trunk@10787 bcc190cf-cafb-0310-a4f2-bffc1f526a37
- Loading branch information
1 parent
bed1418
commit a00be66
Showing
3 changed files
with
144 additions
and
13 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,24 +1,142 @@ | ||
from django.forms.models import inlineformset_factory | ||
from django.forms.models import modelform_factory, inlineformset_factory | ||
from django.test import TestCase | ||
|
||
from models import User, UserSite | ||
from models import User, UserSite, Restaurant, Manager | ||
|
||
class InlineFormsetTests(TestCase): | ||
def test_formset_over_to_field(self): | ||
"A formset over a ForeignKey with a to_field can be saved. Regression for #10243" | ||
Form = modelform_factory(User) | ||
FormSet = inlineformset_factory(User, UserSite) | ||
user = User.objects.create(serial=1, username='apollo13') | ||
user.save() | ||
|
||
# Instantiate the Form and FormSet to prove | ||
# you can create a form with no data | ||
form = Form() | ||
form_set = FormSet(instance=User()) | ||
|
||
# Now create a new User and UserSite instance | ||
data = { | ||
'serial': u'1', | ||
'username': u'apollo13', | ||
'usersite_set-TOTAL_FORMS': u'1', | ||
'usersite_set-INITIAL_FORMS': u'0', | ||
'usersite_set-0-data': u'10', | ||
'usersite_set-0-user': u'apollo13' | ||
} | ||
user = User() | ||
form = Form(data) | ||
if form.is_valid(): | ||
user = form.save() | ||
else: | ||
self.fail('Errors found on form:%s' % form_set) | ||
|
||
form_set = FormSet(data, instance=user) | ||
if form_set.is_valid(): | ||
form_set.save() | ||
usersite = UserSite.objects.all().values()[0] | ||
self.assertEqual(usersite, {'data': 10, 'user_id': u'apollo13', 'id': 1}) | ||
usersite = UserSite.objects.all().values() | ||
self.assertEqual(usersite[0]['data'], 10) | ||
self.assertEqual(usersite[0]['user_id'], u'apollo13') | ||
else: | ||
self.fail('Errors found on formset:%s' % form_set.errors) | ||
|
||
# Now update the UserSite instance | ||
data = { | ||
'usersite_set-TOTAL_FORMS': u'1', | ||
'usersite_set-INITIAL_FORMS': u'1', | ||
'usersite_set-0-id': unicode(usersite[0]['id']), | ||
'usersite_set-0-data': u'11', | ||
'usersite_set-0-user': u'apollo13' | ||
} | ||
form_set = FormSet(data, instance=user) | ||
if form_set.is_valid(): | ||
form_set.save() | ||
usersite = UserSite.objects.all().values() | ||
self.assertEqual(usersite[0]['data'], 11) | ||
self.assertEqual(usersite[0]['user_id'], u'apollo13') | ||
else: | ||
self.fail('Errors found on formset:%s' % form_set.errors) | ||
|
||
# Now add a new UserSite instance | ||
data = { | ||
'usersite_set-TOTAL_FORMS': u'2', | ||
'usersite_set-INITIAL_FORMS': u'1', | ||
'usersite_set-0-id': unicode(usersite[0]['id']), | ||
'usersite_set-0-data': u'11', | ||
'usersite_set-0-user': u'apollo13', | ||
'usersite_set-1-data': u'42', | ||
'usersite_set-1-user': u'apollo13' | ||
} | ||
form_set = FormSet(data, instance=user) | ||
if form_set.is_valid(): | ||
form_set.save() | ||
usersite = UserSite.objects.all().values().order_by('user') | ||
self.assertEqual(usersite[0]['data'], 11) | ||
self.assertEqual(usersite[0]['user_id'], u'apollo13') | ||
self.assertEqual(usersite[1]['data'], 42) | ||
self.assertEqual(usersite[1]['user_id'], u'apollo13') | ||
else: | ||
self.fail('Errors found on formset:%s' % form_set.errors) | ||
|
||
def test_formset_over_inherited_model(self): | ||
"A formset over a ForeignKey with a to_field can be saved. Regression for #11120" | ||
Form = modelform_factory(Restaurant) | ||
FormSet = inlineformset_factory(Restaurant, Manager) | ||
|
||
# Instantiate the Form and FormSet to prove | ||
# you can create a form with no data | ||
form = Form() | ||
form_set = FormSet(instance=Restaurant()) | ||
|
||
# Now create a new Restaurant and Manager instance | ||
data = { | ||
'name': u"Guido's House of Pasta", | ||
'manager_set-TOTAL_FORMS': u'1', | ||
'manager_set-INITIAL_FORMS': u'0', | ||
'manager_set-0-name': u'Guido Van Rossum' | ||
} | ||
restaurant = User() | ||
form = Form(data) | ||
if form.is_valid(): | ||
restaurant = form.save() | ||
else: | ||
self.fail('Errors found on form:%s' % form_set) | ||
|
||
form_set = FormSet(data, instance=restaurant) | ||
if form_set.is_valid(): | ||
form_set.save() | ||
manager = Manager.objects.all().values() | ||
self.assertEqual(manager[0]['name'], 'Guido Van Rossum') | ||
else: | ||
self.fail('Errors found on formset:%s' % form_set.errors) | ||
|
||
# Now update the Manager instance | ||
data = { | ||
'manager_set-TOTAL_FORMS': u'1', | ||
'manager_set-INITIAL_FORMS': u'1', | ||
'manager_set-0-id': unicode(manager[0]['id']), | ||
'manager_set-0-name': u'Terry Gilliam' | ||
} | ||
form_set = FormSet(data, instance=restaurant) | ||
if form_set.is_valid(): | ||
form_set.save() | ||
manager = Manager.objects.all().values() | ||
self.assertEqual(manager[0]['name'], 'Terry Gilliam') | ||
else: | ||
self.fail('Errors found on formset:%s' % form_set.errors) | ||
|
||
# Now add a new Manager instance | ||
data = { | ||
'manager_set-TOTAL_FORMS': u'2', | ||
'manager_set-INITIAL_FORMS': u'1', | ||
'manager_set-0-id': unicode(manager[0]['id']), | ||
'manager_set-0-name': u'Terry Gilliam', | ||
'manager_set-1-name': u'John Cleese' | ||
} | ||
form_set = FormSet(data, instance=restaurant) | ||
if form_set.is_valid(): | ||
form_set.save() | ||
manager = Manager.objects.all().values().order_by('name') | ||
self.assertEqual(manager[0]['name'], 'John Cleese') | ||
self.assertEqual(manager[1]['name'], 'Terry Gilliam') | ||
else: | ||
self.fail('Errors found on form:%s' % form_set.errors) | ||
self.fail('Errors found on formset:%s' % form_set.errors) |