#30126: Incorrect validation of forms.DecimalField
--------------------------------------------+------------------------
               Reporter:  Roman Paranichev  |          Owner:  nobody
                   Type:  Uncategorized     |         Status:  new
              Component:  Forms             |        Version:  2.1
               Severity:  Normal            |       Keywords:
           Triage Stage:  Unreviewed        |      Has patch:  0
    Needs documentation:  0                 |    Needs tests:  0
Patch needs improvement:  0                 |  Easy pickings:  0
                  UI/UX:  0                 |
--------------------------------------------+------------------------
 Steps to reproduce:
 1. create html form

 {{{
 <form action="/payment/">
 <input type="number" step="0.01" name="amount" value="0.02" required>
 <input type="submit" value="Submit">
 </form>
 }}}

 2. create django-form for validation:

 {{{
 from django import forms

 class CreatePaymentForm(forms.Form):
     amount = forms.DecimalField(min_value=0.02, max_digits=12,
 decimal_places=2)
 }}}

 3. Try to validate from in a view class:

 {{{
 import json
 from django.http import HttpResponse
 from django.views.generic import View
 from django.contrib.auth.decorators import login_required
 from django.utils.decorators import method_decorator
 from django.views.decorators.csrf import csrf_exempt
 from api.forms import CreatePaymentForm

 @method_decorator(login_required, name='dispatch')
 @method_decorator(csrf_exempt, name='dispatch')
 class PaymentView(View):

     def post(self, request):
         form = CreatePaymentForm(request.POST)
         if form.is_valid():
               pass
         print("post: %s, errors: %s" % (request.POST, form.errors))
         return HttpResponse(json.dumps({'errors': form.errors}),
 status=400)
 }}}

 The output will be:
 post: <QueryDict: {'amount': ['0.02']}>, errors: <ul
 class="errorlist"><li>amount<ul class="errorlist"><li>Ensure this value is
 greater than or equal to 0.02.</li></ul></li></ul>

-- 
Ticket URL: <https://code.djangoproject.com/ticket/30126>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.

-- 
You received this message because you are subscribed to the Google Groups 
"Django updates" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
To post to this group, send email to [email protected].
To view this discussion on the web visit 
https://groups.google.com/d/msgid/django-updates/049.6479b6cbe1e885b12ffa632970761b00%40djangoproject.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to