{{{
class TestFormX(forms.Form):
test_one = forms.CharField(required=True)
def __init__(self, *args, **kwargs):
super(TestFormX, self).__init__(*args, **kwargs)
self.fields['test_two'] = forms.IntegerField(required=False)
for key in (3,4):
self.fields[key] = forms.IntegerField(required=False,
label='must have a label')
def sandbox2(request):
if request.method == 'POST':
form = TestFormX(request.POST)
if form.is_valid():
print 'Form is valid'
else:
print form.errors
else:
form = TestFormX()
return render(request, 'xxx_sandbox2.html', {'form' : form},
status=200)
}}}
Form fields test_one and test_two act normally. Fields 3 and 4 render and
appear to work, but
won't bind data from the request.POST. Thus, any input by the user is
lost.
This was found on a dynamically built from.Form, where an integer database
primary key was used as the field name.
--
Ticket URL: <https://code.djangoproject.com/ticket/22678>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
* status: new => closed
* needs_better_patch: => 0
* resolution: => invalid
* needs_tests: => 0
* needs_docs: => 0
Comment:
Hi,
I believe the problem here is that you're using integers as keys on
`TestFormX.fields` which is not supported (only strings are allowed).
Things should work if you use `for key in ('3', '4'):`.
Marking this as `invalid` consequently.
Thanks.
--
Ticket URL: <https://code.djangoproject.com/ticket/22678#comment:1>
* status: closed => new
* resolution: invalid =>
Comment:
I intended to convey that above: the issue is the integer. Strings work,
integers don't.
The form as build 'looked' like reasonable code, but had a murky and hard
to track problem.
Most code paths blow up on integers, but not this one.
The proposed fix is to assert on string for the key.
--
Ticket URL: <https://code.djangoproject.com/ticket/22678#comment:2>
* status: new => closed
* resolution: => wontfix
Comment:
I think it's reasonable to expect that most people won't mix types in the
`fields` dictionary. I'm sorry you ran into the issue, but I don't think
fixing it is worthwhile.
--
Ticket URL: <https://code.djangoproject.com/ticket/22678#comment:3>