mirror of
https://github.com/django/django.git
synced 2025-09-24 03:03:09 +00:00
Fixed #30613 -- Moved index name validation to system checks.
This commit is contained in:
parent
f197c3dd91
commit
53209f7830
5 changed files with 64 additions and 35 deletions
|
@ -296,6 +296,39 @@ class IndexesTests(SimpleTestCase):
|
|||
|
||||
self.assertEqual(Bar.check(), [])
|
||||
|
||||
def test_name_constraints(self):
|
||||
class Model(models.Model):
|
||||
class Meta:
|
||||
indexes = [
|
||||
models.Index(fields=['id'], name='_index_name'),
|
||||
models.Index(fields=['id'], name='5index_name'),
|
||||
]
|
||||
|
||||
self.assertEqual(Model.check(), [
|
||||
Error(
|
||||
"The index name '%sindex_name' cannot start with an "
|
||||
"underscore or a number." % prefix,
|
||||
obj=Model,
|
||||
id='models.E033',
|
||||
) for prefix in ('_', '5')
|
||||
])
|
||||
|
||||
def test_max_name_length(self):
|
||||
index_name = 'x' * 31
|
||||
|
||||
class Model(models.Model):
|
||||
class Meta:
|
||||
indexes = [models.Index(fields=['id'], name=index_name)]
|
||||
|
||||
self.assertEqual(Model.check(), [
|
||||
Error(
|
||||
"The index name '%s' cannot be longer than 30 characters."
|
||||
% index_name,
|
||||
obj=Model,
|
||||
id='models.E034',
|
||||
),
|
||||
])
|
||||
|
||||
|
||||
@isolate_apps('invalid_models_tests')
|
||||
class FieldNamesTests(SimpleTestCase):
|
||||
|
|
|
@ -63,20 +63,6 @@ class SimpleIndexesTests(SimpleTestCase):
|
|||
with self.assertRaisesMessage(ValueError, 'Index.condition must be a Q instance.'):
|
||||
models.Index(condition='invalid', name='long_book_idx')
|
||||
|
||||
def test_max_name_length(self):
|
||||
msg = 'Index names cannot be longer than 30 characters.'
|
||||
with self.assertRaisesMessage(ValueError, msg):
|
||||
models.Index(fields=['title'], name='looooooooooooong_index_name_idx')
|
||||
|
||||
def test_name_constraints(self):
|
||||
msg = 'Index names cannot start with an underscore (_).'
|
||||
with self.assertRaisesMessage(ValueError, msg):
|
||||
models.Index(fields=['title'], name='_name_starting_with_underscore')
|
||||
|
||||
msg = 'Index names cannot start with a number (0-9).'
|
||||
with self.assertRaisesMessage(ValueError, msg):
|
||||
models.Index(fields=['title'], name='5name_starting_with_number')
|
||||
|
||||
def test_name_auto_generation(self):
|
||||
index = models.Index(fields=['author'])
|
||||
index.set_name_with_model(Book)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue