Skip to content

Commit 95eb7f6

Browse files
serhiy-storchakasavannahostrowski
authored andcommitted
pythongh-95468: Add more tests for "--" (double dash) in test_argparse (pythonGH-124274)
1 parent e9483e6 commit 95eb7f6

File tree

1 file changed

+41
-2
lines changed

1 file changed

+41
-2
lines changed

Lib/test/test_argparse.py

Lines changed: 41 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -5760,7 +5760,9 @@ def test_zero_or_more_optional(self):
57605760
args = parser.parse_args([])
57615761
self.assertEqual(NS(x=[]), args)
57625762

5763-
def test_double_dash(self):
5763+
5764+
class TestDoubleDash(TestCase):
5765+
def test_single_argument_option(self):
57645766
parser = argparse.ArgumentParser(exit_on_error=False)
57655767
parser.add_argument('-f', '--foo')
57665768
parser.add_argument('bar', nargs='*')
@@ -5784,6 +5786,7 @@ def test_double_dash(self):
57845786
args = parser.parse_args(['a', '--', 'b', '--', 'c', '--foo', 'd'])
57855787
self.assertEqual(NS(foo=None, bar=['a', 'b', '--', 'c', '--foo', 'd']), args)
57865788

5789+
def test_multiple_argument_option(self):
57875790
parser = argparse.ArgumentParser(exit_on_error=False)
57885791
parser.add_argument('-f', '--foo', nargs='*')
57895792
parser.add_argument('bar', nargs='*')
@@ -5806,6 +5809,7 @@ def test_double_dash(self):
58065809
self.assertEqual(NS(foo=['c'], bar=['a', 'b']), args)
58075810
self.assertEqual(argv, ['--', 'd'])
58085811

5812+
def test_multiple_double_dashes(self):
58095813
parser = argparse.ArgumentParser(exit_on_error=False)
58105814
parser.add_argument('foo')
58115815
parser.add_argument('bar', nargs='*')
@@ -5821,9 +5825,10 @@ def test_double_dash(self):
58215825
args = parser.parse_args(['--', '--', 'a', '--', 'b', 'c'])
58225826
self.assertEqual(NS(foo='--', bar=['a', '--', 'b', 'c']), args)
58235827

5828+
def test_remainder(self):
58245829
parser = argparse.ArgumentParser(exit_on_error=False)
58255830
parser.add_argument('foo')
5826-
parser.add_argument('bar', nargs=argparse.REMAINDER)
5831+
parser.add_argument('bar', nargs='...')
58275832

58285833
args = parser.parse_args(['--', 'a', 'b', 'c'])
58295834
self.assertEqual(NS(foo='a', bar=['b', 'c']), args)
@@ -5834,6 +5839,40 @@ def test_double_dash(self):
58345839
args = parser.parse_args(['a', '--', 'b', '--', 'c'])
58355840
self.assertEqual(NS(foo='a', bar=['b', '--', 'c']), args)
58365841

5842+
parser = argparse.ArgumentParser(exit_on_error=False)
5843+
parser.add_argument('--foo')
5844+
parser.add_argument('bar', nargs='...')
5845+
args = parser.parse_args(['--foo', 'a', '--', 'b', '--', 'c'])
5846+
self.assertEqual(NS(foo='a', bar=['--', 'b', '--', 'c']), args)
5847+
5848+
def test_subparser(self):
5849+
parser = argparse.ArgumentParser(exit_on_error=False)
5850+
parser.add_argument('foo')
5851+
subparsers = parser.add_subparsers()
5852+
parser1 = subparsers.add_parser('run')
5853+
parser1.add_argument('-f')
5854+
parser1.add_argument('bar', nargs='*')
5855+
5856+
args = parser.parse_args(['x', 'run', 'a', 'b', '-f', 'c'])
5857+
self.assertEqual(NS(foo='x', f='c', bar=['a', 'b']), args)
5858+
args = parser.parse_args(['x', 'run', 'a', 'b', '--', '-f', 'c'])
5859+
self.assertEqual(NS(foo='x', f=None, bar=['a', 'b', '-f', 'c']), args)
5860+
args = parser.parse_args(['x', 'run', 'a', '--', 'b', '-f', 'c'])
5861+
self.assertEqual(NS(foo='x', f=None, bar=['a', 'b', '-f', 'c']), args)
5862+
args = parser.parse_args(['x', 'run', '--', 'a', 'b', '-f', 'c'])
5863+
self.assertEqual(NS(foo='x', f=None, bar=['a', 'b', '-f', 'c']), args)
5864+
args = parser.parse_args(['x', '--', 'run', 'a', 'b', '-f', 'c'])
5865+
self.assertEqual(NS(foo='x', f='c', bar=['a', 'b']), args)
5866+
args = parser.parse_args(['--', 'x', 'run', 'a', 'b', '-f', 'c'])
5867+
self.assertEqual(NS(foo='x', f='c', bar=['a', 'b']), args)
5868+
args = parser.parse_args(['x', 'run', '--', 'a', '--', 'b'])
5869+
self.assertEqual(NS(foo='x', f=None, bar=['a', '--', 'b']), args)
5870+
args = parser.parse_args(['x', '--', 'run', '--', 'a', '--', 'b'])
5871+
self.assertEqual(NS(foo='x', f=None, bar=['a', '--', 'b']), args)
5872+
self.assertRaisesRegex(argparse.ArgumentError,
5873+
"invalid choice: '--'",
5874+
parser.parse_args, ['--', 'x', '--', 'run', 'a', 'b'])
5875+
58375876

58385877
# ===========================
58395878
# parse_intermixed_args tests

0 commit comments

Comments
 (0)