mirror of
https://github.com/django/django.git
synced 2025-07-24 05:36:15 +00:00
Fixed #29015 -- Added an exception if the PostgreSQL database name is too long.
This commit is contained in:
parent
6d1f576945
commit
6b3d292043
2 changed files with 19 additions and 0 deletions
|
@ -2,6 +2,7 @@ import unittest
|
|||
import warnings
|
||||
from unittest import mock
|
||||
|
||||
from django.core.exceptions import ImproperlyConfigured
|
||||
from django.db import DatabaseError, connection, connections
|
||||
from django.test import TestCase
|
||||
|
||||
|
@ -39,6 +40,18 @@ class Tests(TestCase):
|
|||
self.assertEqual(len(w), 1)
|
||||
self.assertEqual(w[0].message.__class__, RuntimeWarning)
|
||||
|
||||
def test_database_name_too_long(self):
|
||||
from django.db.backends.postgresql.base import DatabaseWrapper
|
||||
settings = connection.settings_dict.copy()
|
||||
max_name_length = connection.ops.max_name_length()
|
||||
settings['NAME'] = 'a' + (max_name_length * 'a')
|
||||
msg = (
|
||||
'Database names longer than %d characters are not supported by '
|
||||
'PostgreSQL. Supply a shorter NAME in settings.DATABASES.'
|
||||
) % max_name_length
|
||||
with self.assertRaisesMessage(ImproperlyConfigured, msg):
|
||||
DatabaseWrapper(settings).get_connection_params()
|
||||
|
||||
def test_connect_and_rollback(self):
|
||||
"""
|
||||
PostgreSQL shouldn't roll back SET TIME ZONE, even if the first
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue