mirror of
https://github.com/django/django.git
synced 2025-10-23 21:59:11 +00:00
[1.1.X] Fixed #12285. ModelForm raises a more informative error if it doesn't have a model class defined. Backport of [12526] from trunk.
git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.1.X@12530 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -214,6 +214,8 @@ class BaseModelForm(BaseForm):
|
|||||||
empty_permitted=False, instance=None):
|
empty_permitted=False, instance=None):
|
||||||
opts = self._meta
|
opts = self._meta
|
||||||
if instance is None:
|
if instance is None:
|
||||||
|
if opts.model is None:
|
||||||
|
raise ValueError('ModelForm has no model class specified.')
|
||||||
# if we didn't get an instance, instantiate a new one
|
# if we didn't get an instance, instantiate a new one
|
||||||
self.instance = opts.model()
|
self.instance = opts.model()
|
||||||
object_data = {}
|
object_data = {}
|
||||||
|
@@ -101,3 +101,9 @@ class CustomFieldSaveTests(TestCase):
|
|||||||
# generate an AssertionError if it is called more than once during save.
|
# generate an AssertionError if it is called more than once during save.
|
||||||
form = CFFForm(data = {'f': None})
|
form = CFFForm(data = {'f': None})
|
||||||
form.save()
|
form.save()
|
||||||
|
|
||||||
|
class ModelClassTests(TestCase):
|
||||||
|
def test_no_model_class(self):
|
||||||
|
class NoModelModelForm(forms.ModelForm):
|
||||||
|
pass
|
||||||
|
self.assertRaises(ValueError, NoModelModelForm)
|
||||||
|
Reference in New Issue
Block a user