mirror of
https://github.com/django/django.git
synced 2025-01-03 15:06:09 +00:00
Fixed #30903 -- Fixed migrations crash on PostgreSQL when adding Index with opclasses and ordering.
This commit is contained in:
parent
2a54ce72f9
commit
fa5f3291e7
1
AUTHORS
1
AUTHORS
@ -340,6 +340,7 @@ answer newbie questions, and generally made Django that much better:
|
|||||||
Gustavo Picon
|
Gustavo Picon
|
||||||
hambaloney
|
hambaloney
|
||||||
Hang Park <hangpark@kaist.ac.kr>
|
Hang Park <hangpark@kaist.ac.kr>
|
||||||
|
Hannes Ljungberg <hannes.ljungberg@gmail.com>
|
||||||
Hannes Struß <x@hannesstruss.de>
|
Hannes Struß <x@hannesstruss.de>
|
||||||
Hasan Ramezani <hasan.r67@gmail.com>
|
Hasan Ramezani <hasan.r67@gmail.com>
|
||||||
Hawkeye
|
Hawkeye
|
||||||
|
@ -110,13 +110,14 @@ class IndexColumns(Columns):
|
|||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
def col_str(column, idx):
|
def col_str(column, idx):
|
||||||
try:
|
|
||||||
col = self.quote_name(column) + self.col_suffixes[idx]
|
|
||||||
except IndexError:
|
|
||||||
col = self.quote_name(column)
|
|
||||||
# Index.__init__() guarantees that self.opclasses is the same
|
# Index.__init__() guarantees that self.opclasses is the same
|
||||||
# length as self.columns.
|
# length as self.columns.
|
||||||
return '{} {}'.format(col, self.opclasses[idx])
|
col = '{} {}'.format(self.quote_name(column), self.opclasses[idx])
|
||||||
|
try:
|
||||||
|
col = '{} {}'.format(col, self.col_suffixes[idx])
|
||||||
|
except IndexError:
|
||||||
|
pass
|
||||||
|
return col
|
||||||
|
|
||||||
return ', '.join(col_str(column, idx) for idx, column in enumerate(self.columns))
|
return ', '.join(col_str(column, idx) for idx, column in enumerate(self.columns))
|
||||||
|
|
||||||
|
@ -17,3 +17,7 @@ Bugfixes
|
|||||||
* Prevented :option:`migrate --plan` from showing that ``RunPython`` operations
|
* Prevented :option:`migrate --plan` from showing that ``RunPython`` operations
|
||||||
are irreversible when ``reverse_code`` callables don't have docstrings or
|
are irreversible when ``reverse_code`` callables don't have docstrings or
|
||||||
when showing a forward migration plan (:ticket:`30870`).
|
when showing a forward migration plan (:ticket:`30870`).
|
||||||
|
|
||||||
|
* Fixed migrations crash on PostgreSQL when adding an
|
||||||
|
:class:`~django.db.models.Index` with fields ordering and
|
||||||
|
:attr:`~.Index.opclasses` (:ticket:`30903`).
|
||||||
|
@ -196,6 +196,33 @@ class SchemaIndexesPostgreSQLTests(TransactionTestCase):
|
|||||||
cursor.execute(self.get_opclass_query % indexname)
|
cursor.execute(self.get_opclass_query % indexname)
|
||||||
self.assertCountEqual(cursor.fetchall(), [('text_pattern_ops', indexname)])
|
self.assertCountEqual(cursor.fetchall(), [('text_pattern_ops', indexname)])
|
||||||
|
|
||||||
|
def test_ops_class_descending(self):
|
||||||
|
indexname = 'test_ops_class_ordered'
|
||||||
|
index = Index(
|
||||||
|
name=indexname,
|
||||||
|
fields=['-body'],
|
||||||
|
opclasses=['text_pattern_ops'],
|
||||||
|
)
|
||||||
|
with connection.schema_editor() as editor:
|
||||||
|
editor.add_index(IndexedArticle2, index)
|
||||||
|
with editor.connection.cursor() as cursor:
|
||||||
|
cursor.execute(self.get_opclass_query % indexname)
|
||||||
|
self.assertCountEqual(cursor.fetchall(), [('text_pattern_ops', indexname)])
|
||||||
|
|
||||||
|
def test_ops_class_descending_partial(self):
|
||||||
|
indexname = 'test_ops_class_ordered_partial'
|
||||||
|
index = Index(
|
||||||
|
name=indexname,
|
||||||
|
fields=['-body'],
|
||||||
|
opclasses=['text_pattern_ops'],
|
||||||
|
condition=Q(headline__contains='China'),
|
||||||
|
)
|
||||||
|
with connection.schema_editor() as editor:
|
||||||
|
editor.add_index(IndexedArticle2, index)
|
||||||
|
with editor.connection.cursor() as cursor:
|
||||||
|
cursor.execute(self.get_opclass_query % indexname)
|
||||||
|
self.assertCountEqual(cursor.fetchall(), [('text_pattern_ops', indexname)])
|
||||||
|
|
||||||
|
|
||||||
@skipUnless(connection.vendor == 'mysql', 'MySQL tests')
|
@skipUnless(connection.vendor == 'mysql', 'MySQL tests')
|
||||||
class SchemaIndexesMySQLTests(TransactionTestCase):
|
class SchemaIndexesMySQLTests(TransactionTestCase):
|
||||||
|
Loading…
Reference in New Issue
Block a user