mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Fixed #29350 -- Fix get_primary_key_column() method in sqlite3 backend
Thanks Tim Graham and Mariusz Felisiak for the reviews.
This commit is contained in:
committed by
Claude Paroz
parent
6b3d292043
commit
30f8642f2e
27
tests/backends/sqlite/test_introspection.py
Normal file
27
tests/backends/sqlite/test_introspection.py
Normal file
@@ -0,0 +1,27 @@
|
||||
import unittest
|
||||
|
||||
from django.db import connection
|
||||
from django.test import TestCase
|
||||
|
||||
|
||||
@unittest.skipUnless(connection.vendor == 'sqlite', 'SQLite tests')
|
||||
class IntrospectionTests(TestCase):
|
||||
def test_get_primary_key_column(self):
|
||||
"""
|
||||
Get the primary key column regardless of whether or not it has
|
||||
quotation.
|
||||
"""
|
||||
testable_column_strings = (
|
||||
('id', 'id'), ('[id]', 'id'), ('`id`', 'id'), ('"id"', 'id'),
|
||||
('[id col]', 'id col'), ('`id col`', 'id col'), ('"id col"', 'id col')
|
||||
)
|
||||
with connection.cursor() as cursor:
|
||||
for column, expected_string in testable_column_strings:
|
||||
sql = 'CREATE TABLE test_primary (%s int PRIMARY KEY NOT NULL)' % column
|
||||
with self.subTest(column=column):
|
||||
try:
|
||||
cursor.execute(sql)
|
||||
field = connection.introspection.get_primary_key_column(cursor, 'test_primary')
|
||||
self.assertEqual(field, expected_string)
|
||||
finally:
|
||||
cursor.execute('DROP TABLE test_primary')
|
Reference in New Issue
Block a user