{{{
django.core.exceptions.ImproperlyConfigured: Cannot determine PostGIS
version for database "umap" . GeoDjango requires at least PostGIS version
1.3. Was the database created from a spatial database template?
}}}
This patch first does a trivial database connection to flesh out the real
exception, before checking the PostGIS version number:
{{{
***************
*** 246,256 ****
# comprising user-supplied values for the major, minor, and
# subminor revision of PostGIS.
-
- # First connect to the database trivially
- # This prevents raising a GeoDjango exception below if the
connection is bad
- with self.connection.temporary_connection() as cursor:
- cursor.execute('SELECT version()')
-
- # Now check PostGIS
if hasattr(settings, 'POSTGIS_VERSION'):
version = settings.POSTGIS_VERSION
--- 246,249 ----
***************
*** 260,265 ****
except DatabaseError:
raise ImproperlyConfigured(
! 'Cannot determine PostGIS version for database "%s"
'
! 'using command "SELECT postgis_lib_version()". '
'GeoDjango requires at least PostGIS version 1.3. '
'Was the database created from a spatial database '
--- 253,257 ----
except DatabaseError:
raise ImproperlyConfigured(
! 'Cannot determine PostGIS version for database "%s".
'
'GeoDjango requires at least PostGIS version 1.3. '
'Was the database created from a spatial database '
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/24862>
Django <https://code.djangoproject.com/>
The Web framework for perfectionists with deadlines.
* needs_better_patch: => 0
* needs_tests: => 0
* needs_docs: => 0
Old description:
New description:
For a project with GeoDjango if the database is completely down, you'll
get exception:
}}}
--
--
Ticket URL: <https://code.djangoproject.com/ticket/24862#comment:1>
* needs_better_patch: 0 => 1
* version: 1.8 => master
* stage: Unreviewed => Accepted
Comment:
Good suggestion. Could you attach a patch against master, either as a
Github pull request, or as a `git diff` output?
--
Ticket URL: <https://code.djangoproject.com/ticket/24862#comment:2>
* status: new => assigned
* owner: nobody => sephii
--
Ticket URL: <https://code.djangoproject.com/ticket/24862#comment:3>
Comment (by sephii):
Pull request is available here:
https://github.com/django/django/pull/4796/
Note that:
* I didn't include tests for this trivial change
* I wasn't able to reproduce the issue since it looks like that on newer
PostGIS versions PostGIS functions are always available
--
Ticket URL: <https://code.djangoproject.com/ticket/24862#comment:4>
* status: assigned => closed
* resolution: => fixed
Comment:
In [changeset:"0a899157836cc4c3d3980ab6a70b2f37bbb7ba97" 0a899157]:
{{{
#!CommitTicketReference repository=""
revision="0a899157836cc4c3d3980ab6a70b2f37bbb7ba97"
Fixed #24862 -- Improved PostGIS database connection error message
Thanks brycenesbitt for the patch.
}}}
--
Ticket URL: <https://code.djangoproject.com/ticket/24862#comment:5>