mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #19401 -- Ensure that swappable model references are case insensitive.
This is necessary because get_model() checks are case insensitive, and if the swapable check isn't, the swappable logic gets tied up in knots with models that are partially swapped out. Thanks to chris@cogdon.org for the report and extensive analysis, and Preston for his work on the draft patch.
This commit is contained in:
@@ -9,6 +9,8 @@ from django.db.models.loading import cache
|
||||
from django.test import TestCase
|
||||
from django.test.utils import override_settings
|
||||
|
||||
from regressiontests.swappable_models.models import Article
|
||||
|
||||
|
||||
class SwappableModelTests(TestCase):
|
||||
def setUp(self):
|
||||
@@ -44,3 +46,13 @@ class SwappableModelTests(TestCase):
|
||||
for ct in ContentType.objects.all()]
|
||||
self.assertIn(('swappable_models', 'alternatearticle'), apps_models)
|
||||
self.assertNotIn(('swappable_models', 'article'), apps_models)
|
||||
|
||||
@override_settings(TEST_ARTICLE_MODEL='swappable_models.article')
|
||||
def test_case_insensitive(self):
|
||||
"Model names are case insensitive. Check that model swapping honors this."
|
||||
try:
|
||||
Article.objects.all()
|
||||
except AttributeError:
|
||||
self.fail('Swappable model names should be case insensitive.')
|
||||
|
||||
self.assertIsNone(Article._meta.swapped)
|
||||
|
||||
Reference in New Issue
Block a user