diff options
-rwxr-xr-x | cmd2.py | 12 | ||||
-rw-r--r-- | tests/test_cmd2.py | 4 |
2 files changed, 4 insertions, 12 deletions
@@ -1138,21 +1138,15 @@ class Cmd(cmd.Cmd): Usage: pause [text]""" sm.input(text + '\n') - # noinspection PyMethodMayBeStatic def do_shell(self, command): """Execute a command as if at the OS prompt. Usage: shell <command> [arguments]""" try: - out = subprocess.check_output(shlex.split(command)) - except subprocess.CalledProcessError as e: - self.perror(e, traceback_war=False) + proc = subprocess.Popen(command, stdout=self.stdout, stderr=sys.stderr, shell=True) + proc.communicate() except FileNotFoundError as e: - self.perror(e, traceback_war=False) - else: - if six.PY3: - out = out.decode() - self.stdout.write(out + '\n') + self.perror(e.strerror, traceback_war=False) def path_complete(self, text, line, begidx, endidx, dir_exe_only=False, dir_only=False): """Method called to complete an input line by local file system path completion. diff --git a/tests/test_cmd2.py b/tests/test_cmd2.py index 592e6af2..9dd2697b 100644 --- a/tests/test_cmd2.py +++ b/tests/test_cmd2.py @@ -103,12 +103,10 @@ To enable full traceback, run the following command: 'set debug true' def test_base_shell(base_app, monkeypatch): m = mock.Mock() - monkeypatch.setattr("os.system", m) + monkeypatch.setattr("subprocess.Popen", m) out = run_cmd(base_app, 'shell echo a') assert out == [] assert m.called - m.assert_called_with('echo a') - def test_base_py(base_app, capsys): run_cmd(base_app, 'py qqq=3') |