summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorColin Watson <cjwatson@canonical.com>2022-04-23 22:53:48 +0100
committerJelmer Vernooij <jelmer@jelmer.uk>2022-07-01 19:32:38 +0100
commit13bf5fd3d94539f907fc0c72dfff75c3b1c87f74 (patch)
treebd767dc2ea9fbb05484ddc4098b543b691a0f414
parentdbada1efac5c89c996b2b1536f4b0c5fb227d000 (diff)
downloadtesttools-13bf5fd3d94539f907fc0c72dfff75c3b1c87f74.tar.gz
Fix various test failures with Python 3.11
The changes for https://peps.python.org/pep-0657/ require a number of changes in our tests. Some tests still fail due to https://twistedmatrix.com/trac/ticket/10336, so I'm not adding 3.11 to the test matrix yet. Fixes #325.
-rw-r--r--testtools/tests/test_run.py4
-rw-r--r--testtools/tests/test_testresult.py23
-rw-r--r--testtools/tests/test_testsuite.py2
3 files changed, 16 insertions, 13 deletions
diff --git a/testtools/tests/test_run.py b/testtools/tests/test_run.py
index ee96eec..9808421 100644
--- a/testtools/tests/test_run.py
+++ b/testtools/tests/test_run.py
@@ -202,9 +202,9 @@ unittest.loader._FailedTest.runexample
Failed to import test module: runexample
Traceback (most recent call last):
File ".../loader.py", line ..., in _find_test_path
- package = self._get_module_from_name(name)
+ package = self._get_module_from_name(name)...
File ".../loader.py", line ..., in _get_module_from_name
- __import__(name)
+ __import__(name)...
File ".../runexample/__init__.py", line 1
class not in
...^...
diff --git a/testtools/tests/test_testresult.py b/testtools/tests/test_testresult.py
index 72ffb0a..d419f02 100644
--- a/testtools/tests/test_testresult.py
+++ b/testtools/tests/test_testresult.py
@@ -1265,11 +1265,11 @@ class TestTestResult(TestCase):
DocTestMatches(
'Traceback (most recent call last):\n'
' File "...testtools...runtest.py", line ..., in _run_user\n'
- ' return fn(*args, **kwargs)\n'
+ ' return fn(*args, **kwargs)\n...'
' File "...testtools...testcase.py", line ..., in _run_test_method\n'
- ' return self._get_test_method()()\n'
+ ' return self._get_test_method()()\n...'
' File "...testtools...tests...test_testresult.py", line ..., in error\n'
- ' 1/0\n'
+ ' 1/0\n...'
'ZeroDivisionError: ...\n',
doctest.ELLIPSIS | doctest.REPORT_UDIFF))
@@ -1282,7 +1282,7 @@ class TestTestResult(TestCase):
DocTestMatches(
'Traceback (most recent call last):\n'
' File "...testtools...tests...test_testresult.py", line ..., in error\n'
- ' 1/0\n'
+ ' 1/0\n...'
'ZeroDivisionError: ...\n',
doctest.ELLIPSIS))
@@ -1321,17 +1321,17 @@ class TestTestResult(TestCase):
DocTestMatches(
'Traceback (most recent call last):\n'
' File "...testtools...runtest.py", line ..., in _run_user\n'
- ' return fn(*args, **kwargs)\n'
+ ' return fn(*args, **kwargs)\n...'
' args = ...\n'
' fn = ...\n'
' kwargs = ...\n'
' self = ...\n'
' File "...testtools...testcase.py", line ..., in _run_test_method\n'
- ' return self._get_test_method()()\n'
+ ' return self._get_test_method()()\n...'
' result = ...\n'
' self = ...\n'
' File "...testtools...tests...test_testresult.py", line ..., in error\n'
- ' 1/0\n'
+ ' 1/0\n...'
' a = 1\n'
' self = ...\n'
'ZeroDivisionError: ...\n',
@@ -2644,12 +2644,15 @@ class TestNonAsciiResults(TestCase):
" raise RuntimeError\n"
" def __repr__(self):\n"
" raise RuntimeError\n")
+ if sys.version_info >= (3, 11):
+ expected = "UnprintableError: <exception str() failed>\n"
+ else:
+ expected = (
+ "UnprintableError: <unprintable UnprintableError object>\n")
textoutput = self._test_external_case(
modulelevel=exception_class,
testline="raise UnprintableError")
- self.assertIn(self._as_output(
- "UnprintableError: <unprintable UnprintableError object>\n"),
- textoutput)
+ self.assertIn(self._as_output(expected), textoutput)
def test_non_ascii_dirname(self):
"""Script paths in the traceback can be non-ascii"""
diff --git a/testtools/tests/test_testsuite.py b/testtools/tests/test_testsuite.py
index 358ac3a..26d2152 100644
--- a/testtools/tests/test_testsuite.py
+++ b/testtools/tests/test_testsuite.py
@@ -178,7 +178,7 @@ class TestConcurrentStreamTestSuiteRun(TestCase):
"Traceback (most recent call last):\n")
self.assertThat(events[2][6].decode('utf8'), DocTestMatches("""\
File "...testtools/testsuite.py", line ..., in _run_test
- test.run(process_result)
+ test.run(process_result)...
""", doctest.ELLIPSIS))
self.assertThat(events[3][6].decode('utf8'), DocTestMatches("""\
TypeError: ...run() takes ...1 ...argument...2...given...