mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Fixed #9991: correctly introspect PostgreSQL 'real' types.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@10379 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
		| @@ -7,6 +7,7 @@ class DatabaseIntrospection(BaseDatabaseIntrospection): | |||||||
|         21: 'SmallIntegerField', |         21: 'SmallIntegerField', | ||||||
|         23: 'IntegerField', |         23: 'IntegerField', | ||||||
|         25: 'TextField', |         25: 'TextField', | ||||||
|  |         700: 'FloatField', | ||||||
|         701: 'FloatField', |         701: 'FloatField', | ||||||
|         869: 'IPAddressField', |         869: 'IPAddressField', | ||||||
|         1043: 'CharField', |         1043: 'CharField', | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
|  | from django.conf import settings | ||||||
| from django.db import connection | from django.db import connection | ||||||
| from django.test import TestCase | from django.test import TestCase | ||||||
| from django.utils import functional | from django.utils import functional | ||||||
| @@ -44,11 +45,11 @@ class IntrospectionTests(TestCase): | |||||||
|                       |                       | ||||||
|     def test_django_table_names(self): |     def test_django_table_names(self): | ||||||
|         cursor = connection.cursor() |         cursor = connection.cursor() | ||||||
|         cursor.execute('CREATE TABLE django_introspection_testcase_table (id INTEGER);'); |         cursor.execute('CREATE TABLE django_introspection_test_table (id INTEGER);'); | ||||||
|         tl = connection.introspection.django_table_names() |         tl = connection.introspection.django_table_names() | ||||||
|  |         cursor.execute("DROP TABLE django_introspection_test_table;") | ||||||
|         self.assert_('django_introspection_testcase_table' not in tl, |         self.assert_('django_introspection_testcase_table' not in tl, | ||||||
|                      "django_table_names() returned a non-Django table") |                      "django_table_names() returned a non-Django table") | ||||||
|         cursor.execute("DROP TABLE django_introspection_testcase_table;") |  | ||||||
|                          |                          | ||||||
|     def test_installed_models(self): |     def test_installed_models(self): | ||||||
|         tables = [Article._meta.db_table, Reporter._meta.db_table] |         tables = [Article._meta.db_table, Reporter._meta.db_table] | ||||||
| @@ -68,20 +69,20 @@ class IntrospectionTests(TestCase): | |||||||
|                          [f.column for f in Reporter._meta.fields]) |                          [f.column for f in Reporter._meta.fields]) | ||||||
|      |      | ||||||
|     def test_get_table_description_types(self): |     def test_get_table_description_types(self): | ||||||
|         cursor = connection.cursor() |         cursor = connection.cursor()             | ||||||
|         desc = connection.introspection.get_table_description(cursor, Reporter._meta.db_table) |         desc = connection.introspection.get_table_description(cursor, Reporter._meta.db_table) | ||||||
|  |  | ||||||
|         # Convert the datatype into a string |  | ||||||
|         def datatype(dbtype): |  | ||||||
|             dt = connection.introspection.data_types_reverse[dbtype] |  | ||||||
|             if type(dt) is tuple: |  | ||||||
|                 return dt[0] |  | ||||||
|             else: |  | ||||||
|                 return dt |  | ||||||
|              |  | ||||||
|         self.assertEqual([datatype(r[1]) for r in desc], |         self.assertEqual([datatype(r[1]) for r in desc], | ||||||
|                           ['IntegerField', 'CharField', 'CharField', 'CharField']) |                           ['IntegerField', 'CharField', 'CharField', 'CharField']) | ||||||
|  |  | ||||||
|  |     # Regression test for #9991 - 'real' types in postgres | ||||||
|  |     if settings.DATABASE_ENGINE.startswith('postgresql'): | ||||||
|  |         def test_postgresql_real_type(self): | ||||||
|  |             cursor = connection.cursor() | ||||||
|  |             cursor.execute("CREATE TABLE django_introspection_real_test_table (number REAL);")  | ||||||
|  |             desc = connection.introspection.get_table_description(cursor, 'django_introspection_real_test_table') | ||||||
|  |             cursor.execute('DROP TABLE django_introspection_real_test_table;') | ||||||
|  |             self.assertEqual(datatype(desc[0][1]), 'FloatField') | ||||||
|  |  | ||||||
|     def test_get_relations(self): |     def test_get_relations(self): | ||||||
|         cursor = connection.cursor() |         cursor = connection.cursor() | ||||||
|         relations = connection.introspection.get_relations(cursor, Article._meta.db_table) |         relations = connection.introspection.get_relations(cursor, Article._meta.db_table) | ||||||
| @@ -96,4 +97,12 @@ class IntrospectionTests(TestCase): | |||||||
|     def test_get_indexes(self): |     def test_get_indexes(self): | ||||||
|         cursor = connection.cursor() |         cursor = connection.cursor() | ||||||
|         indexes = connection.introspection.get_indexes(cursor, Article._meta.db_table) |         indexes = connection.introspection.get_indexes(cursor, Article._meta.db_table) | ||||||
|         self.assertEqual(indexes['reporter_id'], {'unique': False, 'primary_key': False}) |         self.assertEqual(indexes['reporter_id'], {'unique': False, 'primary_key': False}) | ||||||
|  |          | ||||||
|  | def datatype(dbtype): | ||||||
|  |     """Helper to convert a data type into a string.""" | ||||||
|  |     dt = connection.introspection.data_types_reverse[dbtype] | ||||||
|  |     if type(dt) is tuple: | ||||||
|  |         return dt[0] | ||||||
|  |     else: | ||||||
|  |         return dt | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user