]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/commitdiff
Test fixture improvements
authorMike Bayer <mike_mp@zzzcomputing.com>
Mon, 11 Nov 2019 19:57:08 +0000 (14:57 -0500)
committerMike Bayer <mike_mp@zzzcomputing.com>
Mon, 11 Nov 2019 19:58:12 +0000 (14:58 -0500)
- ensure we escape out percent signs when a CompiledSQL or RegexSQL
has percent signs in the SQL or in the parameter repr

- to support combinations, print out complete test name in skip
messages, py.test environment gives us a way to do this

Change-Id: Ia9e62f7c1026c1465986144c5757e35fc164a2b8
(cherry picked from commit 3cf0a1642eafe53e3c3b40b06cf105a32676a27f)

lib/sqlalchemy/testing/assertsql.py
lib/sqlalchemy/testing/config.py
lib/sqlalchemy/testing/exclusions.py
lib/sqlalchemy/testing/plugin/plugin_base.py
lib/sqlalchemy/testing/plugin/pytestplugin.py

index 00496d549025023625d6e6377630c7c050a72d83..63f7811d0ba7309f822a6f3e3fa96af8efd993c4 100644 (file)
@@ -183,10 +183,13 @@ class CompiledSQL(SQLMatchRule):
 
     def _failure_message(self, expected_params):
         return (
-            "Testing for compiled statement %r partial params %r, "
+            "Testing for compiled statement %r partial params %s, "
             "received %%(received_statement)r with params "
             "%%(received_parameters)r"
-            % (self.statement.replace("%", "%%"), expected_params)
+            % (
+                self.statement.replace("%", "%%"),
+                repr(expected_params).replace("%", "%%"),
+            )
         )
 
 
@@ -200,9 +203,13 @@ class RegexSQL(CompiledSQL):
 
     def _failure_message(self, expected_params):
         return (
-            "Testing for compiled statement ~%r partial params %r, "
+            "Testing for compiled statement ~%r partial params %s, "
             "received %%(received_statement)r with params "
-            "%%(received_parameters)r" % (self.orig_regex, expected_params)
+            "%%(received_parameters)r"
+            % (
+                self.orig_regex.replace("%", "%%"),
+                repr(expected_params).replace("%", "%%"),
+            )
         )
 
     def _compare_sql(self, execute_observed, received_statement):
index 8262142ec5a0c6a8df35ddf3a67a5fac6a17838d..ae84a7878cc7e42544f57fe2fe422cd4dc02f4f6 100644 (file)
@@ -89,6 +89,10 @@ def fixture(*arg, **kw):
     return _fixture_functions.fixture(*arg, **kw)
 
 
+def get_current_test_name():
+    return _fixture_functions.get_current_test_name()
+
+
 class Config(object):
     def __init__(self, db, db_opts, options, file_config):
         self._set_name(db)
index cf61091e3f10d868bb63cb5b5f4d40cdc38ce90e..f7420644022905c1b99d9fab7238d24a3a18144d 100644 (file)
@@ -141,7 +141,10 @@ class compound(object):
 
         for skip in self.skips:
             if self._check_combinations(combination, skip) and skip(cfg):
-                msg = "'%s' : %s" % (fn.__name__, skip._as_string(cfg))
+                msg = "'%s' : %s" % (
+                    config.get_current_test_name(),
+                    skip._as_string(cfg),
+                )
                 config.skip_test(msg)
 
         try:
index c5323921af5631a7abebec62bf45f404f8395da5..8afe69d3541bec14c2fceb4d1e1c01121153764f 100644 (file)
@@ -722,6 +722,9 @@ class FixtureFunctions(ABC):
     def fixture(self, *arg, **kw):
         raise NotImplementedError()
 
+    def get_current_test_name(self):
+        raise NotImplementedError()
+
 
 _fixture_fn_class = None
 
index 5cb6d1b4cdcb987765bfcbd431edf81179716dfd..dc83f1f51a19e6bd61f98ff13b4c56d388417b67 100644 (file)
@@ -414,3 +414,6 @@ class PytestFixtureFunctions(plugin_base.FixtureFunctions):
 
     def fixture(self, *arg, **kw):
         return pytest.fixture(*arg, **kw)
+
+    def get_current_test_name(self):
+        return os.environ.get("PYTEST_CURRENT_TEST")