mirror of
https://github.com/AdaCore/cpython.git
synced 2026-02-12 12:57:15 -08:00
bpo-34530: Fix distutils find_executable() (GH-9049) (GH-9058)
distutils.spawn.find_executable() now falls back on os.defpath if the
PATH environment variable is not set.
(cherry picked from commit 39487196c8)
This commit is contained in:
@@ -208,7 +208,8 @@ def find_executable(executable, path=None):
|
||||
os.environ['PATH']. Returns the complete filename or None if not found.
|
||||
"""
|
||||
if path is None:
|
||||
path = os.environ['PATH']
|
||||
path = os.environ.get('PATH', os.defpath)
|
||||
|
||||
paths = path.split(os.pathsep)
|
||||
base, ext = os.path.splitext(executable)
|
||||
|
||||
|
||||
@@ -1,8 +1,11 @@
|
||||
"""Tests for distutils.spawn."""
|
||||
import unittest
|
||||
import os
|
||||
import stat
|
||||
import sys
|
||||
import time
|
||||
from test.test_support import captured_stdout, run_unittest
|
||||
import unittest
|
||||
from test.support import captured_stdout, run_unittest
|
||||
from test import support as test_support
|
||||
|
||||
from distutils.spawn import _nt_quote_args
|
||||
from distutils.spawn import spawn, find_executable
|
||||
@@ -53,6 +56,48 @@ class SpawnTestCase(support.TempdirManager,
|
||||
os.chmod(exe, 0777)
|
||||
spawn([exe]) # should work without any error
|
||||
|
||||
def test_find_executable(self):
|
||||
with test_support.temp_dir() as tmp_dir:
|
||||
# use TESTFN to get a pseudo-unique filename
|
||||
program_noeext = test_support.TESTFN
|
||||
# Give the temporary program an ".exe" suffix for all.
|
||||
# It's needed on Windows and not harmful on other platforms.
|
||||
program = program_noeext + ".exe"
|
||||
|
||||
filename = os.path.join(tmp_dir, program)
|
||||
with open(filename, "wb"):
|
||||
pass
|
||||
os.chmod(filename, stat.S_IXUSR)
|
||||
|
||||
# test path parameter
|
||||
rv = find_executable(program, path=tmp_dir)
|
||||
self.assertEqual(rv, filename)
|
||||
|
||||
if sys.platform == 'win32':
|
||||
# test without ".exe" extension
|
||||
rv = find_executable(program_noeext, path=tmp_dir)
|
||||
self.assertEqual(rv, filename)
|
||||
|
||||
# test find in the current directory
|
||||
with test_support.change_cwd(tmp_dir):
|
||||
rv = find_executable(program)
|
||||
self.assertEqual(rv, program)
|
||||
|
||||
# test non-existent program
|
||||
dont_exist_program = "dontexist_" + program
|
||||
rv = find_executable(dont_exist_program , path=tmp_dir)
|
||||
self.assertIsNone(rv)
|
||||
|
||||
# test os.defpath: missing PATH environment variable
|
||||
with test_support.EnvironmentVarGuard() as env:
|
||||
from distutils import spawn
|
||||
with test_support.swap_attr(spawn.os, 'defpath', tmp_dir):
|
||||
env.pop('PATH')
|
||||
|
||||
rv = find_executable(program)
|
||||
self.assertEqual(rv, filename)
|
||||
|
||||
|
||||
def test_suite():
|
||||
return unittest.makeSuite(SpawnTestCase)
|
||||
|
||||
|
||||
@@ -0,0 +1,2 @@
|
||||
``distutils.spawn.find_executable()`` now falls back on :data:`os.defpath`
|
||||
if the ``PATH`` environment variable is not set.
|
||||
Reference in New Issue
Block a user