mirror of
https://github.com/django/django.git
synced 2025-01-18 14:24:39 +00:00
5fa4f40f45
Thanks Lynn Cyrin for contributing to the patch, and Nick Pope for review.
138 lines
5.1 KiB
Python
138 lines
5.1 KiB
Python
from django import forms
|
|
from django.core.exceptions import ValidationError
|
|
from django.db import IntegrityError, models, transaction
|
|
from django.test import SimpleTestCase, TestCase
|
|
|
|
from .models import BooleanModel, FksToBooleans, NullBooleanModel
|
|
|
|
|
|
class BooleanFieldTests(TestCase):
|
|
def _test_get_prep_value(self, f):
|
|
self.assertIs(f.get_prep_value(True), True)
|
|
self.assertIs(f.get_prep_value('1'), True)
|
|
self.assertIs(f.get_prep_value(1), True)
|
|
self.assertIs(f.get_prep_value(False), False)
|
|
self.assertIs(f.get_prep_value('0'), False)
|
|
self.assertIs(f.get_prep_value(0), False)
|
|
self.assertIsNone(f.get_prep_value(None))
|
|
|
|
def _test_to_python(self, f):
|
|
self.assertIs(f.to_python(1), True)
|
|
self.assertIs(f.to_python(0), False)
|
|
|
|
def test_booleanfield_get_prep_value(self):
|
|
self._test_get_prep_value(models.BooleanField())
|
|
|
|
def test_nullbooleanfield_get_prep_value(self):
|
|
self._test_get_prep_value(models.BooleanField(null=True))
|
|
|
|
def test_nullbooleanfield_old_get_prep_value(self):
|
|
self._test_get_prep_value(models.NullBooleanField())
|
|
|
|
def test_booleanfield_to_python(self):
|
|
self._test_to_python(models.BooleanField())
|
|
|
|
def test_nullbooleanfield_to_python(self):
|
|
self._test_to_python(models.BooleanField(null=True))
|
|
|
|
def test_nullbooleanfield_old_to_python(self):
|
|
self._test_to_python(models.NullBooleanField())
|
|
|
|
def test_booleanfield_choices_blank(self):
|
|
"""
|
|
BooleanField with choices and defaults doesn't generate a formfield
|
|
with the blank option (#9640, #10549).
|
|
"""
|
|
choices = [(1, 'Si'), (2, 'No')]
|
|
f = models.BooleanField(choices=choices, default=1, null=False)
|
|
self.assertEqual(f.formfield().choices, choices)
|
|
|
|
def test_nullbooleanfield_formfield(self):
|
|
f = models.BooleanField(null=True)
|
|
self.assertIsInstance(f.formfield(), forms.NullBooleanField)
|
|
f = models.NullBooleanField()
|
|
self.assertIsInstance(f.formfield(), forms.NullBooleanField)
|
|
|
|
def test_return_type(self):
|
|
b = BooleanModel.objects.create(bfield=True)
|
|
b.refresh_from_db()
|
|
self.assertIs(b.bfield, True)
|
|
|
|
b2 = BooleanModel.objects.create(bfield=False)
|
|
b2.refresh_from_db()
|
|
self.assertIs(b2.bfield, False)
|
|
|
|
b3 = NullBooleanModel.objects.create(nbfield=True, nbfield_old=True)
|
|
b3.refresh_from_db()
|
|
self.assertIs(b3.nbfield, True)
|
|
self.assertIs(b3.nbfield_old, True)
|
|
|
|
b4 = NullBooleanModel.objects.create(nbfield=False, nbfield_old=False)
|
|
b4.refresh_from_db()
|
|
self.assertIs(b4.nbfield, False)
|
|
self.assertIs(b4.nbfield_old, False)
|
|
|
|
# When an extra clause exists, the boolean conversions are applied with
|
|
# an offset (#13293).
|
|
b5 = BooleanModel.objects.all().extra(select={'string_col': 'string'})[0]
|
|
self.assertNotIsInstance(b5.pk, bool)
|
|
|
|
def test_select_related(self):
|
|
"""
|
|
Boolean fields retrieved via select_related() should return booleans.
|
|
"""
|
|
bmt = BooleanModel.objects.create(bfield=True)
|
|
bmf = BooleanModel.objects.create(bfield=False)
|
|
nbmt = NullBooleanModel.objects.create(nbfield=True, nbfield_old=True)
|
|
nbmf = NullBooleanModel.objects.create(nbfield=False, nbfield_old=False)
|
|
m1 = FksToBooleans.objects.create(bf=bmt, nbf=nbmt)
|
|
m2 = FksToBooleans.objects.create(bf=bmf, nbf=nbmf)
|
|
|
|
# select_related('fk_field_name')
|
|
ma = FksToBooleans.objects.select_related('bf').get(pk=m1.id)
|
|
self.assertIs(ma.bf.bfield, True)
|
|
self.assertIs(ma.nbf.nbfield, True)
|
|
|
|
# select_related()
|
|
mb = FksToBooleans.objects.select_related().get(pk=m1.id)
|
|
mc = FksToBooleans.objects.select_related().get(pk=m2.id)
|
|
self.assertIs(mb.bf.bfield, True)
|
|
self.assertIs(mb.nbf.nbfield, True)
|
|
self.assertIs(mb.nbf.nbfield_old, True)
|
|
self.assertIs(mc.bf.bfield, False)
|
|
self.assertIs(mc.nbf.nbfield, False)
|
|
self.assertIs(mc.nbf.nbfield_old, False)
|
|
|
|
def test_null_default(self):
|
|
"""
|
|
A BooleanField defaults to None, which isn't a valid value (#15124).
|
|
"""
|
|
boolean_field = BooleanModel._meta.get_field('bfield')
|
|
self.assertFalse(boolean_field.has_default())
|
|
b = BooleanModel()
|
|
self.assertIsNone(b.bfield)
|
|
with transaction.atomic():
|
|
with self.assertRaises(IntegrityError):
|
|
b.save()
|
|
|
|
nb = NullBooleanModel()
|
|
self.assertIsNone(nb.nbfield)
|
|
self.assertIsNone(nb.nbfield_old)
|
|
nb.save() # no error
|
|
|
|
|
|
class ValidationTest(SimpleTestCase):
|
|
|
|
def test_boolean_field_doesnt_accept_empty_input(self):
|
|
f = models.BooleanField()
|
|
with self.assertRaises(ValidationError):
|
|
f.clean(None, None)
|
|
|
|
def test_nullbooleanfield_blank(self):
|
|
"""
|
|
NullBooleanField shouldn't throw a validation error when given a value
|
|
of None.
|
|
"""
|
|
nullboolean = NullBooleanModel(nbfield=None, nbfield_old=None)
|
|
nullboolean.full_clean()
|