summaryrefslogtreecommitdiff
path: root/tests/test_completion.py
diff options
context:
space:
mode:
authorKevin Van Brunt <kmvanbrunt@gmail.com>2020-02-17 12:12:55 -0500
committerKevin Van Brunt <kmvanbrunt@gmail.com>2020-02-17 12:12:55 -0500
commitb6971fb9d518da673de1943e9e47dffe1acaf4b4 (patch)
treec311eb89aa27326f4948d5eac7577d8892ed4852 /tests/test_completion.py
parent729e152c525bc30d36f130f8dc8442aeb00d1de8 (diff)
downloadcmd2-git-b6971fb9d518da673de1943e9e47dffe1acaf4b4.tar.gz
Only tab complete after redirection tokens if redirection is allowed
Diffstat (limited to 'tests/test_completion.py')
-rwxr-xr-xtests/test_completion.py60
1 files changed, 32 insertions, 28 deletions
diff --git a/tests/test_completion.py b/tests/test_completion.py
index f545c8f9..e13d87de 100755
--- a/tests/test_completion.py
+++ b/tests/test_completion.py
@@ -902,11 +902,6 @@ class RedirCompType(enum.Enum):
DEFAULT = 3,
NONE = 4
- """
- fake > >
- fake | grep > file
- fake | grep > file >
- """
@pytest.mark.parametrize('line, comp_type', [
('fake', RedirCompType.DEFAULT),
@@ -933,31 +928,40 @@ class RedirCompType(enum.Enum):
('fake > file >>', RedirCompType.NONE),
])
def test_redirect_complete(cmd2_app, monkeypatch, line, comp_type):
- shell_cmd_complete_mock = mock.MagicMock(name='shell_cmd_complete')
- monkeypatch.setattr("cmd2.Cmd.shell_cmd_complete", shell_cmd_complete_mock)
-
- path_complete_mock = mock.MagicMock(name='path_complete')
- monkeypatch.setattr("cmd2.Cmd.path_complete", path_complete_mock)
-
- default_complete_mock = mock.MagicMock(name='fake_completer')
-
- text = ''
- line = '{} {}'.format(line, text)
- endidx = len(line)
- begidx = endidx - len(text)
+ # Test both cases of allow_redirection
+ cmd2_app.allow_redirection = True
+ for count in range(2):
+ shell_cmd_complete_mock = mock.MagicMock(name='shell_cmd_complete')
+ monkeypatch.setattr("cmd2.Cmd.shell_cmd_complete", shell_cmd_complete_mock)
+
+ path_complete_mock = mock.MagicMock(name='path_complete')
+ monkeypatch.setattr("cmd2.Cmd.path_complete", path_complete_mock)
+
+ default_complete_mock = mock.MagicMock(name='fake_completer')
+
+ text = ''
+ line = '{} {}'.format(line, text)
+ endidx = len(line)
+ begidx = endidx - len(text)
+
+ cmd2_app._redirect_complete(text, line, begidx, endidx, default_complete_mock)
+
+ if comp_type == RedirCompType.SHELL_CMD:
+ shell_cmd_complete_mock.assert_called_once()
+ elif comp_type == RedirCompType.PATH:
+ path_complete_mock.assert_called_once()
+ elif comp_type == RedirCompType.DEFAULT:
+ default_complete_mock.assert_called_once()
+ else:
+ shell_cmd_complete_mock.assert_not_called()
+ path_complete_mock.assert_not_called()
+ default_complete_mock.assert_not_called()
- cmd2_app._redirect_complete(text, line, begidx, endidx, default_complete_mock)
+ # Do the next test with allow_redirection as False
+ cmd2_app.allow_redirection = False
+ if comp_type != RedirCompType.DEFAULT:
+ comp_type = RedirCompType.NONE
- if comp_type == RedirCompType.SHELL_CMD:
- shell_cmd_complete_mock.assert_called_once()
- elif comp_type == RedirCompType.PATH:
- path_complete_mock.assert_called_once()
- elif comp_type == RedirCompType.DEFAULT:
- default_complete_mock.assert_called_once()
- else:
- shell_cmd_complete_mock.assert_not_called()
- path_complete_mock.assert_not_called()
- default_complete_mock.assert_not_called()
def test_complete_set_value(cmd2_app):
text = ''