summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeil Schemenauer <nas-github@arctrix.com>2017-12-02 21:54:00 (GMT)
committerGitHub <noreply@github.com>2017-12-02 21:54:00 (GMT)
commit1eaa1169c522727b1911b798d45c8984992bd179 (patch)
treef09dbacdac2ac91adafceefe108bfab0079c2d8f
parent13badcbc60cdbfae1dba1683fd2fae9d70717143 (diff)
downloadcpython-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.py30
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()