mirror of
https://github.com/django/django.git
synced 2025-08-03 18:38:50 +00:00
Fixed #28046 -- Added the db_tablespace parameter to class-based indexes.
Thanks Markus Holtermann and Tim Graham for reviews.
This commit is contained in:
parent
617505ca89
commit
3297dede7f
7 changed files with 93 additions and 23 deletions
|
@ -1,5 +1,6 @@
|
|||
from django.db import models
|
||||
from django.test import SimpleTestCase
|
||||
from django.conf import settings
|
||||
from django.db import connection, models
|
||||
from django.test import SimpleTestCase, skipUnlessDBFeature
|
||||
|
||||
from .models import Book, ChildModel1, ChildModel2
|
||||
|
||||
|
@ -70,12 +71,15 @@ class IndexesTests(SimpleTestCase):
|
|||
long_field_index.set_name_with_model(Book)
|
||||
|
||||
def test_deconstruction(self):
|
||||
index = models.Index(fields=['title'])
|
||||
index = models.Index(fields=['title'], db_tablespace='idx_tbls')
|
||||
index.set_name_with_model(Book)
|
||||
path, args, kwargs = index.deconstruct()
|
||||
self.assertEqual(path, 'django.db.models.Index')
|
||||
self.assertEqual(args, ())
|
||||
self.assertEqual(kwargs, {'fields': ['title'], 'name': 'model_index_title_196f42_idx'})
|
||||
self.assertEqual(
|
||||
kwargs,
|
||||
{'fields': ['title'], 'name': 'model_index_title_196f42_idx', 'db_tablespace': 'idx_tbls'}
|
||||
)
|
||||
|
||||
def test_clone(self):
|
||||
index = models.Index(fields=['title'])
|
||||
|
@ -92,3 +96,39 @@ class IndexesTests(SimpleTestCase):
|
|||
self.assertEqual(index_names, ['model_index_name_440998_idx'])
|
||||
index_names = [index.name for index in ChildModel2._meta.indexes]
|
||||
self.assertEqual(index_names, ['model_index_name_b6c374_idx'])
|
||||
|
||||
@skipUnlessDBFeature('supports_tablespaces')
|
||||
def test_db_tablespace(self):
|
||||
with connection.schema_editor() as editor:
|
||||
# Index with db_tablespace attribute.
|
||||
for fields in [
|
||||
# Field with db_tablespace specified on model.
|
||||
['shortcut'],
|
||||
# Field without db_tablespace specified on model.
|
||||
['author'],
|
||||
# Multi-column with db_tablespaces specified on model.
|
||||
['shortcut', 'isbn'],
|
||||
# Multi-column without db_tablespace specified on model.
|
||||
['title', 'author'],
|
||||
]:
|
||||
with self.subTest(fields=fields):
|
||||
index = models.Index(fields=fields, db_tablespace='idx_tbls2')
|
||||
self.assertIn('"idx_tbls2"', index.create_sql(Book, editor).lower())
|
||||
# Indexes without db_tablespace attribute.
|
||||
for fields in [['author'], ['shortcut', 'isbn'], ['title', 'author']]:
|
||||
with self.subTest(fields=fields):
|
||||
index = models.Index(fields=fields)
|
||||
# The DEFAULT_INDEX_TABLESPACE setting can't be tested
|
||||
# because it's evaluated when the model class is defined.
|
||||
# As a consequence, @override_settings doesn't work.
|
||||
if settings.DEFAULT_INDEX_TABLESPACE:
|
||||
self.assertIn(
|
||||
'"%s"' % settings.DEFAULT_INDEX_TABLESPACE,
|
||||
index.create_sql(Book, editor).lower()
|
||||
)
|
||||
else:
|
||||
self.assertNotIn('TABLESPACE', index.create_sql(Book, editor))
|
||||
# Field with db_tablespace specified on the model and an index
|
||||
# without db_tablespace.
|
||||
index = models.Index(fields=['shortcut'])
|
||||
self.assertIn('"idx_tbls"', index.create_sql(Book, editor).lower())
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue