diff --git a/django/db/migrations/operations/special.py b/django/db/migrations/operations/special.py index 0700023325..311271483e 100644 --- a/django/db/migrations/operations/special.py +++ b/django/db/migrations/operations/special.py @@ -93,6 +93,8 @@ class RunSQL(Operation): kwargs["state_operations"] = self.state_operations if self.hints: kwargs["hints"] = self.hints + if self.elidable: + kwargs["elidable"] = self.elidable return (self.__class__.__qualname__, [], kwargs) @property @@ -173,6 +175,8 @@ class RunPython(Operation): kwargs["atomic"] = self.atomic if self.hints: kwargs["hints"] = self.hints + if self.elidable: + kwargs["elidable"] = self.elidable return (self.__class__.__qualname__, [], kwargs) @property diff --git a/tests/migrations/test_operations.py b/tests/migrations/test_operations.py index e859b62a10..90c22bc73b 100644 --- a/tests/migrations/test_operations.py +++ b/tests/migrations/test_operations.py @@ -5543,6 +5543,10 @@ class OperationTests(OperationTestBase): elidable_operation = migrations.RunSQL("SELECT 1 FROM void;", elidable=True) self.assertEqual(elidable_operation.reduce(operation, []), [operation]) + # Test elidable deconstruction + definition = elidable_operation.deconstruct() + self.assertIs(definition[2]["elidable"], True) + def test_run_sql_params(self): """ #23426 - RunSQL should accept parameters. @@ -5796,6 +5800,10 @@ class OperationTests(OperationTestBase): elidable_operation = migrations.RunPython(inner_method, elidable=True) self.assertEqual(elidable_operation.reduce(operation, []), [operation]) + # Test elidable deconstruction + definition = elidable_operation.deconstruct() + self.assertIs(definition[2]["elidable"], True) + def test_run_python_invalid_reverse_code(self): msg = "RunPython must be supplied with callable arguments" with self.assertRaisesMessage(ValueError, msg):