From: Neil Schemenauer Date: Sat, 2 Dec 2017 21:54:00 +0000 (-0800) Subject: Add a minimal unit test for Python/frozen.c. (#2995) X-Git-Tag: v3.7.0a3~24 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=1eaa1169c522727b1911b798d45c8984992bd179;p=thirdparty%2FPython%2Fcpython.git Add a minimal unit test for Python/frozen.c. (#2995) If the marshal or bytecode formats get changed, frozen.c needs to be updated as well. It can be easy to miss this step and not doing so can cause test_importlib to crash in mysterious ways. Add an explict unit test to make it easier to track down the problem. --- diff --git a/Lib/test/test_frozen.py b/Lib/test/test_frozen.py new file mode 100644 index 000000000000..a7c748422b1d --- /dev/null +++ b/Lib/test/test_frozen.py @@ -0,0 +1,30 @@ +"""Basic test of the frozen module (source is in Python/frozen.c).""" + +# The Python/frozen.c source code contains a marshalled Python module +# and therefore depends on the marshal format as well as the bytecode +# format. If those formats have been changed then frozen.c needs to be +# updated. +# +# The test_importlib also tests this module but because those tests +# are much more complicated, it might be unclear why they are failing. +# Invalid marshalled data in frozen.c could case the interpreter to +# crash when __hello__ is imported. + +import sys +import unittest +from test.support import captured_stdout +from importlib import util + + +class TestFrozen(unittest.TestCase): + def test_frozen(self): + name = '__hello__' + if name in sys.modules: + del sys.modules[name] + with captured_stdout() as out: + import __hello__ + self.assertEqual(out.getvalue(), 'Hello world!\n') + + +if __name__ == '__main__': + unittest.main()