diff options
author | Todd Leonhardt <todd.leonhardt@gmail.com> | 2017-02-24 02:35:52 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-02-24 02:35:52 -0500 |
commit | 233dc435f3b99b71c48b5f3ecdbafe7718807571 (patch) | |
tree | 0ba5ea307d9c4db633233b0a5e14e0b7521647aa /tests/test_parsing.py | |
parent | b9ac44f889c42631808a4149a81f2e271990b75b (diff) | |
parent | 6ad77bed288403b6baa55c781737674f7f7dc49b (diff) | |
download | cmd2-git-233dc435f3b99b71c48b5f3ecdbafe7718807571.tar.gz |
Merge pull request #56 from python-cmd2/input_redirection_parsing_bug
Input redirection parsing bug
Diffstat (limited to 'tests/test_parsing.py')
-rw-r--r-- | tests/test_parsing.py | 52 |
1 files changed, 47 insertions, 5 deletions
diff --git a/tests/test_parsing.py b/tests/test_parsing.py index 7186a143..b3b1543d 100644 --- a/tests/test_parsing.py +++ b/tests/test_parsing.py @@ -43,6 +43,12 @@ def parser(): c._init_parser() return c.parser +@fixture +def input_parser(): + c = cmd2.Cmd() + c._init_parser() + return c.inputParser + def test_remaining_args(): assert cmd2.remaining_args('-f bar bar cow', ['bar', 'cow']) == 'bar cow' @@ -179,16 +185,16 @@ def test_parse_simple_piped(parser): - command: {0}""".format(command, pipe) assert parser.parseString('simple | piped').dump() == expected -def test_parse_doulbe_pipe_is_not_a_pipe(parser): - command = "double" - args = "-pipe || is not a pipe" +def test_parse_double_pipe_is_not_a_pipe(parser): + command = "double-pipe" + args = "|| is not a pipe" if new_pyparsing: command = repr(command) args = repr(args) - expected = """['double', '-pipe || is not a pipe'] + expected = """['double-pipe', '|| is not a pipe'] - args: {1} - command: {0} -- statement: ['double', '-pipe || is not a pipe'] +- statement: ['double-pipe', '|| is not a pipe'] - args: {1} - command: {0}""".format(command, args) assert parser.parseString('double-pipe || is not a pipe').dump() == expected @@ -237,6 +243,42 @@ def test_parse_output_redirect(parser): - command: {0}""".format(command, args, redirect, output) assert parser.parseString('output into > afile.txt').dump() == expected +def test_parse_output_redirect_with_dash_in_path(parser): + command = "output" + args = "into" + redirect = ">" + output = "python-cmd2/afile.txt" + if new_pyparsing: + command = repr(command) + args = repr(args) + redirect = repr(redirect) + output = repr(output) + expected = """['output', 'into', '>', 'python-cmd2/afile.txt'] +- args: {1} +- command: {0} +- output: {2} +- outputTo: {3} +- statement: ['output', 'into'] + - args: {1} + - command: {0}""".format(command, args, redirect, output) + assert parser.parseString('output into > python-cmd2/afile.txt').dump() == expected + +def test_parse_input_redirect(input_parser): + input_from = "< afile.txt" + if new_pyparsing: + input_from = repr(input_from) + expected = """['', '< afile.txt'] +- inputFrom: {0}""".format(input_from) + assert input_parser.parseString('< afile.txt').dump() == expected + +def test_parse_input_redirect_with_dash_in_path(input_parser): + input_from = "< python-cmd2/afile.txt" + if new_pyparsing: + input_from = repr(input_from) + expected = """['', '< python-cmd2/afile.txt'] +- inputFrom: {0}""".format(input_from) + assert input_parser.parseString('< python-cmd2/afile.txt').dump() == expected + def test_parse_pipe_and_redirect(parser): command = "output" args = "into" |