mirror of https://github.com/python/cpython.git
Issue #3210: Ensure stdio handles are closed if CreateProcess fails
This commit is contained in:
parent
2e3d539ce2
commit
af5ac3974b
|
@ -544,6 +544,26 @@ def test_issue8780(self):
|
|||
output = subprocess.check_output([sys.executable, '-c', code])
|
||||
self.assert_(output.startswith(b'Hello World!'), ascii(output))
|
||||
|
||||
def test_handles_closed_on_exception(self):
|
||||
# If CreateProcess exits with an error, ensure the
|
||||
# duplicate output handles are released
|
||||
ifhandle, ifname = mkstemp()
|
||||
ofhandle, ofname = mkstemp()
|
||||
efhandle, efname = mkstemp()
|
||||
try:
|
||||
subprocess.Popen (["*"], stdin=ifhandle, stdout=ofhandle,
|
||||
stderr=efhandle)
|
||||
except OSError:
|
||||
os.close(ifhandle)
|
||||
os.remove(ifname)
|
||||
os.close(ofhandle)
|
||||
os.remove(ofname)
|
||||
os.close(efhandle)
|
||||
os.remove(efname)
|
||||
self.assertFalse(os.path.exists(ifname))
|
||||
self.assertFalse(os.path.exists(ofname))
|
||||
self.assertFalse(os.path.exists(efname))
|
||||
|
||||
|
||||
# context manager
|
||||
class _SuppressCoreFiles(object):
|
||||
|
|
|
@ -429,6 +429,7 @@ sp_CreateProcess(PyObject* self, PyObject* args)
|
|||
PyObject* env_mapping;
|
||||
Py_UNICODE* current_directory;
|
||||
PyObject* startup_info;
|
||||
DWORD error;
|
||||
|
||||
if (! PyArg_ParseTuple(args, "ZZOOiiOZO:CreateProcess",
|
||||
&application_name,
|
||||
|
@ -478,8 +479,22 @@ sp_CreateProcess(PyObject* self, PyObject* args)
|
|||
|
||||
Py_XDECREF(environment);
|
||||
|
||||
if (! result)
|
||||
return PyErr_SetFromWindowsErr(GetLastError());
|
||||
if (! result) {
|
||||
error = GetLastError();
|
||||
if(si.hStdInput != INVALID_HANDLE_VALUE) {
|
||||
CloseHandle(si.hStdInput);
|
||||
si.hStdInput = INVALID_HANDLE_VALUE;
|
||||
}
|
||||
if(si.hStdOutput != INVALID_HANDLE_VALUE) {
|
||||
CloseHandle(si.hStdOutput);
|
||||
si.hStdOutput = INVALID_HANDLE_VALUE;
|
||||
}
|
||||
if(si.hStdError != INVALID_HANDLE_VALUE) {
|
||||
CloseHandle(si.hStdError);
|
||||
si.hStdError = INVALID_HANDLE_VALUE;
|
||||
}
|
||||
return PyErr_SetFromWindowsErr(error);
|
||||
}
|
||||
|
||||
return Py_BuildValue("NNii",
|
||||
sp_handle_new(pi.hProcess),
|
||||
|
|
Loading…
Reference in New Issue