diff options
author | Ezio Melotti <ezio.melotti@gmail.com> | 2012-11-23 16:48:32 (GMT) |
---|---|---|
committer | Ezio Melotti <ezio.melotti@gmail.com> | 2012-11-23 16:48:32 (GMT) |
commit | a0dd22e5e824195e322cb417ebb34c66475e952d (patch) | |
tree | e956848fbcae719625590663cbef64c6401d124e | |
parent | 3c76aa6b234fb1496b35488f30cca2fece467354 (diff) | |
download | cpython-a0dd22e5e824195e322cb417ebb34c66475e952d.zip cpython-a0dd22e5e824195e322cb417ebb34c66475e952d.tar.gz cpython-a0dd22e5e824195e322cb417ebb34c66475e952d.tar.bz2 |
#16306: report only the first unknown option and add more tests. Patch by Serhiy Storchaka.
-rw-r--r-- | Lib/test/test_cmd_line.py | 18 | ||||
-rw-r--r-- | Modules/main.c | 1 | ||||
-rw-r--r-- | Python/getopt.c | 2 |
3 files changed, 17 insertions, 4 deletions
diff --git a/Lib/test/test_cmd_line.py b/Lib/test/test_cmd_line.py index d8f2443..e12f305 100644 --- a/Lib/test/test_cmd_line.py +++ b/Lib/test/test_cmd_line.py @@ -376,12 +376,24 @@ class CmdLineTest(unittest.TestCase): print("del sys.modules['__main__']", file=script) assert_python_ok(filename) - def test_unknown_options(self): - rc, out, err = assert_python_failure('-z', __cleanenv=True) - self.assertIn(b'Unknown option', err) + rc, out, err = assert_python_failure('-E', '-z') + self.assertIn(b'Unknown option: -z', err) + self.assertEqual(err.splitlines().count(b'Unknown option: -z'), 1) + self.assertEqual(b'', out) + # Add "without='-E'" to prevent _assert_python to append -E + # to env_vars and change the output of stderr + rc, out, err = assert_python_failure('-z', without='-E') + self.assertIn(b'Unknown option: -z', err) self.assertEqual(err.splitlines().count(b'Unknown option: -z'), 1) self.assertEqual(b'', out) + rc, out, err = assert_python_failure('-a', '-z', without='-E') + self.assertIn(b'Unknown option: -a', err) + # only the first unknown option is reported + self.assertNotIn(b'Unknown option: -z', err) + self.assertEqual(err.splitlines().count(b'Unknown option: -a'), 1) + self.assertEqual(b'', out) + def test_main(): test.support.run_unittest(CmdLineTest) diff --git a/Modules/main.c b/Modules/main.c index 5d1d896..17aebae 100644 --- a/Modules/main.c +++ b/Modules/main.c @@ -339,6 +339,7 @@ Py_Main(int argc, wchar_t **argv) /* Hash randomization needed early for all string operations (including -W and -X options). */ + _PyOS_opterr = 0; /* prevent printing the error in 1st pass */ while ((c = _PyOS_GetOpt(argc, argv, PROGRAM_OPTS)) != EOF) { if (c == 'm' || c == 'c') { /* -c / -m is the last option: following arguments are diff --git a/Python/getopt.c b/Python/getopt.c index 037aa5d..5cf4cbd 100644 --- a/Python/getopt.c +++ b/Python/getopt.c @@ -45,7 +45,7 @@ static wchar_t *opt_ptr = L""; void _PyOS_ResetGetOpt(void) { - _PyOS_opterr = 0; /* prevent printing the error in 2nd loop in main.c */ + _PyOS_opterr = 1; _PyOS_optind = 1; _PyOS_optarg = NULL; opt_ptr = L""; |