2018-03-18 04:00:58 +08:00
|
|
|
import unittest
|
|
|
|
|
|
|
|
from django.db import connection
|
|
|
|
from django.test import TestCase
|
|
|
|
|
|
|
|
|
|
|
|
@unittest.skipUnless(connection.vendor == 'mysql', 'MySQL tests')
|
|
|
|
class SchemaEditorTests(TestCase):
|
|
|
|
def test_quote_value(self):
|
2018-12-06 02:47:40 +08:00
|
|
|
import MySQLdb
|
2018-03-18 04:00:58 +08:00
|
|
|
editor = connection.schema_editor()
|
|
|
|
tested_values = [
|
2018-02-09 23:04:00 +08:00
|
|
|
('string', "'string'"),
|
2021-03-27 19:01:49 +08:00
|
|
|
('¿Tú hablas inglés?', "'¿Tú hablas inglés?'"),
|
2021-03-29 16:10:19 +08:00
|
|
|
(b'bytes', b"'bytes'"),
|
2018-03-18 04:00:58 +08:00
|
|
|
(42, '42'),
|
2018-12-06 02:47:40 +08:00
|
|
|
(1.754, '1.754e0' if MySQLdb.version_info >= (1, 3, 14) else '1.754'),
|
2019-01-19 20:31:15 +08:00
|
|
|
(False, b'0' if MySQLdb.version_info >= (1, 4, 0) else '0'),
|
2018-03-18 04:00:58 +08:00
|
|
|
]
|
|
|
|
for value, expected in tested_values:
|
|
|
|
with self.subTest(value=value):
|
|
|
|
self.assertEqual(editor.quote_value(value), expected)
|