diff options
author | Neil Schemenauer <nas-github@arctrix.com> | 2017-12-02 21:54:00 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-12-02 21:54:00 (GMT) |
commit | 1eaa1169c522727b1911b798d45c8984992bd179 (patch) | |
tree | f09dbacdac2ac91adafceefe108bfab0079c2d8f | |
parent | 13badcbc60cdbfae1dba1683fd2fae9d70717143 (diff) | |
download | cpython-1eaa1169c522727b1911b798d45c8984992bd179.zip cpython-1eaa1169c522727b1911b798d45c8984992bd179.tar.gz cpython-1eaa1169c522727b1911b798d45c8984992bd179.tar.bz2 |
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.
-rw-r--r-- | Lib/test/test_frozen.py | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/Lib/test/test_frozen.py b/Lib/test/test_frozen.py new file mode 100644 index 0000000..a7c7484 --- /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() |