mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #13335: Adjusted the r12950 fix to properly handle import errors resulting from nested calls to load_app.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12972 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -75,16 +75,23 @@ class AppCache(object):
|
||||
app_module = import_module(app_name)
|
||||
try:
|
||||
imp.find_module('models', app_module.__path__)
|
||||
except ImportError:
|
||||
self.nesting_level -= 1
|
||||
# App has no models module, that's not a problem.
|
||||
return None
|
||||
try:
|
||||
models = import_module('.models', app_name)
|
||||
except ImportError:
|
||||
self.nesting_level -= 1
|
||||
if can_postpone:
|
||||
# Either the app has no models, or the package is still being
|
||||
# Either the app has an error, or the package is still being
|
||||
# imported by Python and the model module isn't available yet.
|
||||
# We will check again once all the recursion has finished (in
|
||||
# populate).
|
||||
self.postponed.append(app_name)
|
||||
return None
|
||||
models = import_module('.models', app_name)
|
||||
return None
|
||||
else:
|
||||
raise
|
||||
self.nesting_level -= 1
|
||||
if models not in self.app_store:
|
||||
self.app_store[models] = len(self.app_store)
|
||||
|
@@ -0,0 +1,3 @@
|
||||
from django.contrib import admin
|
||||
from admin_scripts.complex_app.models.foo import Foo
|
||||
admin.site.register(Foo)
|
@@ -0,0 +1,4 @@
|
||||
from admin_scripts.complex_app.models.bar import Bar
|
||||
from admin_scripts.complex_app.models.foo import Foo
|
||||
|
||||
__all__ = ['Foo', 'Bar']
|
@@ -0,0 +1,7 @@
|
||||
from django.db import models
|
||||
|
||||
from ..admin import foo
|
||||
class Bar(models.Model):
|
||||
name = models.CharField(max_length=5)
|
||||
class Meta:
|
||||
app_label = 'complex_app'
|
@@ -0,0 +1,6 @@
|
||||
from django.db import models
|
||||
|
||||
class Foo(models.Model):
|
||||
name = models.CharField(max_length=5)
|
||||
class Meta:
|
||||
app_label = 'complex_app'
|
1
tests/regressiontests/admin_scripts/simple_app/models.py
Normal file
1
tests/regressiontests/admin_scripts/simple_app/models.py
Normal file
@@ -0,0 +1 @@
|
||||
from admin_scripts.complex_app.models.bar import Bar
|
@@ -957,7 +957,7 @@ class ManageMultipleSettings(AdminScriptTestCase):
|
||||
self.assertOutput(err, "Unknown command: 'noargs_command'")
|
||||
|
||||
|
||||
class ManageValidateImportErrorsReported(AdminScriptTestCase):
|
||||
class ManageValidate(AdminScriptTestCase):
|
||||
def tearDown(self):
|
||||
self.remove_settings('settings.py')
|
||||
|
||||
@@ -976,7 +976,17 @@ class ManageValidateImportErrorsReported(AdminScriptTestCase):
|
||||
out, err = self.run_manage(args)
|
||||
self.assertNoOutput(out)
|
||||
self.assertOutput(err, 'ImportError')
|
||||
|
||||
|
||||
def test_complex_app(self):
|
||||
"manage.py validate does not raise an ImportError validating a complex app with nested calls to load_app"
|
||||
self.write_settings('settings.py',
|
||||
apps=['admin_scripts.complex_app', 'admin_scripts.simple_app'],
|
||||
sdict={'DEBUG': True})
|
||||
args = ['validate']
|
||||
out, err = self.run_manage(args)
|
||||
self.assertNoOutput(err)
|
||||
self.assertOutput(out, '0 errors found')
|
||||
|
||||
|
||||
##########################################################################
|
||||
# COMMAND PROCESSING TESTS
|
||||
|
Reference in New Issue
Block a user