mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[4.2.x] Fixed #34529, Refs #34525 -- Reduced index operations with Meta.indexes/index_together when optimizing migrations.
This makes squashing migrations an available path for changing Meta.index_together, which is deprecated, to Meta.indexes. Follow up tof810325721. Backport of8e2460d599from main.
This commit is contained in:
		| @@ -2266,10 +2266,9 @@ class AutodetectorTests(BaseAutodetectorTests): | ||||
|             changes, | ||||
|             "eggs", | ||||
|             0, | ||||
|             ["CreateModel", "CreateModel", "AddIndex", "AlterUniqueTogether"], | ||||
|             ["CreateModel", "CreateModel"], | ||||
|         ) | ||||
|         self.assertNotIn("unique_together", changes["eggs"][0].operations[0].options) | ||||
|         self.assertNotIn("unique_together", changes["eggs"][0].operations[1].options) | ||||
|         self.assertMigrationDependencies(changes, "eggs", 0, []) | ||||
|  | ||||
|     def test_alter_db_table_add(self): | ||||
| @@ -2565,6 +2564,9 @@ class AutodetectorTests(BaseAutodetectorTests): | ||||
|  | ||||
|     def test_create_model_with_indexes(self): | ||||
|         """Test creation of new model with indexes already defined.""" | ||||
|         added_index = models.Index( | ||||
|             fields=["name"], name="create_model_with_indexes_idx" | ||||
|         ) | ||||
|         author = ModelState( | ||||
|             "otherapp", | ||||
|             "Author", | ||||
| @@ -2573,25 +2575,25 @@ class AutodetectorTests(BaseAutodetectorTests): | ||||
|                 ("name", models.CharField(max_length=200)), | ||||
|             ], | ||||
|             { | ||||
|                 "indexes": [ | ||||
|                     models.Index(fields=["name"], name="create_model_with_indexes_idx") | ||||
|                 ] | ||||
|                 "indexes": [added_index], | ||||
|             }, | ||||
|         ) | ||||
|         changes = self.get_changes([], [author]) | ||||
|         added_index = models.Index( | ||||
|             fields=["name"], name="create_model_with_indexes_idx" | ||||
|         ) | ||||
|         # Right number of migrations? | ||||
|         self.assertEqual(len(changes["otherapp"]), 1) | ||||
|         # Right number of actions? | ||||
|         migration = changes["otherapp"][0] | ||||
|         self.assertEqual(len(migration.operations), 2) | ||||
|         self.assertEqual(len(migration.operations), 1) | ||||
|         # Right actions order? | ||||
|         self.assertOperationTypes(changes, "otherapp", 0, ["CreateModel", "AddIndex"]) | ||||
|         self.assertOperationTypes(changes, "otherapp", 0, ["CreateModel"]) | ||||
|         self.assertOperationAttributes(changes, "otherapp", 0, 0, name="Author") | ||||
|         self.assertOperationAttributes( | ||||
|             changes, "otherapp", 0, 1, model_name="author", index=added_index | ||||
|             changes, | ||||
|             "otherapp", | ||||
|             0, | ||||
|             0, | ||||
|             name="Author", | ||||
|             options={"indexes": [added_index]}, | ||||
|         ) | ||||
|  | ||||
|     def test_add_indexes(self): | ||||
| @@ -3984,62 +3986,69 @@ class AutodetectorTests(BaseAutodetectorTests): | ||||
|             }, | ||||
|         ) | ||||
|  | ||||
|     def test_add_model_order_with_respect_to_index_constraint(self): | ||||
|         tests = [ | ||||
|             ( | ||||
|                 "AddIndex", | ||||
|                 { | ||||
|                     "indexes": [ | ||||
|                         models.Index(fields=["_order"], name="book_order_idx"), | ||||
|                     ] | ||||
|                 }, | ||||
|             ), | ||||
|             ( | ||||
|                 "AddConstraint", | ||||
|                 { | ||||
|                     "constraints": [ | ||||
|                         models.CheckConstraint( | ||||
|                             check=models.Q(_order__gt=1), | ||||
|                             name="book_order_gt_1", | ||||
|                         ), | ||||
|                     ] | ||||
|                 }, | ||||
|             ), | ||||
|         ] | ||||
|         for operation, extra_option in tests: | ||||
|             with self.subTest(operation=operation): | ||||
|                 after = ModelState( | ||||
|                     "testapp", | ||||
|                     "Author", | ||||
|                     [ | ||||
|                         ("id", models.AutoField(primary_key=True)), | ||||
|                         ("name", models.CharField(max_length=200)), | ||||
|                         ("book", models.ForeignKey("otherapp.Book", models.CASCADE)), | ||||
|                     ], | ||||
|                     options={ | ||||
|                         "order_with_respect_to": "book", | ||||
|                         **extra_option, | ||||
|                     }, | ||||
|                 ) | ||||
|                 changes = self.get_changes([], [self.book, after]) | ||||
|                 self.assertNumberMigrations(changes, "testapp", 1) | ||||
|                 self.assertOperationTypes( | ||||
|                     changes, | ||||
|                     "testapp", | ||||
|                     0, | ||||
|                     [ | ||||
|                         "CreateModel", | ||||
|                         operation, | ||||
|                     ], | ||||
|                 ) | ||||
|                 self.assertOperationAttributes( | ||||
|                     changes, | ||||
|                     "testapp", | ||||
|                     0, | ||||
|                     0, | ||||
|                     name="Author", | ||||
|                     options={"order_with_respect_to": "book"}, | ||||
|                 ) | ||||
|     def test_add_model_order_with_respect_to_constraint(self): | ||||
|         after = ModelState( | ||||
|             "testapp", | ||||
|             "Author", | ||||
|             [ | ||||
|                 ("id", models.AutoField(primary_key=True)), | ||||
|                 ("name", models.CharField(max_length=200)), | ||||
|                 ("book", models.ForeignKey("otherapp.Book", models.CASCADE)), | ||||
|             ], | ||||
|             options={ | ||||
|                 "order_with_respect_to": "book", | ||||
|                 "constraints": [ | ||||
|                     models.CheckConstraint( | ||||
|                         check=models.Q(_order__gt=1), name="book_order_gt_1" | ||||
|                     ), | ||||
|                 ], | ||||
|             }, | ||||
|         ) | ||||
|         changes = self.get_changes([], [self.book, after]) | ||||
|         self.assertNumberMigrations(changes, "testapp", 1) | ||||
|         self.assertOperationTypes( | ||||
|             changes, | ||||
|             "testapp", | ||||
|             0, | ||||
|             ["CreateModel", "AddConstraint"], | ||||
|         ) | ||||
|         self.assertOperationAttributes( | ||||
|             changes, | ||||
|             "testapp", | ||||
|             0, | ||||
|             0, | ||||
|             name="Author", | ||||
|             options={"order_with_respect_to": "book"}, | ||||
|         ) | ||||
|  | ||||
|     def test_add_model_order_with_respect_to_index(self): | ||||
|         after = ModelState( | ||||
|             "testapp", | ||||
|             "Author", | ||||
|             [ | ||||
|                 ("id", models.AutoField(primary_key=True)), | ||||
|                 ("name", models.CharField(max_length=200)), | ||||
|                 ("book", models.ForeignKey("otherapp.Book", models.CASCADE)), | ||||
|             ], | ||||
|             options={ | ||||
|                 "order_with_respect_to": "book", | ||||
|                 "indexes": [models.Index(fields=["_order"], name="book_order_idx")], | ||||
|             }, | ||||
|         ) | ||||
|         changes = self.get_changes([], [self.book, after]) | ||||
|         self.assertNumberMigrations(changes, "testapp", 1) | ||||
|         self.assertOperationTypes(changes, "testapp", 0, ["CreateModel"]) | ||||
|         self.assertOperationAttributes( | ||||
|             changes, | ||||
|             "testapp", | ||||
|             0, | ||||
|             0, | ||||
|             name="Author", | ||||
|             options={ | ||||
|                 "order_with_respect_to": "book", | ||||
|                 "indexes": [models.Index(fields=["_order"], name="book_order_idx")], | ||||
|             }, | ||||
|         ) | ||||
|  | ||||
|     def test_set_alter_order_with_respect_to_index_constraint_unique_together(self): | ||||
|         tests = [ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user