summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorkotfu <kotfu@kotfu.net>2018-01-14 15:38:00 -0700
committerkotfu <kotfu@kotfu.net>2018-01-14 15:38:00 -0700
commitcab8a1626f61088c35fb3b4a0ce92b76bba0f1da (patch)
treeafc6c814befa59927469b944ba2fefb487779192 /tests
parent405f4e4e951e0af46c7c5d746459f24e5c316eab (diff)
downloadcmd2-git-cab8a1626f61088c35fb3b4a0ce92b76bba0f1da.tar.gz
more robust argparse and arglist decorators
Diffstat (limited to 'tests')
-rw-r--r--tests/test_argparse.py46
1 files changed, 44 insertions, 2 deletions
diff --git a/tests/test_argparse.py b/tests/test_argparse.py
index 7d6d99de..79075fe9 100644
--- a/tests/test_argparse.py
+++ b/tests/test_argparse.py
@@ -64,6 +64,17 @@ class ArgparseApp(cmd2.Cmd):
else:
self.stdout.write('False')
+
+ argparser = argparse.ArgumentParser()
+ argparser.add_argument('args', nargs='*')
+ @cmd2.with_argument_list
+ @cmd2.with_argument_parser(argparser)
+ def do_arglistandargparser(self, arglist, args=None):
+ if isinstance(arglist, list):
+ self.stdout.write(' '.join(arglist))
+ else:
+ self.stdout.write('False')
+
@cmd2.with_argument_list
def do_arglist(self, arglist):
if isinstance(arglist, list):
@@ -71,17 +82,32 @@ class ArgparseApp(cmd2.Cmd):
else:
self.stdout.write('False')
+ @cmd2.with_argument_list
+ @cmd2.with_argument_list
+ def do_arglisttwice(self, arglist):
+ if isinstance(arglist, list):
+ self.stdout.write(' '.join(arglist))
+ else:
+ self.stdout.write('False')
+
+
class ArglistApp(cmd2.Cmd):
def __init__(self):
self.use_argument_list = True
cmd2.Cmd.__init__(self)
def do_arglist(self, arglist):
+ """Print true if the arglist parameter is passed as a list."""
if isinstance(arglist, list):
self.stdout.write('True')
else:
self.stdout.write('False')
+ @cmd2.with_argument_list
+ def do_arglistwithdecorator(self, arglist):
+ self.stdout.write(' '.join(arglist))
+
+
@pytest.fixture
def argparse_app():
app = ArgparseApp()
@@ -142,9 +168,25 @@ def test_argparse_arglist(argparse_app):
assert out[0] == 'True'
def test_arglist(argparse_app):
- out = run_cmd(argparse_app, 'arglist "we should" get these in a list, not a string')
+ out = run_cmd(argparse_app, 'arglist "we should" get these')
assert out[0] == 'True'
+def test_arglist_decorator_twice(argparse_app):
+ out = run_cmd(argparse_app, 'arglisttwice "we should" get these')
+ assert out[0] == 'we should get these'
+
+def test_arglist_and_argparser(argparse_app):
+ out = run_cmd(argparse_app, 'arglistandargparser some "quoted words"')
+ assert out[0] == 'some quoted words'
+
def test_use_argument_list(arglist_app):
- out = run_cmd(arglist_app, 'arglist "we should" get these in a list, not a string')
+ out = run_cmd(arglist_app, 'arglist "we should" get these in a list, not a string')
assert out[0] == 'True'
+
+def test_arglist_attribute_and_decorator(arglist_app):
+ out = run_cmd(arglist_app, 'arglistwithdecorator "we should" get these')
+ assert out[0] == 'we should get these'
+
+#def test_arglist_help(arglist_app):
+# out = run_cmd(arglist_app, 'help arglist')
+# assert out[0] == 'True'