Commit ea75187c authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-34783: Fix test_nonexisting_script() (GH-9896)

Fix test_cmd_line_script.test_nonexisting_script(): the test must not
rely on sys.executable, since main.c uses config->program which can
be different than sys.executable in many cases (for example, on macOS
when using the framework).
parent 43a5bd7b
...@@ -630,8 +630,6 @@ class CmdLineTest(unittest.TestCase): ...@@ -630,8 +630,6 @@ class CmdLineTest(unittest.TestCase):
traceback_lines = stderr.decode().splitlines() traceback_lines = stderr.decode().splitlines()
self.assertIn("No module named script_pkg", traceback_lines[-1]) self.assertIn("No module named script_pkg", traceback_lines[-1])
@unittest.skipIf(sys.platform == 'darwin' and sys._framework,
"test not valid for macOS framework builds")
def test_nonexisting_script(self): def test_nonexisting_script(self):
# bpo-34783: "./python script.py" must not crash # bpo-34783: "./python script.py" must not crash
# if the script file doesn't exist. # if the script file doesn't exist.
...@@ -639,17 +637,12 @@ class CmdLineTest(unittest.TestCase): ...@@ -639,17 +637,12 @@ class CmdLineTest(unittest.TestCase):
# is not the actual Python executable file name. # is not the actual Python executable file name.
script = 'nonexistingscript.py' script = 'nonexistingscript.py'
self.assertFalse(os.path.exists(script)) self.assertFalse(os.path.exists(script))
# Only test the base name, since the error message can use
# a relative path, whereas sys.executable can be an asolution path.
program = os.path.basename(sys.executable)
proc = spawn_python(script, text=True, proc = spawn_python(script, text=True,
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
stderr=subprocess.PIPE) stderr=subprocess.PIPE)
out, err = proc.communicate() out, err = proc.communicate()
# "./python" must be in the error message: self.assertIn(": can't open file ", err)
# "./python: can't open file (...)"
self.assertIn(program, err)
self.assertNotEqual(proc.returncode, 0) self.assertNotEqual(proc.returncode, 0)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment