]> granicus.if.org Git - python/commitdiff
Fix bug with argparse.Parser.parse_args(*args)
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Sun, 2 Sep 2012 12:59:19 +0000 (14:59 +0200)
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Sun, 2 Sep 2012 12:59:19 +0000 (14:59 +0200)
Lib/argparse.py
Lib/test/test_argparse.py

index cc3e374a661f64dd3bddd7202b85f8754c289ca3..67bbef2046e4afbcdfc5e3a222cc92acfb01c5b6 100644 (file)
@@ -1709,9 +1709,12 @@ class ArgumentParser(_AttributeHolder, _ActionsContainer):
         return args
 
     def parse_known_args(self, args=None, namespace=None):
-        # args default to the system args
         if args is None:
+            # args default to the system args
             args = _sys.argv[1:]
+        else:
+            # make sure that args are mutable
+            args = list(args)
 
         # default Namespace built from parser defaults
         if namespace is None:
index fe930a3e8c7b059c9d6ca04726380b2a74d9125b..2e6584f5d9962c5ae88e40a4a8d8bfbd9bc038fd 100644 (file)
@@ -4565,6 +4565,24 @@ class TestMessageContentError(TestCase):
 
 class TestParseKnownArgs(TestCase):
 
+    def test_arguments_tuple(self):
+        parser = argparse.ArgumentParser()
+        parser.parse_args(())
+
+    def test_arguments_list(self):
+        parser = argparse.ArgumentParser()
+        parser.parse_args([])
+
+    def test_arguments_tuple_positional(self):
+        parser = argparse.ArgumentParser()
+        parser.add_argument('x')
+        parser.parse_args(('x',))
+
+    def test_arguments_list_positional(self):
+        parser = argparse.ArgumentParser()
+        parser.add_argument('x')
+        parser.parse_args(['x'])
+
     def test_optionals(self):
         parser = argparse.ArgumentParser()
         parser.add_argument('--foo')