Fixed #33563 -- Fixed contenttype reverse data migration crash with a multiple databases setup.

This commit is contained in:
Hameed Gifford 2022-03-08 00:22:03 -05:00 committed by GitHub
parent c121e32082
commit 58d357fc65
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 33 additions and 1 deletions

View File

@ -2,8 +2,9 @@ from django.db import migrations, models
def add_legacy_name(apps, schema_editor): def add_legacy_name(apps, schema_editor):
alias = schema_editor.connection.alias
ContentType = apps.get_model("contenttypes", "ContentType") ContentType = apps.get_model("contenttypes", "ContentType")
for ct in ContentType.objects.all(): for ct in ContentType.objects.using(alias):
try: try:
ct.name = apps.get_model(ct.app_label, ct.model)._meta.object_name ct.name = apps.get_model(ct.app_label, ct.model)._meta.object_name
except LookupError: except LookupError:

View File

@ -0,0 +1,31 @@
from importlib import import_module
from django.apps import apps
from django.contrib.auth.models import Permission
from django.contrib.contenttypes.models import ContentType
from django.db import DEFAULT_DB_ALIAS, connections
from django.test import TransactionTestCase
remove_content_type_name = import_module(
"django.contrib.contenttypes.migrations.0002_remove_content_type_name"
)
class MultiDBRemoveContentTypeNameTests(TransactionTestCase):
databases = {"default", "other"}
available_apps = ["django.contrib.auth", "django.contrib.contenttypes"]
def test_add_legacy_name_other_database(self):
# add_legacy_name() should update ContentType objects in the specified
# database. Remove ContentTypes from the default database to distinct
# from which database they are fetched.
Permission.objects.all().delete()
ContentType.objects.all().delete()
# ContentType.name in the current version is a property and cannot be
# set, so an AttributeError is raised with the other database.
with self.assertRaises(AttributeError):
with connections["other"].schema_editor() as editor:
remove_content_type_name.add_legacy_name(apps, editor)
# ContentType were removed from the default database.
with connections[DEFAULT_DB_ALIAS].schema_editor() as editor:
remove_content_type_name.add_legacy_name(apps, editor)