diff options
author | Eric Snow <ericsnowcurrently@gmail.com> | 2021-10-28 16:14:37 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-10-28 16:14:37 (GMT) |
commit | 13d9205f4057eeeef80a25d410ad123876dc60cd (patch) | |
tree | 18cbd8603e3f3a29d9f40a0bd8a4648356c205c9 /Lib/test/test_tools | |
parent | 7f61d9d84843e3445f62eb00c47902f0daa30a72 (diff) | |
download | cpython-13d9205f4057eeeef80a25d410ad123876dc60cd.zip cpython-13d9205f4057eeeef80a25d410ad123876dc60cd.tar.gz cpython-13d9205f4057eeeef80a25d410ad123876dc60cd.tar.bz2 |
bpo-45629: Add a test for the "freeze" tool. (gh-29222)
The "freeze" tool has been part of the repo for a long time. However, it hasn't had any tests in the test suite to guard against regressions. We add such a test here. This is especially important as there has been a lot of change recently related to frozen modules, with more to come.
Note that as part of the test we build Python out-of-tree and install it in a temp dir.
https://bugs.python.org/issue45629
Diffstat (limited to 'Lib/test/test_tools')
-rw-r--r-- | Lib/test/test_tools/test_freeze.py | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/Lib/test/test_tools/test_freeze.py b/Lib/test/test_tools/test_freeze.py new file mode 100644 index 0000000..392a776 --- /dev/null +++ b/Lib/test/test_tools/test_freeze.py @@ -0,0 +1,29 @@ +"""Sanity-check tests for the "freeze" tool.""" + +import sys +import textwrap +import unittest + +from test import support + +from . import imports_under_tool, skip_if_missing +skip_if_missing('freeze') +with imports_under_tool('freeze', 'test'): + import freeze as helper + + +@unittest.skipIf(sys.platform.startswith('win'), 'not supported on Windows') +@support.skip_if_buildbot('not all buildbots have enough space') +class TestFreeze(unittest.TestCase): + + def test_freeze_simple_script(self): + script = textwrap.dedent(""" + import sys + print('running...') + sys.exit(0) + """) + outdir, scriptfile, python = helper.prepare(script) + + executable = helper.freeze(python, scriptfile, outdir) + text = helper.run(executable) + self.assertEqual(text, 'running...') |