diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-10-23 10:53:04 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2019-10-24 10:13:27 -0400 |
| commit | f9000e2a38bc879a4964a4f396e87185d0d21cd2 (patch) | |
| tree | b6925ca5a92e5b9009288bdb048040af463dad8e /test/sql | |
| parent | d76cb7213557c24609a1a75d8c391aea0179562a (diff) | |
| download | sqlalchemy-f9000e2a38bc879a4964a4f396e87185d0d21cd2.tar.gz | |
Use default repr() for quoted_name under python 3
Changed the ``repr()`` of the :class:`.quoted_name` construct to use
regular string repr() under Python 3, rather than running it through
"backslashreplace" escaping, which can be misleading.
Modified the approach of "name normalization" for the Oracle and Firebird
dialects, which converts from the UPPERCASE-as-case-insensitive convention
of these dialects into lowercase-as-case-insensitive for SQLAlchemy, to not
automatically apply the :class:`.quoted_name` construct to a name that
matches itself under upper or lower case conversion, as is the case for
many non-european characters. All names used within metadata structures
are converted to :class:`.quoted_name` objects in any case; the change
here would only affect the output of some inspection functions.
Moved name normalize to be under default dialect, added test coverage
in test/sql/test_quote.py
Fixes: #4931
Change-Id: Ic121b20e07249824710a54423e321d94a425362f
Diffstat (limited to 'test/sql')
| -rw-r--r-- | test/sql/test_quote.py | 49 | ||||
| -rw-r--r-- | test/sql/test_unicode.py | 32 |
2 files changed, 70 insertions, 11 deletions
diff --git a/test/sql/test_quote.py b/test/sql/test_quote.py index d7219b12d..aba6a0204 100644 --- a/test/sql/test_quote.py +++ b/test/sql/test_quote.py @@ -1,3 +1,5 @@ +#!coding: utf-8 + from sqlalchemy import CheckConstraint from sqlalchemy import Column from sqlalchemy import column @@ -11,6 +13,7 @@ from sqlalchemy import select from sqlalchemy import sql from sqlalchemy import Table from sqlalchemy import testing +from sqlalchemy import util from sqlalchemy.engine import default from sqlalchemy.sql import compiler from sqlalchemy.sql.elements import _anonymous_label @@ -18,6 +21,7 @@ from sqlalchemy.sql.elements import quoted_name from sqlalchemy.testing import AssertsCompiledSQL from sqlalchemy.testing import eq_ from sqlalchemy.testing import fixtures +from sqlalchemy.testing import is_ from sqlalchemy.testing.util import picklers @@ -250,6 +254,14 @@ class QuoteTest(fixtures.TestBase, AssertsCompiledSQL): ') AS "LaLa"', ) + def test_repr_unicode(self): + name = quoted_name(u"姓名", None) + + if util.py2k: + eq_(repr(name), "'\u59d3\u540d'") + else: + eq_(repr(name), repr(u"姓名")) + def test_lower_case_names(self): # Create table with quote defaults metadata = MetaData() @@ -988,3 +1000,40 @@ class QuotedIdentTest(fixtures.TestBase): def _assert_not_quoted(self, value): assert not isinstance(value, quoted_name) + + +class NameNormalizeTest(fixtures.TestBase): + dialect = default.DefaultDialect() + + @testing.combinations( + ("NAME", "name", False), + ("NA ME", "NA ME", False), + ("NaMe", "NaMe", False), + (u"姓名", u"姓名", False), + ("name", "name", True), # an all-lower case name needs quote forced + ) + def test_name_normalize(self, original, normalized, is_quote): + orig_norm = self.dialect.normalize_name(original) + + eq_(orig_norm, normalized) + if is_quote: + is_(orig_norm.quote, True) + else: + assert not isinstance(orig_norm, quoted_name) + + @testing.combinations( + ("name", "NAME", False), + ("NA ME", "NA ME", False), + ("NaMe", "NaMe", False), + (u"姓名", u"姓名", False), + (quoted_name("name", quote=True), "name", True), + ) + def test_name_denormalize(self, original, denormalized, is_quote): + orig_denorm = self.dialect.denormalize_name(original) + + eq_(orig_denorm, denormalized) + + if is_quote: + is_(orig_denorm.quote, True) + else: + assert not isinstance(orig_denorm, quoted_name) diff --git a/test/sql/test_unicode.py b/test/sql/test_unicode.py index 5b51644e6..dd7cad6b2 100644 --- a/test/sql/test_unicode.py +++ b/test/sql/test_unicode.py @@ -6,6 +6,7 @@ from sqlalchemy import ForeignKey from sqlalchemy import Integer from sqlalchemy import MetaData from sqlalchemy import testing +from sqlalchemy import util from sqlalchemy.testing import engines from sqlalchemy.testing import eq_ from sqlalchemy.testing import fixtures @@ -190,14 +191,23 @@ class UnicodeSchemaTest(fixtures.TestBase): ue("\u6e2c\u8a66"), m, Column(ue("\u6e2c\u8a66_id"), Integer) ) - # I hardly understand what's going on with the backslashes in - # this one on py2k vs. py3k - eq_( - repr(t), - ( - "Table('\\u6e2c\\u8a66', MetaData(bind=None), " - "Column('\\u6e2c\\u8a66_id', Integer(), " - "table=<\u6e2c\u8a66>), " - "schema=None)" - ), - ) + if util.py2k: + eq_( + repr(t), + ( + "Table('\\u6e2c\\u8a66', MetaData(bind=None), " + "Column('\\u6e2c\\u8a66_id', Integer(), " + "table=<\u6e2c\u8a66>), " + "schema=None)" + ), + ) + else: + eq_( + repr(t), + ( + "Table('測試', MetaData(bind=None), " + "Column('測試_id', Integer(), " + "table=<測試>), " + "schema=None)" + ), + ) |
