[2.2.x] Fixed #30111 -- Fixed AppRegistryNotReady error with django.contrib.postgres in INSTALLED_APPS.

Regression in e192223ed9.
Backport of 2804b8d215 from master.
This commit is contained in:
Nasir Hussain 2019-01-23 03:49:30 +05:00 committed by Tim Graham
parent 51247bc55f
commit 6ce7887f13
3 changed files with 44 additions and 10 deletions

View File

@ -1,6 +1,7 @@
from django.apps.registry import Apps from django.apps.registry import Apps
from django.db import models from django.db import models
from django.db.utils import DatabaseError from django.db.utils import DatabaseError
from django.utils.decorators import classproperty
from django.utils.timezone import now from django.utils.timezone import now
from .exceptions import MigrationSchemaMissing from .exceptions import MigrationSchemaMissing
@ -18,7 +19,15 @@ class MigrationRecorder:
If a migration is unapplied its row is removed from the table. Having If a migration is unapplied its row is removed from the table. Having
a row in the table always means a migration is applied. a row in the table always means a migration is applied.
""" """
_migration_class = None
@classproperty
def Migration(cls):
"""
Lazy load to avoid AppRegistryNotReady if installed apps import
MigrationRecorder.
"""
if cls._migration_class is None:
class Migration(models.Model): class Migration(models.Model):
app = models.CharField(max_length=255) app = models.CharField(max_length=255)
name = models.CharField(max_length=255) name = models.CharField(max_length=255)
@ -26,11 +35,14 @@ class MigrationRecorder:
class Meta: class Meta:
apps = Apps() apps = Apps()
app_label = "migrations" app_label = 'migrations'
db_table = "django_migrations" db_table = 'django_migrations'
def __str__(self): def __str__(self):
return "Migration %s for %s" % (self.name, self.app) return 'Migration %s for %s' % (self.name, self.app)
cls._migration_class = Migration
return cls._migration_class
def __init__(self, connection): def __init__(self, connection):
self.connection = connection self.connection = connection

View File

@ -0,0 +1,5 @@
SECRET_KEY = 'abcdefg'
INSTALLED_APPS = [
'django.contrib.postgres',
]

View File

@ -0,0 +1,17 @@
import os
import subprocess
import sys
from tests.postgres_tests import PostgreSQLSimpleTestCase
class PostgresIntegrationTests(PostgreSQLSimpleTestCase):
def test_check(self):
os.chdir(os.path.dirname(__file__))
result = subprocess.run(
[sys.executable, '-m', 'django', 'check', '--settings', 'integration_settings'],
stdout=subprocess.DEVNULL,
stderr=subprocess.PIPE,
)
stderr = '\n'.join([e.decode() for e in result.stderr.splitlines()])
self.assertEqual(result.returncode, 0, msg=stderr)