1
0
mirror of https://github.com/django/django.git synced 2025-10-20 20:29:14 +00:00

[1.11.x] Fixed #28051 -- Made migrations respect Index's name argument.

Thanks Marc Tamlyn for the report and Tim Graham for the review.

Backport of d3cf75ec6fbdd2c1f1bb1e6ccb48d4de1da2952b from master
This commit is contained in:
Markus Holtermann 2017-04-07 17:47:53 +02:00 committed by Tim Graham
parent 0cb009aa48
commit f9d2a20d7b
3 changed files with 18 additions and 2 deletions

View File

@ -463,6 +463,7 @@ class ModelState(object):
elif name == "indexes": elif name == "indexes":
indexes = [idx.clone() for idx in model._meta.indexes] indexes = [idx.clone() for idx in model._meta.indexes]
for index in indexes: for index in indexes:
if not index.name:
index.set_name_with_model(model) index.set_name_with_model(model)
options['indexes'] = indexes options['indexes'] = indexes
else: else:

View File

@ -9,4 +9,6 @@ Django 1.11.1 fixes several bugs in 1.11.
Bugfixes Bugfixes
======== ========
* ... * Made migrations respect ``Index``s ``name`` argument. If you created a
named index with Django 1.11, ``makemigrations`` will create a migration to
recreate the index with the correct name (:ticket:`28051`).

View File

@ -1071,6 +1071,19 @@ class ModelStateTests(SimpleTestCase):
child1_state.options['indexes'][0].name = 'bar' child1_state.options['indexes'][0].name = 'bar'
self.assertEqual(Child1._meta.indexes[0].name, 'migrations__name_b0afd7_idx') self.assertEqual(Child1._meta.indexes[0].name, 'migrations__name_b0afd7_idx')
@isolate_apps('migrations')
def test_explicit_index_name(self):
class TestModel(models.Model):
name = models.CharField(max_length=50)
class Meta:
app_label = 'migrations'
indexes = [models.indexes.Index(fields=['name'], name='foo_idx')]
model_state = ModelState.from_model(TestModel)
index_names = [index.name for index in model_state.options['indexes']]
self.assertEqual(index_names, ['foo_idx'])
class RelatedModelsTests(SimpleTestCase): class RelatedModelsTests(SimpleTestCase):