diff options
| author | Jeff <jeffrey.yancey@gmail.com> | 2018-05-23 15:55:27 -0400 |
|---|---|---|
| committer | Tim Graham <timograham@gmail.com> | 2018-06-15 12:07:40 -0400 |
| commit | 2b7b199390336f7068ef8cb8d67b2e83fb6b818e (patch) | |
| tree | 3b2358011320ac23c353797584e8fcec7b4689a3 /tests | |
| parent | 0eca99dadeed76bf0ac1a3cf4b62926ae5717319 (diff) | |
[2.1.x] Fixed #29000 -- Fixed RenameModel's renaming of a M2M column when run after RenameField.
Regression in 45ded053b1f4320284aa5dac63052f6d1baefea9.
Backport of fcc4e251dbc917118f73d7187ee2f4cbf3883f36 from master
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/migrations/test_operations.py | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/tests/migrations/test_operations.py b/tests/migrations/test_operations.py index b5c9fb1b3d..d70feaacdb 100644 --- a/tests/migrations/test_operations.py +++ b/tests/migrations/test_operations.py @@ -802,6 +802,34 @@ class OperationTests(OperationTestBase): self.assertEqual(PonyRider.objects.count(), 2) self.assertEqual(pony.riders.count(), 2) + def test_rename_m2m_model_after_rename_field(self): + """RenameModel renames a many-to-many column after a RenameField.""" + app_label = 'test_rename_multiple' + project_state = self.apply_operations(app_label, ProjectState(), operations=[ + migrations.CreateModel('Pony', fields=[ + ('id', models.AutoField(primary_key=True)), + ('name', models.CharField(max_length=20)), + ]), + migrations.CreateModel('Rider', fields=[ + ('id', models.AutoField(primary_key=True)), + ('pony', models.ForeignKey('test_rename_multiple.Pony', models.CASCADE)), + ]), + migrations.CreateModel('PonyRider', fields=[ + ('id', models.AutoField(primary_key=True)), + ('riders', models.ManyToManyField('Rider')), + ]), + migrations.RenameField(model_name='pony', old_name='name', new_name='fancy_name'), + migrations.RenameModel(old_name='Rider', new_name='Jockey'), + ], atomic=connection.features.supports_atomic_references_rename) + Pony = project_state.apps.get_model(app_label, 'Pony') + Jockey = project_state.apps.get_model(app_label, 'Jockey') + PonyRider = project_state.apps.get_model(app_label, 'PonyRider') + # No "no such column" error means the column was renamed correctly. + pony = Pony.objects.create(fancy_name='a good name') + jockey = Jockey.objects.create(pony=pony) + ponyrider = PonyRider.objects.create() + ponyrider.riders.add(jockey) + def test_add_field(self): """ Tests the AddField operation. |
