From ef6308db01f7b57467f62b731ce968a9fa18fc48 Mon Sep 17 00:00:00 2001 From: Karen Tracey Date: Wed, 14 Apr 2010 19:14:23 +0000 Subject: [PATCH] [1.1.X] 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/branches/releases/1.1.X@12973 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- django/db/models/loading.py | 13 ++++++++++--- .../admin_scripts/complex_app/__init__.py | 0 .../admin_scripts/complex_app/admin/__init__.py | 0 .../admin_scripts/complex_app/admin/foo.py | 3 +++ .../admin_scripts/complex_app/models/__init__.py | 4 ++++ .../admin_scripts/complex_app/models/bar.py | 7 +++++++ .../admin_scripts/complex_app/models/foo.py | 6 ++++++ .../admin_scripts/simple_app/__init__.py | 0 .../admin_scripts/simple_app/models.py | 1 + tests/regressiontests/admin_scripts/tests.py | 14 ++++++++++++-- 10 files changed, 43 insertions(+), 5 deletions(-) create mode 100644 tests/regressiontests/admin_scripts/complex_app/__init__.py create mode 100644 tests/regressiontests/admin_scripts/complex_app/admin/__init__.py create mode 100644 tests/regressiontests/admin_scripts/complex_app/admin/foo.py create mode 100644 tests/regressiontests/admin_scripts/complex_app/models/__init__.py create mode 100644 tests/regressiontests/admin_scripts/complex_app/models/bar.py create mode 100644 tests/regressiontests/admin_scripts/complex_app/models/foo.py create mode 100644 tests/regressiontests/admin_scripts/simple_app/__init__.py create mode 100644 tests/regressiontests/admin_scripts/simple_app/models.py diff --git a/django/db/models/loading.py b/django/db/models/loading.py index 5a8cb0d083..ddf6d3c99f 100644 --- a/django/db/models/loading.py +++ b/django/db/models/loading.py @@ -74,16 +74,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) diff --git a/tests/regressiontests/admin_scripts/complex_app/__init__.py b/tests/regressiontests/admin_scripts/complex_app/__init__.py new file mode 100644 index 0000000000..e69de29bb2 diff --git a/tests/regressiontests/admin_scripts/complex_app/admin/__init__.py b/tests/regressiontests/admin_scripts/complex_app/admin/__init__.py new file mode 100644 index 0000000000..e69de29bb2 diff --git a/tests/regressiontests/admin_scripts/complex_app/admin/foo.py b/tests/regressiontests/admin_scripts/complex_app/admin/foo.py new file mode 100644 index 0000000000..1b933d028d --- /dev/null +++ b/tests/regressiontests/admin_scripts/complex_app/admin/foo.py @@ -0,0 +1,3 @@ +from django.contrib import admin +from admin_scripts.complex_app.models.foo import Foo +admin.site.register(Foo) diff --git a/tests/regressiontests/admin_scripts/complex_app/models/__init__.py b/tests/regressiontests/admin_scripts/complex_app/models/__init__.py new file mode 100644 index 0000000000..a4d6d9539a --- /dev/null +++ b/tests/regressiontests/admin_scripts/complex_app/models/__init__.py @@ -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'] diff --git a/tests/regressiontests/admin_scripts/complex_app/models/bar.py b/tests/regressiontests/admin_scripts/complex_app/models/bar.py new file mode 100644 index 0000000000..1da16f8f65 --- /dev/null +++ b/tests/regressiontests/admin_scripts/complex_app/models/bar.py @@ -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' diff --git a/tests/regressiontests/admin_scripts/complex_app/models/foo.py b/tests/regressiontests/admin_scripts/complex_app/models/foo.py new file mode 100644 index 0000000000..70c285e392 --- /dev/null +++ b/tests/regressiontests/admin_scripts/complex_app/models/foo.py @@ -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' diff --git a/tests/regressiontests/admin_scripts/simple_app/__init__.py b/tests/regressiontests/admin_scripts/simple_app/__init__.py new file mode 100644 index 0000000000..e69de29bb2 diff --git a/tests/regressiontests/admin_scripts/simple_app/models.py b/tests/regressiontests/admin_scripts/simple_app/models.py new file mode 100644 index 0000000000..65b30ed38a --- /dev/null +++ b/tests/regressiontests/admin_scripts/simple_app/models.py @@ -0,0 +1 @@ +from admin_scripts.complex_app.models.bar import Bar diff --git a/tests/regressiontests/admin_scripts/tests.py b/tests/regressiontests/admin_scripts/tests.py index d7e21ce92f..d17c0de7b4 100644 --- a/tests/regressiontests/admin_scripts/tests.py +++ b/tests/regressiontests/admin_scripts/tests.py @@ -958,7 +958,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') @@ -977,7 +977,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