summaryrefslogtreecommitdiff
path: root/django/db/backends/postgresql_psycopg2/base.py
diff options
context:
space:
mode:
authorClaude Paroz <claude@2xlibre.net>2015-05-14 19:27:31 +0200
committerClaude Paroz <claude@2xlibre.net>2015-05-15 18:44:20 +0200
commit3226050358cfcffcb14f7e48e3a5cee873388406 (patch)
tree470e446939b422a6764df8ef393396e3663f1662 /django/db/backends/postgresql_psycopg2/base.py
parent2dee853ed4def42b7ef1b3b472b395055543cc00 (diff)
Fixed #24791 -- Added fallback when 'postgres' database isn't available
Thanks Carl Meyer and Tim Graham for the reviews.
Diffstat (limited to 'django/db/backends/postgresql_psycopg2/base.py')
-rw-r--r--django/db/backends/postgresql_psycopg2/base.py26
1 files changed, 26 insertions, 0 deletions
diff --git a/django/db/backends/postgresql_psycopg2/base.py b/django/db/backends/postgresql_psycopg2/base.py
index d110b120d7..a76ca3c0df 100644
--- a/django/db/backends/postgresql_psycopg2/base.py
+++ b/django/db/backends/postgresql_psycopg2/base.py
@@ -4,10 +4,14 @@ PostgreSQL database backend for Django.
Requires psycopg 2: http://initd.org/projects/psycopg2
"""
+import warnings
+
from django.conf import settings
from django.core.exceptions import ImproperlyConfigured
+from django.db import DEFAULT_DB_ALIAS
from django.db.backends.base.base import BaseDatabaseWrapper
from django.db.backends.base.validation import BaseDatabaseValidation
+from django.db.utils import DatabaseError as WrappedDatabaseError
from django.utils.encoding import force_str
from django.utils.functional import cached_property
from django.utils.safestring import SafeBytes, SafeText
@@ -231,6 +235,28 @@ class DatabaseWrapper(BaseDatabaseWrapper):
return True
@cached_property
+ def _nodb_connection(self):
+ nodb_connection = super(DatabaseWrapper, self)._nodb_connection
+ try:
+ nodb_connection.ensure_connection()
+ except (DatabaseError, WrappedDatabaseError):
+ warnings.warn(
+ "Normally Django will use a connection to the 'postgres' database "
+ "to avoid running initialization queries against the production "
+ "database when it's not needed (for example, when running tests). "
+ "Django was unable to create a connection to the 'postgres' database "
+ "and will use the default database instead.",
+ RuntimeWarning
+ )
+ settings_dict = self.settings_dict.copy()
+ settings_dict['NAME'] = settings.DATABASES[DEFAULT_DB_ALIAS]['NAME']
+ nodb_connection = self.__class__(
+ self.settings_dict.copy(),
+ alias=self.alias,
+ allow_thread_sharing=False)
+ return nodb_connection
+
+ @cached_property
def psycopg2_version(self):
return PSYCOPG2_VERSION