mirror of
https://github.com/django/django.git
synced 2025-11-25 05:04:26 +00:00
Fixed #24109 -- Allowed RunSQL and RunPython operations to be elided.
Thanks to Markus Holtermann and Tim Graham for their review.
This commit is contained in:
parent
49f4c9f4c6
commit
729e0b086d
9 changed files with 81 additions and 8 deletions
|
|
@ -1,6 +1,7 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
|
||||
from django.db import migrations, models
|
||||
from django.db.migrations import operations
|
||||
from django.db.migrations.optimizer import MigrationOptimizer
|
||||
from django.test import SimpleTestCase
|
||||
|
||||
|
|
@ -631,3 +632,22 @@ class OptimizerTests(SimpleTestCase):
|
|||
migrations.CreateModel("Bar", [("width", models.IntegerField())]),
|
||||
],
|
||||
)
|
||||
|
||||
def test_optimize_elidable_operation(self):
|
||||
elidable_operation = operations.base.Operation()
|
||||
elidable_operation.elidable = True
|
||||
self.assertOptimizesTo(
|
||||
[
|
||||
elidable_operation,
|
||||
migrations.CreateModel("Foo", [("name", models.CharField(max_length=255))]),
|
||||
elidable_operation,
|
||||
migrations.CreateModel("Bar", [("size", models.IntegerField())]),
|
||||
elidable_operation,
|
||||
migrations.RenameModel("Foo", "Phou"),
|
||||
migrations.DeleteModel("Bar"),
|
||||
elidable_operation,
|
||||
],
|
||||
[
|
||||
migrations.CreateModel("Phou", [("name", models.CharField(max_length=255))]),
|
||||
],
|
||||
)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue