From: Nikita Sobolev Date: Wed, 3 Nov 2021 13:55:42 +0000 (+0300) Subject: bpo-45578: add tests for `dis.distb` (GH-29332) X-Git-Tag: v3.11.0a2~19 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=e346f196819aeb02a8a94205ce3e1536c4c2f105;p=thirdparty%2FPython%2Fcpython.git bpo-45578: add tests for `dis.distb` (GH-29332) --- diff --git a/Lib/test/test_dis.py b/Lib/test/test_dis.py index 4755e3f3a172..2a0e3b4e8498 100644 --- a/Lib/test/test_dis.py +++ b/Lib/test/test_dis.py @@ -1359,5 +1359,45 @@ class TestFinderMethods(unittest.TestCase): self.assertEqual(res, expected) +class TestDisTraceback(unittest.TestCase): + def setUp(self) -> None: + try: # We need to clean up existing tracebacks + del sys.last_traceback + except AttributeError: + pass + return super().setUp() + + def get_disassembly(self, tb): + output = io.StringIO() + with contextlib.redirect_stdout(output): + dis.distb(tb) + return output.getvalue() + + def test_distb_empty(self): + with self.assertRaises(RuntimeError): + dis.distb() + + def test_distb_last_traceback(self): + # We need to have an existing last traceback in `sys`: + tb = get_tb() + sys.last_traceback = tb + + self.assertEqual(self.get_disassembly(None), dis_traceback) + + def test_distb_explicit_arg(self): + tb = get_tb() + + self.assertEqual(self.get_disassembly(tb), dis_traceback) + + +class TestDisTracebackWithFile(TestDisTraceback): + # Run the `distb` tests again, using the file arg instead of print + def get_disassembly(self, tb): + output = io.StringIO() + with contextlib.redirect_stdout(output): + dis.distb(tb, file=output) + return output.getvalue() + + if __name__ == "__main__": unittest.main() diff --git a/Misc/NEWS.d/next/Tests/2021-10-30-19-00-25.bpo-45578.bvu6X2.rst b/Misc/NEWS.d/next/Tests/2021-10-30-19-00-25.bpo-45578.bvu6X2.rst new file mode 100644 index 000000000000..3d0e0ca3f04a --- /dev/null +++ b/Misc/NEWS.d/next/Tests/2021-10-30-19-00-25.bpo-45578.bvu6X2.rst @@ -0,0 +1 @@ +Add tests for :func:`dis.distb`