summaryrefslogtreecommitdiffstats
path: root/Lib/test
diff options
context:
space:
mode:
authorVictor Stinner <vstinner@python.org>2022-10-11 08:07:57 (GMT)
committerGitHub <noreply@github.com>2022-10-11 08:07:57 (GMT)
commite0ae9ddffe0a708d0d3f5b8cc10488d466fc43c4 (patch)
treebc97c042724b8c89a29d36f81b1f804070622784 /Lib/test
parentb399115ef18945f7526492225d72a512048ad20d (diff)
downloadcpython-e0ae9ddffe0a708d0d3f5b8cc10488d466fc43c4.zip
cpython-e0ae9ddffe0a708d0d3f5b8cc10488d466fc43c4.tar.gz
cpython-e0ae9ddffe0a708d0d3f5b8cc10488d466fc43c4.tar.bz2
gh-97669: Remove outdated example scripts (#97675) (#98167)
Remove outdated example scripts of the Tools/scripts/ directory: * gprof2html.py * md5sum.py * nm2def.py * pathfix.py * win_add2path.py Remove test_gprof2html, test_md5sum and test_pathfix of test_tools.
Diffstat (limited to 'Lib/test')
-rw-r--r--Lib/test/test_tools/test_gprof2html.py35
-rw-r--r--Lib/test/test_tools/test_md5sum.py78
-rw-r--r--Lib/test/test_tools/test_pathfix.py131
-rw-r--r--Lib/test/test_tools/test_sundry.py11
4 files changed, 2 insertions, 253 deletions
diff --git a/Lib/test/test_tools/test_gprof2html.py b/Lib/test/test_tools/test_gprof2html.py
deleted file mode 100644
index 7cceb8f..0000000
--- a/Lib/test/test_tools/test_gprof2html.py
+++ /dev/null
@@ -1,35 +0,0 @@
-"""Tests for the gprof2html script in the Tools directory."""
-
-import os
-import sys
-import unittest
-from unittest import mock
-import tempfile
-
-from test.test_tools import skip_if_missing, import_tool
-
-skip_if_missing()
-
-class Gprof2htmlTests(unittest.TestCase):
-
- def setUp(self):
- self.gprof = import_tool('gprof2html')
- oldargv = sys.argv
- def fixup():
- sys.argv = oldargv
- self.addCleanup(fixup)
- sys.argv = []
-
- def test_gprof(self):
- # Issue #14508: this used to fail with a NameError.
- with mock.patch.object(self.gprof, 'webbrowser') as wmock, \
- tempfile.TemporaryDirectory() as tmpdir:
- fn = os.path.join(tmpdir, 'abc')
- open(fn, 'wb').close()
- sys.argv = ['gprof2html', fn]
- self.gprof.main()
- self.assertTrue(wmock.open.called)
-
-
-if __name__ == '__main__':
- unittest.main()
diff --git a/Lib/test/test_tools/test_md5sum.py b/Lib/test/test_tools/test_md5sum.py
deleted file mode 100644
index 710461f..0000000
--- a/Lib/test/test_tools/test_md5sum.py
+++ /dev/null
@@ -1,78 +0,0 @@
-"""Tests for the md5sum script in the Tools directory."""
-
-import os
-import unittest
-from test.support import os_helper
-from test.support import hashlib_helper
-from test.support.script_helper import assert_python_ok, assert_python_failure
-
-from test.test_tools import scriptsdir, skip_if_missing
-
-skip_if_missing()
-
-@hashlib_helper.requires_hashdigest('md5', openssl=True)
-class MD5SumTests(unittest.TestCase):
- @classmethod
- def setUpClass(cls):
- cls.script = os.path.join(scriptsdir, 'md5sum.py')
- os.mkdir(os_helper.TESTFN_ASCII)
- cls.fodder = os.path.join(os_helper.TESTFN_ASCII, 'md5sum.fodder')
- with open(cls.fodder, 'wb') as f:
- f.write(b'md5sum\r\ntest file\r\n')
- cls.fodder_md5 = b'd38dae2eb1ab346a292ef6850f9e1a0d'
- cls.fodder_textmode_md5 = b'a8b07894e2ca3f2a4c3094065fa6e0a5'
-
- @classmethod
- def tearDownClass(cls):
- os_helper.rmtree(os_helper.TESTFN_ASCII)
-
- def test_noargs(self):
- rc, out, err = assert_python_ok(self.script)
- self.assertEqual(rc, 0)
- self.assertTrue(
- out.startswith(b'd41d8cd98f00b204e9800998ecf8427e <stdin>'))
- self.assertFalse(err)
-
- def test_checksum_fodder(self):
- rc, out, err = assert_python_ok(self.script, self.fodder)
- self.assertEqual(rc, 0)
- self.assertTrue(out.startswith(self.fodder_md5))
- for part in self.fodder.split(os.path.sep):
- self.assertIn(part.encode(), out)
- self.assertFalse(err)
-
- def test_dash_l(self):
- rc, out, err = assert_python_ok(self.script, '-l', self.fodder)
- self.assertEqual(rc, 0)
- self.assertIn(self.fodder_md5, out)
- parts = self.fodder.split(os.path.sep)
- self.assertIn(parts[-1].encode(), out)
- self.assertNotIn(parts[-2].encode(), out)
-
- def test_dash_t(self):
- rc, out, err = assert_python_ok(self.script, '-t', self.fodder)
- self.assertEqual(rc, 0)
- self.assertTrue(out.startswith(self.fodder_textmode_md5))
- self.assertNotIn(self.fodder_md5, out)
-
- def test_dash_s(self):
- rc, out, err = assert_python_ok(self.script, '-s', '512', self.fodder)
- self.assertEqual(rc, 0)
- self.assertIn(self.fodder_md5, out)
-
- def test_multiple_files(self):
- rc, out, err = assert_python_ok(self.script, self.fodder, self.fodder)
- self.assertEqual(rc, 0)
- lines = out.splitlines()
- self.assertEqual(len(lines), 2)
- self.assertEqual(*lines)
-
- def test_usage(self):
- rc, out, err = assert_python_failure(self.script, '-h')
- self.assertEqual(rc, 2)
- self.assertEqual(out, b'')
- self.assertGreater(err, b'')
-
-
-if __name__ == '__main__':
- unittest.main()
diff --git a/Lib/test/test_tools/test_pathfix.py b/Lib/test/test_tools/test_pathfix.py
deleted file mode 100644
index aa754bc..0000000
--- a/Lib/test/test_tools/test_pathfix.py
+++ /dev/null
@@ -1,131 +0,0 @@
-import os
-import subprocess
-import sys
-import unittest
-from test.support import os_helper
-from test.test_tools import scriptsdir, skip_if_missing
-
-
-# need Tools/script/ directory: skip if run on Python installed on the system
-skip_if_missing()
-
-
-class TestPathfixFunctional(unittest.TestCase):
- script = os.path.join(scriptsdir, 'pathfix.py')
-
- def setUp(self):
- self.addCleanup(os_helper.unlink, os_helper.TESTFN)
-
- def pathfix(self, shebang, pathfix_flags, exitcode=0, stdout='', stderr='',
- directory=''):
- if directory:
- # bpo-38347: Test filename should contain lowercase, uppercase,
- # "-", "_" and digits.
- filename = os.path.join(directory, 'script-A_1.py')
- pathfix_arg = directory
- else:
- filename = os_helper.TESTFN
- pathfix_arg = filename
-
- with open(filename, 'w', encoding='utf8') as f:
- f.write(f'{shebang}\n' + 'print("Hello world")\n')
-
- encoding = sys.getfilesystemencoding()
- proc = subprocess.run(
- [sys.executable, self.script,
- *pathfix_flags, '-n', pathfix_arg],
- env={**os.environ, 'PYTHONIOENCODING': encoding},
- capture_output=True)
-
- if stdout == '' and proc.returncode == 0:
- stdout = f'{filename}: updating\n'
- self.assertEqual(proc.returncode, exitcode, proc)
- self.assertEqual(proc.stdout.decode(encoding), stdout.replace('\n', os.linesep), proc)
- self.assertEqual(proc.stderr.decode(encoding), stderr.replace('\n', os.linesep), proc)
-
- with open(filename, 'r', encoding='utf8') as f:
- output = f.read()
-
- lines = output.split('\n')
- self.assertEqual(lines[1:], ['print("Hello world")', ''])
- new_shebang = lines[0]
-
- if proc.returncode != 0:
- self.assertEqual(shebang, new_shebang)
-
- return new_shebang
-
- def test_recursive(self):
- tmpdir = os_helper.TESTFN + '.d'
- self.addCleanup(os_helper.rmtree, tmpdir)
- os.mkdir(tmpdir)
- expected_stderr = f"recursedown('{os.path.basename(tmpdir)}')\n"
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python',
- ['-i', '/usr/bin/python3'],
- directory=tmpdir,
- stderr=expected_stderr),
- '#! /usr/bin/python3')
-
- def test_pathfix(self):
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python',
- ['-i', '/usr/bin/python3']),
- '#! /usr/bin/python3')
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python -R',
- ['-i', '/usr/bin/python3']),
- '#! /usr/bin/python3')
-
- def test_pathfix_keeping_flags(self):
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python -R',
- ['-i', '/usr/bin/python3', '-k']),
- '#! /usr/bin/python3 -R')
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python',
- ['-i', '/usr/bin/python3', '-k']),
- '#! /usr/bin/python3')
-
- def test_pathfix_adding_flag(self):
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python',
- ['-i', '/usr/bin/python3', '-a', 's']),
- '#! /usr/bin/python3 -s')
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python -S',
- ['-i', '/usr/bin/python3', '-a', 's']),
- '#! /usr/bin/python3 -s')
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python -V',
- ['-i', '/usr/bin/python3', '-a', 'v', '-k']),
- '#! /usr/bin/python3 -vV')
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python',
- ['-i', '/usr/bin/python3', '-a', 'Rs']),
- '#! /usr/bin/python3 -Rs')
- self.assertEqual(
- self.pathfix(
- '#! /usr/bin/env python -W default',
- ['-i', '/usr/bin/python3', '-a', 's', '-k']),
- '#! /usr/bin/python3 -sW default')
-
- def test_pathfix_adding_errors(self):
- self.pathfix(
- '#! /usr/bin/env python -E',
- ['-i', '/usr/bin/python3', '-a', 'W default', '-k'],
- exitcode=2,
- stderr="-a option doesn't support whitespaces")
-
-
-if __name__ == '__main__':
- unittest.main()
diff --git a/Lib/test/test_tools/test_sundry.py b/Lib/test/test_tools/test_sundry.py
index ed03c2f..04e38ac 100644
--- a/Lib/test/test_tools/test_sundry.py
+++ b/Lib/test/test_tools/test_sundry.py
@@ -19,15 +19,13 @@ class TestSundryScripts(unittest.TestCase):
# added for a script it should be added to the allowlist below.
# scripts that have independent tests.
- allowlist = ['reindent', 'pdeps', 'gprof2html', 'md5sum']
+ allowlist = ['reindent']
# scripts that can't be imported without running
denylist = ['make_ctype']
- # scripts that use windows-only modules
- windows_only = ['win_add2path']
# denylisted for other reasons
other = ['2to3']
- skiplist = denylist + allowlist + windows_only + other
+ skiplist = denylist + allowlist + other
def test_sundry(self):
old_modules = import_helper.modules_setup()
@@ -45,11 +43,6 @@ class TestSundryScripts(unittest.TestCase):
# Unload all modules loaded in this test
import_helper.modules_cleanup(*old_modules)
- @unittest.skipIf(sys.platform != "win32", "Windows-only test")
- def test_sundry_windows(self):
- for name in self.windows_only:
- import_tool(name)
-
if __name__ == '__main__':
unittest.main()