mirror of
https://github.com/django/django.git
synced 2025-08-04 02:48:35 +00:00
Revert "Fixed #22397 -- Issues removing M2M field with explicit through model."
This reverts commit 00e3b9a2a9
.
It's causing a regression when tested with the proxy_model_inheritance tests.
This commit is contained in:
parent
214d1e1b0f
commit
0d397e5a5b
7 changed files with 26 additions and 158 deletions
|
@ -1,12 +1,9 @@
|
|||
import unittest
|
||||
|
||||
from django.db import connection, migrations, models, router
|
||||
from django.db.migrations.migration import Migration
|
||||
from django.db.migrations.state import ProjectState
|
||||
from django.db import connection, models, migrations, router
|
||||
from django.db.models.fields import NOT_PROVIDED
|
||||
from django.db.transaction import atomic
|
||||
from django.db.utils import IntegrityError
|
||||
|
||||
from django.db.migrations.state import ProjectState
|
||||
from .test_base import MigrationTestBase
|
||||
|
||||
|
||||
|
@ -18,16 +15,15 @@ class OperationTests(MigrationTestBase):
|
|||
"""
|
||||
|
||||
def apply_operations(self, app_label, project_state, operations):
|
||||
migration = Migration('name', app_label)
|
||||
migration.operations = operations
|
||||
with connection.schema_editor() as editor:
|
||||
return migration.apply(project_state, editor)
|
||||
new_state = project_state.clone()
|
||||
for operation in operations:
|
||||
operation.state_forwards(app_label, new_state)
|
||||
|
||||
def unapply_operations(self, app_label, project_state, operations):
|
||||
migration = Migration('name', app_label)
|
||||
migration.operations = operations
|
||||
# Set up the database
|
||||
with connection.schema_editor() as editor:
|
||||
return migration.unapply(project_state, editor)
|
||||
for operation in operations:
|
||||
operation.database_forwards(app_label, editor, project_state, new_state)
|
||||
return new_state
|
||||
|
||||
def set_up_test_model(self, app_label, second_model=False, related_model=False, mti_model=False):
|
||||
"""
|
||||
|
@ -400,38 +396,6 @@ class OperationTests(MigrationTestBase):
|
|||
Pony = new_apps.get_model("test_alflmm", "Pony")
|
||||
self.assertTrue(Pony._meta.get_field('stables').blank)
|
||||
|
||||
def test_remove_field_m2m(self):
|
||||
project_state = self.set_up_test_model("test_rmflmm", second_model=True)
|
||||
|
||||
project_state = self.apply_operations("test_rmflmm", project_state, operations=[
|
||||
migrations.AddField("Pony", "stables", models.ManyToManyField("Stable", related_name="ponies"))
|
||||
])
|
||||
self.assertTableExists("test_rmflmm_pony_stables")
|
||||
|
||||
operations = [migrations.RemoveField("Pony", "stables")]
|
||||
self.apply_operations("test_rmflmm", project_state, operations=operations)
|
||||
self.assertTableNotExists("test_rmflmm_pony_stables")
|
||||
|
||||
# And test reversal
|
||||
self.unapply_operations("test_rmflmm", project_state, operations=operations)
|
||||
self.assertTableExists("test_rmflmm_pony_stables")
|
||||
|
||||
def test_remove_field_m2m_with_through(self):
|
||||
project_state = self.set_up_test_model("test_rmflmmwt", second_model=True)
|
||||
|
||||
self.assertTableNotExists("test_rmflmmwt_ponystables")
|
||||
project_state = self.apply_operations("test_rmflmmwt", project_state, operations=[
|
||||
migrations.CreateModel("PonyStables", fields=[
|
||||
("pony", models.ForeignKey('test_rmflmmwt.Pony')),
|
||||
("stable", models.ForeignKey('test_rmflmmwt.Stable')),
|
||||
]),
|
||||
migrations.AddField("Pony", "stables", models.ManyToManyField("Stable", related_name="ponies", through='test_rmflmmwt.PonyStables'))
|
||||
])
|
||||
self.assertTableExists("test_rmflmmwt_ponystables")
|
||||
|
||||
operations = [migrations.RemoveField("Pony", "stables")]
|
||||
self.apply_operations("test_rmflmmwt", project_state, operations=operations)
|
||||
|
||||
def test_remove_field(self):
|
||||
"""
|
||||
Tests the RemoveField operation.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue