mirror of https://github.com/django/django.git
[1.11.x] Fixed #28075 -- Prevented ChoiceWidget from localizing option values.
Backport of 581879a510
from master
This commit is contained in:
parent
c9d933ba99
commit
1442e29983
|
@ -613,7 +613,7 @@ class ChoiceWidget(Widget):
|
|||
option_attrs['id'] = self.id_for_label(option_attrs['id'], index)
|
||||
return {
|
||||
'name': name,
|
||||
'value': value,
|
||||
'value': force_text(value),
|
||||
'label': label,
|
||||
'selected': selected,
|
||||
'index': index,
|
||||
|
|
|
@ -45,3 +45,7 @@ Bugfixes
|
|||
|
||||
* Fixed exception reraising in ORM query execution when ``cursor.execute()``
|
||||
fails and the subsequent ``cursor.close()`` also fails (:ticket:`28091`).
|
||||
|
||||
* Fixed a regression where ``CheckboxSelectMultiple``, ``NullBooleanSelect``,
|
||||
``RadioSelect``, ``SelectMultiple``, and ``Select`` localized option values
|
||||
(:ticket:`28075`).
|
||||
|
|
|
@ -1,5 +1,8 @@
|
|||
import datetime
|
||||
|
||||
from django import forms
|
||||
from django.forms import CheckboxSelectMultiple
|
||||
from django.test import override_settings
|
||||
|
||||
from .base import WidgetTest
|
||||
|
||||
|
@ -149,6 +152,34 @@ class CheckboxSelectMultipleTest(WidgetTest):
|
|||
"""
|
||||
self.check_html(widget, 'letters', ['a', 'c'], html=html)
|
||||
|
||||
@override_settings(USE_L10N=True, USE_THOUSAND_SEPARATOR=True)
|
||||
def test_doesnt_localize_input_value(self):
|
||||
choices = [
|
||||
(1, 'One'),
|
||||
(1000, 'One thousand'),
|
||||
(1000000, 'One million'),
|
||||
]
|
||||
html = """
|
||||
<ul>
|
||||
<li><label><input type="checkbox" name="numbers" value="1" /> One</label></li>
|
||||
<li><label><input type="checkbox" name="numbers" value="1000" /> One thousand</label></li>
|
||||
<li><label><input type="checkbox" name="numbers" value="1000000" /> One million</label></li>
|
||||
</ul>
|
||||
"""
|
||||
self.check_html(self.widget(choices=choices), 'numbers', None, html=html)
|
||||
|
||||
choices = [
|
||||
(datetime.time(0, 0), 'midnight'),
|
||||
(datetime.time(12, 0), 'noon'),
|
||||
]
|
||||
html = """
|
||||
<ul>
|
||||
<li><label><input type="checkbox" name="times" value="00:00:00" /> midnight</label></li>
|
||||
<li><label><input type="checkbox" name="times" value="12:00:00" /> noon</label></li>
|
||||
</ul>
|
||||
"""
|
||||
self.check_html(self.widget(choices=choices), 'times', None, html=html)
|
||||
|
||||
def test_use_required_attribute(self):
|
||||
widget = self.widget(choices=self.beatles)
|
||||
# Always False because browser validation would require all checkboxes
|
||||
|
|
|
@ -1,4 +1,7 @@
|
|||
import datetime
|
||||
|
||||
from django.forms import RadioSelect
|
||||
from django.test import override_settings
|
||||
|
||||
from .base import WidgetTest
|
||||
|
||||
|
@ -99,3 +102,31 @@ class RadioSelectTest(WidgetTest):
|
|||
</ul>
|
||||
"""
|
||||
self.check_html(self.widget(choices=self.beatles), 'beatle', 'J', attrs={'class': 'bar'}, html=html)
|
||||
|
||||
@override_settings(USE_L10N=True, USE_THOUSAND_SEPARATOR=True)
|
||||
def test_doesnt_localize_input_value(self):
|
||||
choices = [
|
||||
(1, 'One'),
|
||||
(1000, 'One thousand'),
|
||||
(1000000, 'One million'),
|
||||
]
|
||||
html = """
|
||||
<ul>
|
||||
<li><label><input type="radio" name="number" value="1" /> One</label></li>
|
||||
<li><label><input type="radio" name="number" value="1000" /> One thousand</label></li>
|
||||
<li><label><input type="radio" name="number" value="1000000" /> One million</label></li>
|
||||
</ul>
|
||||
"""
|
||||
self.check_html(self.widget(choices=choices), 'number', None, html=html)
|
||||
|
||||
choices = [
|
||||
(datetime.time(0, 0), 'midnight'),
|
||||
(datetime.time(12, 0), 'noon'),
|
||||
]
|
||||
html = """
|
||||
<ul>
|
||||
<li><label><input type="radio" name="time" value="00:00:00" /> midnight</label></li>
|
||||
<li><label><input type="radio" name="time" value="12:00:00" /> noon</label></li>
|
||||
</ul>
|
||||
"""
|
||||
self.check_html(self.widget(choices=choices), 'time', None, html=html)
|
||||
|
|
|
@ -2,8 +2,10 @@
|
|||
from __future__ import unicode_literals
|
||||
|
||||
import copy
|
||||
import datetime
|
||||
|
||||
from django.forms import Select
|
||||
from django.test import override_settings
|
||||
from django.utils.safestring import mark_safe
|
||||
|
||||
from .base import WidgetTest
|
||||
|
@ -221,6 +223,34 @@ class SelectTest(WidgetTest):
|
|||
</select>"""
|
||||
))
|
||||
|
||||
@override_settings(USE_L10N=True, USE_THOUSAND_SEPARATOR=True)
|
||||
def test_doesnt_localize_option_value(self):
|
||||
choices = [
|
||||
(1, 'One'),
|
||||
(1000, 'One thousand'),
|
||||
(1000000, 'One million'),
|
||||
]
|
||||
html = """
|
||||
<select name="number">
|
||||
<option value="1">One</option>
|
||||
<option value="1000">One thousand</option>
|
||||
<option value="1000000">One million</option>
|
||||
</select>
|
||||
"""
|
||||
self.check_html(self.widget(choices=choices), 'number', None, html=html)
|
||||
|
||||
choices = [
|
||||
(datetime.time(0, 0), 'midnight'),
|
||||
(datetime.time(12, 0), 'noon'),
|
||||
]
|
||||
html = """
|
||||
<select name="time">
|
||||
<option value="00:00:00">midnight</option>
|
||||
<option value="12:00:00">noon</option>
|
||||
</select>
|
||||
"""
|
||||
self.check_html(self.widget(choices=choices), 'time', None, html=html)
|
||||
|
||||
def test_options(self):
|
||||
options = list(self.widget(choices=self.beatles).options(
|
||||
'name', ['J'], attrs={'class': 'super'},
|
||||
|
|
Loading…
Reference in New Issue