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