mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			64 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from unittest import skipUnless
 | |
| 
 | |
| from django.db import connection, connections
 | |
| from django.test import TestCase
 | |
| 
 | |
| 
 | |
| @skipUnless(connection.vendor == "mysql", "MySQL tests")
 | |
| class ParsingTests(TestCase):
 | |
|     def test_parse_constraint_columns(self):
 | |
|         _parse_constraint_columns = connection.introspection._parse_constraint_columns
 | |
|         tests = (
 | |
|             ("`height` >= 0", ["height"], ["height"]),
 | |
|             ("`cost` BETWEEN 1 AND 10", ["cost"], ["cost"]),
 | |
|             ("`ref1` > `ref2`", ["id", "ref1", "ref2"], ["ref1", "ref2"]),
 | |
|             (
 | |
|                 "`start` IS NULL OR `end` IS NULL OR `start` < `end`",
 | |
|                 ["id", "start", "end"],
 | |
|                 ["start", "end"],
 | |
|             ),
 | |
|             ("JSON_VALID(`json_field`)", ["json_field"], ["json_field"]),
 | |
|             ("CHAR_LENGTH(`name`) > 2", ["name"], ["name"]),
 | |
|             ("lower(`ref1`) != 'test'", ["id", "owe", "ref1"], ["ref1"]),
 | |
|             ("lower(`ref1`) != 'test'", ["id", "lower", "ref1"], ["ref1"]),
 | |
|             ("`name` LIKE 'test%'", ["name"], ["name"]),
 | |
|         )
 | |
|         for check_clause, table_columns, expected_columns in tests:
 | |
|             with self.subTest(check_clause):
 | |
|                 check_columns = _parse_constraint_columns(check_clause, table_columns)
 | |
|                 self.assertEqual(list(check_columns), expected_columns)
 | |
| 
 | |
| 
 | |
| @skipUnless(connection.vendor == "mysql", "MySQL tests")
 | |
| class StorageEngineTests(TestCase):
 | |
|     databases = {"default", "other"}
 | |
| 
 | |
|     def test_get_storage_engine(self):
 | |
|         table_name = "test_storage_engine"
 | |
|         create_sql = "CREATE TABLE %s (id INTEGER) ENGINE = %%s" % table_name
 | |
|         drop_sql = "DROP TABLE %s" % table_name
 | |
|         default_connection = connections["default"]
 | |
|         other_connection = connections["other"]
 | |
|         try:
 | |
|             with default_connection.cursor() as cursor:
 | |
|                 cursor.execute(create_sql % "InnoDB")
 | |
|                 self.assertEqual(
 | |
|                     default_connection.introspection.get_storage_engine(
 | |
|                         cursor, table_name
 | |
|                     ),
 | |
|                     "InnoDB",
 | |
|                 )
 | |
|             with other_connection.cursor() as cursor:
 | |
|                 cursor.execute(create_sql % "MyISAM")
 | |
|                 self.assertEqual(
 | |
|                     other_connection.introspection.get_storage_engine(
 | |
|                         cursor, table_name
 | |
|                     ),
 | |
|                     "MyISAM",
 | |
|                 )
 | |
|         finally:
 | |
|             with default_connection.cursor() as cursor:
 | |
|                 cursor.execute(drop_sql)
 | |
|             with other_connection.cursor() as cursor:
 | |
|                 cursor.execute(drop_sql)
 |