mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	Fixed #14938 - Fixed save-as-new on inline formset with new forms.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@15306 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -690,10 +690,6 @@ class BaseInlineFormSet(BaseModelFormSet): | ||||
|             return 0 | ||||
|         return super(BaseInlineFormSet, self).initial_form_count() | ||||
|  | ||||
|     def total_form_count(self): | ||||
|         if self.save_as_new: | ||||
|             return super(BaseInlineFormSet, self).initial_form_count() | ||||
|         return super(BaseInlineFormSet, self).total_form_count() | ||||
|  | ||||
|     def _construct_form(self, i, **kwargs): | ||||
|         form = super(BaseInlineFormSet, self)._construct_form(i, **kwargs) | ||||
|   | ||||
| @@ -17,3 +17,13 @@ class Restaurant(Place): | ||||
| class Manager(models.Model): | ||||
|     retaurant = models.ForeignKey(Restaurant) | ||||
|     name = models.CharField(max_length=50) | ||||
|  | ||||
| class Network(models.Model): | ||||
|     name = models.CharField(max_length=15) | ||||
|  | ||||
| class Host(models.Model): | ||||
|     network = models.ForeignKey(Network) | ||||
|     hostname = models.CharField(max_length=25) | ||||
|  | ||||
|     def __unicode__(self): | ||||
|         return self.hostname | ||||
|   | ||||
| @@ -2,7 +2,7 @@ from django import forms | ||||
| from django.forms.models import modelform_factory, inlineformset_factory, modelformset_factory | ||||
| from django.test import TestCase | ||||
|  | ||||
| from models import User, UserSite, Restaurant, Manager | ||||
| from models import User, UserSite, Restaurant, Manager, Network, Host | ||||
|  | ||||
|  | ||||
| class InlineFormsetTests(TestCase): | ||||
| @@ -167,6 +167,39 @@ class InlineFormsetTests(TestCase): | ||||
|             self.assertTrue('id' in form.fields) | ||||
|             self.assertEqual(len(form.fields), 1) | ||||
|  | ||||
|     def test_save_as_new_with_new_inlines(self): | ||||
|         """ | ||||
|         Existing and new inlines are saved with save_as_new. | ||||
|  | ||||
|         Regression for #14938. | ||||
|  | ||||
|         """ | ||||
|         efnet = Network.objects.create(name="EFNet") | ||||
|         host1 = Host.objects.create(hostname="irc.he.net", network=efnet) | ||||
|  | ||||
|         HostFormSet = inlineformset_factory(Network, Host) | ||||
|  | ||||
|         # Add a new host, modify previous host, and save-as-new | ||||
|         data = { | ||||
|             'host_set-TOTAL_FORMS': u'2', | ||||
|             'host_set-INITIAL_FORMS': u'1', | ||||
|             'host_set-MAX_NUM_FORMS': u'0', | ||||
|             'host_set-0-id': unicode(host1.id), | ||||
|             'host_set-0-hostname': u'tranquility.hub.dal.net', | ||||
|             'host_set-1-hostname': u'matrix.de.eu.dal.net' | ||||
|         } | ||||
|  | ||||
|         # To save a formset as new, it needs a new hub instance | ||||
|         dalnet = Network.objects.create(name="DALnet") | ||||
|         formset = HostFormSet(data, instance=dalnet, save_as_new=True) | ||||
|  | ||||
|         self.assertTrue(formset.is_valid()) | ||||
|         formset.save() | ||||
|         self.assertQuerysetEqual( | ||||
|             dalnet.host_set.order_by("hostname"), | ||||
|             ["<Host: matrix.de.eu.dal.net>", "<Host: tranquility.hub.dal.net>"] | ||||
|             ) | ||||
|  | ||||
|  | ||||
| class CustomWidget(forms.CharField): | ||||
|     pass | ||||
|   | ||||
		Reference in New Issue
	
	Block a user