mirror of
https://github.com/django/django.git
synced 2025-10-23 21:59:11 +00:00
Fixed #12693 -- Improved error handling when there is an error setting up the database router chain. Thanks to dhageman for the report and fix.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@12305 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
@@ -92,9 +92,14 @@ class ConnectionRouter(object):
|
|||||||
self.routers = []
|
self.routers = []
|
||||||
for r in routers:
|
for r in routers:
|
||||||
if isinstance(r, basestring):
|
if isinstance(r, basestring):
|
||||||
|
try:
|
||||||
module_name, klass_name = r.rsplit('.', 1)
|
module_name, klass_name = r.rsplit('.', 1)
|
||||||
module = import_module(module_name)
|
module = import_module(module_name)
|
||||||
router = getattr(module, klass_name)()
|
router = getattr(module, klass_name)()
|
||||||
|
except ImportError, e:
|
||||||
|
raise ImproperlyConfigured('Error importing database router %s: "%s"' % (klass_name, e))
|
||||||
|
except AttributeError:
|
||||||
|
raise ImproperlyConfigured('Module "%s" does not define a "%s" database router' % (module, klass_name))
|
||||||
else:
|
else:
|
||||||
router = r
|
router = r
|
||||||
self.routers.append(router)
|
self.routers.append(router)
|
||||||
|
Reference in New Issue
Block a user