mirror of https://github.com/python/cpython
SF bug #887946, segfault if redirecting directory
Also provide a warning if a directory is passed on the command line. Add minimal command line test. Will backport.
This commit is contained in:
parent
d157b1d237
commit
11bd119226
|
@ -0,0 +1,50 @@
|
||||||
|
|
||||||
|
import test.test_support, unittest
|
||||||
|
import sys
|
||||||
|
import popen2
|
||||||
|
|
||||||
|
class CmdLineTest(unittest.TestCase):
|
||||||
|
def start_python(self, cmd_line):
|
||||||
|
outfp, infp = popen2.popen4('%s %s' % (sys.executable, cmd_line))
|
||||||
|
infp.close()
|
||||||
|
data = outfp.read()
|
||||||
|
outfp.close()
|
||||||
|
return data
|
||||||
|
|
||||||
|
def test_directories(self):
|
||||||
|
self.assertTrue('is a directory' in self.start_python('.'))
|
||||||
|
self.assertTrue('is a directory' in self.start_python('< .'))
|
||||||
|
|
||||||
|
def verify_valid_flag(self, cmd_line):
|
||||||
|
data = self.start_python(cmd_line)
|
||||||
|
self.assertTrue(data.endswith('\n'))
|
||||||
|
self.assertTrue('Traceback' not in data)
|
||||||
|
|
||||||
|
def test_environment(self):
|
||||||
|
self.verify_valid_flag('-E')
|
||||||
|
|
||||||
|
def test_optimize(self):
|
||||||
|
self.verify_valid_flag('-O')
|
||||||
|
self.verify_valid_flag('-OO')
|
||||||
|
|
||||||
|
def test_q(self):
|
||||||
|
self.verify_valid_flag('-Qold')
|
||||||
|
self.verify_valid_flag('-Qnew')
|
||||||
|
self.verify_valid_flag('-Qwarn')
|
||||||
|
self.verify_valid_flag('-Qwarnall')
|
||||||
|
|
||||||
|
def test_site_flag(self):
|
||||||
|
self.verify_valid_flag('-S')
|
||||||
|
|
||||||
|
def test_usage(self):
|
||||||
|
self.assertTrue('usage' in self.start_python('-h'))
|
||||||
|
|
||||||
|
def test_version(self):
|
||||||
|
version = 'Python %d.%d' % sys.version_info[:2]
|
||||||
|
self.assertTrue(self.start_python('-V').startswith(version))
|
||||||
|
|
||||||
|
def test_main():
|
||||||
|
test.test_support.run_unittest(CmdLineTest)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
test_main()
|
|
@ -12,6 +12,9 @@ What's New in Python 2.5 alpha 1?
|
||||||
Core and builtins
|
Core and builtins
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
|
- SF Bug #887946: fix segfault when redirecting stdin from a directory.
|
||||||
|
Provide a warning when a directory is passed on the command line.
|
||||||
|
|
||||||
- Fix segfault with invalid coding.
|
- Fix segfault with invalid coding.
|
||||||
|
|
||||||
- SF bug #772896: unknown encoding results in MemoryError.
|
- SF bug #772896: unknown encoding results in MemoryError.
|
||||||
|
|
|
@ -359,6 +359,14 @@ Py_Main(int argc, char **argv)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
{
|
||||||
|
/* XXX: does this work on Win/Win64? (see posix_fstat) */
|
||||||
|
struct stat sb;
|
||||||
|
if (fstat(fileno(fp), &sb) == 0 &&
|
||||||
|
S_ISDIR(sb.st_mode)) {
|
||||||
|
fprintf(stderr, "%s: warning '%s' is a directory\n", argv[0], filename);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -947,6 +947,15 @@ _PySys_Init(void)
|
||||||
m = Py_InitModule3("sys", sys_methods, sys_doc);
|
m = Py_InitModule3("sys", sys_methods, sys_doc);
|
||||||
sysdict = PyModule_GetDict(m);
|
sysdict = PyModule_GetDict(m);
|
||||||
|
|
||||||
|
{
|
||||||
|
/* XXX: does this work on Win/Win64? (see posix_fstat) */
|
||||||
|
struct stat sb;
|
||||||
|
if (fstat(fileno(stdin), &sb) == 0 &&
|
||||||
|
S_ISDIR(sb.st_mode)) {
|
||||||
|
Py_FatalError("<stdin> is a directory");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Closing the standard FILE* if sys.std* goes aways causes problems
|
/* Closing the standard FILE* if sys.std* goes aways causes problems
|
||||||
* for embedded Python usages. Closing them when somebody explicitly
|
* for embedded Python usages. Closing them when somebody explicitly
|
||||||
* invokes .close() might be possible, but the FAQ promises they get
|
* invokes .close() might be possible, but the FAQ promises they get
|
||||||
|
|
Loading…
Reference in New Issue