2022-01-13 23:08:38 +00:00
|
|
|
from django.forms import BooleanField, CheckboxInput, Form
|
2015-08-30 21:13:42 -05:00
|
|
|
|
|
|
|
from .base import WidgetTest
|
|
|
|
|
|
|
|
|
|
|
|
class CheckboxInputTest(WidgetTest):
|
|
|
|
widget = CheckboxInput()
|
|
|
|
|
|
|
|
def test_render_empty(self):
|
2018-01-20 23:09:10 -08:00
|
|
|
self.check_html(
|
|
|
|
self.widget, "is_cool", "", html='<input type="checkbox" name="is_cool">'
|
|
|
|
)
|
2015-08-30 21:13:42 -05:00
|
|
|
|
|
|
|
def test_render_none(self):
|
2018-01-20 23:09:10 -08:00
|
|
|
self.check_html(
|
|
|
|
self.widget, "is_cool", None, html='<input type="checkbox" name="is_cool">'
|
|
|
|
)
|
2015-08-30 21:13:42 -05:00
|
|
|
|
|
|
|
def test_render_false(self):
|
2018-01-20 23:09:10 -08:00
|
|
|
self.check_html(
|
|
|
|
self.widget, "is_cool", False, html='<input type="checkbox" name="is_cool">'
|
|
|
|
)
|
2015-08-30 21:13:42 -05:00
|
|
|
|
|
|
|
def test_render_true(self):
|
|
|
|
self.check_html(
|
|
|
|
self.widget,
|
|
|
|
"is_cool",
|
|
|
|
True,
|
2018-01-20 23:09:10 -08:00
|
|
|
html='<input checked type="checkbox" name="is_cool">',
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_render_value(self):
|
|
|
|
"""
|
|
|
|
Using any value that's not in ('', None, False, True) will check the
|
|
|
|
checkbox and set the 'value' attribute.
|
|
|
|
"""
|
|
|
|
self.check_html(
|
|
|
|
self.widget,
|
|
|
|
"is_cool",
|
|
|
|
"foo",
|
2018-01-20 23:09:10 -08:00
|
|
|
html='<input checked type="checkbox" name="is_cool" value="foo">',
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_render_int(self):
|
|
|
|
"""
|
|
|
|
Integers are handled by value, not as booleans (#17114).
|
|
|
|
"""
|
|
|
|
self.check_html(
|
|
|
|
self.widget,
|
|
|
|
"is_cool",
|
|
|
|
0,
|
2018-01-20 23:09:10 -08:00
|
|
|
html='<input checked type="checkbox" name="is_cool" value="0">',
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
self.check_html(
|
|
|
|
self.widget,
|
|
|
|
"is_cool",
|
|
|
|
1,
|
2018-01-20 23:09:10 -08:00
|
|
|
html='<input checked type="checkbox" name="is_cool" value="1">',
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_render_check_test(self):
|
|
|
|
"""
|
|
|
|
You can pass 'check_test' to the constructor. This is a callable that
|
|
|
|
takes the value and returns True if the box should be checked.
|
|
|
|
"""
|
|
|
|
widget = CheckboxInput(check_test=lambda value: value.startswith("hello"))
|
|
|
|
self.check_html(
|
2018-01-20 23:09:10 -08:00
|
|
|
widget, "greeting", "", html=('<input type="checkbox" name="greeting">')
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
self.check_html(
|
|
|
|
widget,
|
|
|
|
"greeting",
|
|
|
|
"hello",
|
2018-01-20 23:09:10 -08:00
|
|
|
html=('<input checked type="checkbox" name="greeting" value="hello">'),
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
self.check_html(
|
|
|
|
widget,
|
|
|
|
"greeting",
|
|
|
|
"hello there",
|
|
|
|
html=(
|
2018-01-20 23:09:10 -08:00
|
|
|
'<input checked type="checkbox" name="greeting" value="hello there">'
|
2022-02-03 20:24:19 +01:00
|
|
|
),
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
self.check_html(
|
|
|
|
widget,
|
|
|
|
"greeting",
|
|
|
|
"hello & goodbye",
|
|
|
|
html=(
|
2018-01-20 23:09:10 -08:00
|
|
|
'<input checked type="checkbox" name="greeting" '
|
|
|
|
'value="hello & goodbye">'
|
2022-02-03 20:24:19 +01:00
|
|
|
),
|
2015-08-30 21:13:42 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
def test_render_check_exception(self):
|
|
|
|
"""
|
|
|
|
Calling check_test() shouldn't swallow exceptions (#17888).
|
|
|
|
"""
|
|
|
|
widget = CheckboxInput(
|
|
|
|
check_test=lambda value: value.startswith("hello"),
|
|
|
|
)
|
|
|
|
|
|
|
|
with self.assertRaises(AttributeError):
|
|
|
|
widget.render("greeting", True)
|
|
|
|
|
|
|
|
def test_value_from_datadict(self):
|
|
|
|
"""
|
|
|
|
The CheckboxInput widget will return False if the key is not found in
|
|
|
|
the data dictionary (because HTML form submission doesn't send any
|
|
|
|
result for unchecked checkboxes).
|
|
|
|
"""
|
|
|
|
self.assertFalse(self.widget.value_from_datadict({}, {}, "testing"))
|
|
|
|
|
|
|
|
def test_value_from_datadict_string_int(self):
|
|
|
|
value = self.widget.value_from_datadict({"testing": "0"}, {}, "testing")
|
2016-06-16 11:19:18 -07:00
|
|
|
self.assertIs(value, True)
|
2016-09-06 17:41:54 -04:00
|
|
|
|
|
|
|
def test_value_omitted_from_data(self):
|
|
|
|
self.assertIs(
|
|
|
|
self.widget.value_omitted_from_data({"field": "value"}, {}, "field"), False
|
|
|
|
)
|
|
|
|
self.assertIs(self.widget.value_omitted_from_data({}, {}, "field"), False)
|
2019-12-09 08:54:40 -08:00
|
|
|
|
|
|
|
def test_get_context_does_not_mutate_attrs(self):
|
|
|
|
attrs = {"checked": False}
|
|
|
|
self.widget.get_context("name", True, attrs)
|
|
|
|
self.assertIs(attrs["checked"], False)
|
2022-01-13 23:08:38 +00:00
|
|
|
|
|
|
|
def test_fieldset(self):
|
|
|
|
class TestForm(Form):
|
|
|
|
template_name = "forms_tests/use_fieldset.html"
|
|
|
|
field = BooleanField(widget=self.widget)
|
|
|
|
|
|
|
|
form = TestForm()
|
|
|
|
self.assertIs(self.widget.use_fieldset, False)
|
|
|
|
self.assertHTMLEqual(
|
|
|
|
form.render(),
|
|
|
|
'<div><label for="id_field">Field:</label>'
|
|
|
|
'<input id="id_field" name="field" required type="checkbox"></div>',
|
|
|
|
)
|