diff options
| author | Diederik van der Boor <vdboor@edoburu.nl> | 2017-07-13 13:55:23 +0200 |
|---|---|---|
| committer | Mariusz Felisiak <felisiak.mariusz@gmail.com> | 2019-08-05 08:41:29 +0200 |
| commit | 25f21bd2376603c8e233a0a0e5a726a0fdfdd33e (patch) | |
| tree | 4c75092f7ee29fff214a3f7c40ac00dd424afc04 /tests | |
| parent | 1af469e67fd3928a4b01722d4706c066000014e9 (diff) | |
Fixed #28393 -- Added helpful error messages for invalid AutoField/FloatField/IntegerField values.
Co-authored-by: Diederik van der Boor <vdboor@edoburu.nl>
Co-authored-by: Nick Pope <nick.pope@flightdataservices.com>
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/model_fields/models.py | 12 | ||||
| -rw-r--r-- | tests/model_fields/test_autofield.py | 32 | ||||
| -rw-r--r-- | tests/model_fields/test_floatfield.py | 17 | ||||
| -rw-r--r-- | tests/model_fields/test_integerfield.py | 17 | ||||
| -rw-r--r-- | tests/queries/tests.py | 2 |
5 files changed, 79 insertions, 1 deletions
diff --git a/tests/model_fields/models.py b/tests/model_fields/models.py index cbf3ec26ea..98b32d0c1e 100644 --- a/tests/model_fields/models.py +++ b/tests/model_fields/models.py @@ -92,6 +92,18 @@ class UnicodeSlugField(models.Model): s = models.SlugField(max_length=255, allow_unicode=True) +class AutoModel(models.Model): + value = models.AutoField(primary_key=True) + + +class BigAutoModel(models.Model): + value = models.BigAutoField(primary_key=True) + + +class SmallAutoModel(models.Model): + value = models.SmallAutoField(primary_key=True) + + class SmallIntegerModel(models.Model): value = models.SmallIntegerField() diff --git a/tests/model_fields/test_autofield.py b/tests/model_fields/test_autofield.py new file mode 100644 index 0000000000..73220ae62b --- /dev/null +++ b/tests/model_fields/test_autofield.py @@ -0,0 +1,32 @@ +from django.test import TestCase + +from .models import AutoModel, BigAutoModel, SmallAutoModel + + +class AutoFieldTests(TestCase): + model = AutoModel + + def test_invalid_value(self): + tests = [ + (TypeError, ()), + (TypeError, []), + (TypeError, {}), + (TypeError, set()), + (TypeError, object()), + (TypeError, complex()), + (ValueError, 'non-numeric string'), + (ValueError, b'non-numeric byte-string'), + ] + for exception, value in tests: + with self.subTest(value=value): + msg = "Field 'value' expected a number but got %r." % (value,) + with self.assertRaisesMessage(exception, msg): + self.model.objects.create(value=value) + + +class BigAutoFieldTests(AutoFieldTests): + model = BigAutoModel + + +class SmallAutoFieldTests(AutoFieldTests): + model = SmallAutoModel diff --git a/tests/model_fields/test_floatfield.py b/tests/model_fields/test_floatfield.py index 481925cf11..856197cd6e 100644 --- a/tests/model_fields/test_floatfield.py +++ b/tests/model_fields/test_floatfield.py @@ -31,3 +31,20 @@ class TestFloatField(TestCase): obj.size = obj with self.assertRaisesMessage(TypeError, msg): obj.save() + + def test_invalid_value(self): + tests = [ + (TypeError, ()), + (TypeError, []), + (TypeError, {}), + (TypeError, set()), + (TypeError, object()), + (TypeError, complex()), + (ValueError, 'non-numeric string'), + (ValueError, b'non-numeric byte-string'), + ] + for exception, value in tests: + with self.subTest(value): + msg = "Field 'size' expected a number but got %r." % (value,) + with self.assertRaisesMessage(exception, msg): + FloatModel.objects.create(size=value) diff --git a/tests/model_fields/test_integerfield.py b/tests/model_fields/test_integerfield.py index 626b67b00b..c72cb48015 100644 --- a/tests/model_fields/test_integerfield.py +++ b/tests/model_fields/test_integerfield.py @@ -137,6 +137,23 @@ class IntegerFieldTests(TestCase): instance = self.model.objects.get(value='10') self.assertEqual(instance.value, 10) + def test_invalid_value(self): + tests = [ + (TypeError, ()), + (TypeError, []), + (TypeError, {}), + (TypeError, set()), + (TypeError, object()), + (TypeError, complex()), + (ValueError, 'non-numeric string'), + (ValueError, b'non-numeric byte-string'), + ] + for exception, value in tests: + with self.subTest(value): + msg = "Field 'value' expected a number but got %r." % (value,) + with self.assertRaisesMessage(exception, msg): + self.model.objects.create(value=value) + class SmallIntegerFieldTests(IntegerFieldTests): model = SmallIntegerModel diff --git a/tests/queries/tests.py b/tests/queries/tests.py index 6d3dcbdb1f..8339c52a02 100644 --- a/tests/queries/tests.py +++ b/tests/queries/tests.py @@ -3853,7 +3853,7 @@ class TestTicket24279(TestCase): class TestInvalidValuesRelation(SimpleTestCase): def test_invalid_values(self): - msg = "invalid literal for int() with base 10: 'abc'" + msg = "Field 'id' expected a number but got 'abc'." with self.assertRaisesMessage(ValueError, msg): Annotation.objects.filter(tag='abc') with self.assertRaisesMessage(ValueError, msg): |
