diff options
author | R David Murray <rdmurray@bitdance.com> | 2014-10-18 00:07:08 (GMT) |
---|---|---|
committer | R David Murray <rdmurray@bitdance.com> | 2014-10-18 00:07:08 (GMT) |
commit | af26c15110b76195e62a06d17e39176d42c0511c (patch) | |
tree | d585a5eafde4ac6b2f0ffc1394547633adf1746e /Lib/test/test_argparse.py | |
parent | 10229a450f82b5582abe3116bbc8cb73daba3e2f (diff) | |
download | cpython-af26c15110b76195e62a06d17e39176d42c0511c.zip cpython-af26c15110b76195e62a06d17e39176d42c0511c.tar.gz cpython-af26c15110b76195e62a06d17e39176d42c0511c.tar.bz2 |
#9351: set_defaults on subparser is no longer ignored if set on parent.
Before, if a default was set on the parent parser, any default for that
variable set via set_defaults on a subparser would be ignored. Now
the subparser set_defaults is honored.
Patch by Jyrki Pullianinen.
Diffstat (limited to 'Lib/test/test_argparse.py')
-rw-r--r-- | Lib/test/test_argparse.py | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/Lib/test/test_argparse.py b/Lib/test/test_argparse.py index 0df66ad..b74b622 100644 --- a/Lib/test/test_argparse.py +++ b/Lib/test/test_argparse.py @@ -2726,6 +2726,13 @@ class TestSetDefaults(TestCase): parser = ErrorRaisingArgumentParser(parents=[parent]) self.assertEqual(NS(x='foo'), parser.parse_args([])) + def test_set_defaults_on_parent_and_subparser(self): + parser = argparse.ArgumentParser() + xparser = parser.add_subparsers().add_parser('X') + parser.set_defaults(foo=1) + xparser.set_defaults(foo=2) + self.assertEqual(NS(foo=2), parser.parse_args(['X'])) + def test_set_defaults_same_as_add_argument(self): parser = ErrorRaisingArgumentParser() parser.set_defaults(w='W', x='X', y='Y', z='Z') |