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:
Neal Norwitz 2005-10-03 00:54:56 +00:00
parent d157b1d237
commit 11bd119226
4 changed files with 70 additions and 0 deletions

50
Lib/test/test_cmd_line.py Normal file
View File

@ -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()

View File

@ -12,6 +12,9 @@ What's New in Python 2.5 alpha 1?
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.
- SF bug #772896: unknown encoding results in MemoryError.

View File

@ -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);
}
}
}
}

View File

@ -947,6 +947,15 @@ _PySys_Init(void)
m = Py_InitModule3("sys", sys_methods, sys_doc);
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
* for embedded Python usages. Closing them when somebody explicitly
* invokes .close() might be possible, but the FAQ promises they get