summaryrefslogtreecommitdiff
path: root/tests/test_run_pyscript.py
diff options
context:
space:
mode:
authorKevin Van Brunt <kmvanbrunt@gmail.com>2019-06-15 01:08:06 -0400
committerKevin Van Brunt <kmvanbrunt@gmail.com>2019-06-15 01:08:06 -0400
commit451f449c7356df00c8d30750355a536b30997608 (patch)
treef7a8c62fbe497c662c5bb8ce96843e63a18a4c96 /tests/test_run_pyscript.py
parentbedc91d612c478da2ca2f048ddf91180a643c324 (diff)
downloadcmd2-git-451f449c7356df00c8d30750355a536b30997608.tar.gz
Renamed file
Diffstat (limited to 'tests/test_run_pyscript.py')
-rw-r--r--tests/test_run_pyscript.py56
1 files changed, 56 insertions, 0 deletions
diff --git a/tests/test_run_pyscript.py b/tests/test_run_pyscript.py
new file mode 100644
index 00000000..bbe9e17d
--- /dev/null
+++ b/tests/test_run_pyscript.py
@@ -0,0 +1,56 @@
+# coding=utf-8
+# flake8: noqa E302
+"""
+Unit/functional testing for run_pytest in cmd2
+"""
+import os
+from cmd2 import plugin
+
+from .conftest import run_cmd
+
+HOOK_OUTPUT = "TEST_OUTPUT"
+
+def cmdfinalization_hook(data: plugin.CommandFinalizationData) -> plugin.CommandFinalizationData:
+ """A cmdfinalization_hook hook which requests application exit"""
+ print(HOOK_OUTPUT)
+ return data
+
+def test_run_pyscript_help(base_app, request):
+ test_dir = os.path.dirname(request.module.__file__)
+ python_script = os.path.join(test_dir, 'pyscript', 'help.py')
+ out1, err1 = run_cmd(base_app, 'help')
+ out2, err2 = run_cmd(base_app, 'run_pyscript {}'.format(python_script))
+ assert out1 and out1 == out2
+
+
+def test_run_pyscript_dir(base_app, request):
+ test_dir = os.path.dirname(request.module.__file__)
+ python_script = os.path.join(test_dir, 'pyscript', 'pyscript_dir.py')
+
+ out, err = run_cmd(base_app, 'run_pyscript {}'.format(python_script))
+ assert out
+ assert out[0] == "['cmd_echo']"
+
+
+def test_run_pyscript_stdout_capture(base_app, request):
+ base_app.register_cmdfinalization_hook(cmdfinalization_hook)
+ test_dir = os.path.dirname(request.module.__file__)
+ python_script = os.path.join(test_dir, 'pyscript', 'stdout_capture.py')
+ out, err = run_cmd(base_app, 'run_pyscript {} {}'.format(python_script, HOOK_OUTPUT))
+
+ assert out[0] == "PASSED"
+ assert out[1] == "PASSED"
+
+def test_run_pyscript_stop(base_app, request):
+ # Verify onecmd_plus_hooks() returns True if any commands in a pyscript return True for stop
+ test_dir = os.path.dirname(request.module.__file__)
+
+ # help.py doesn't run any commands that returns True for stop
+ python_script = os.path.join(test_dir, 'pyscript', 'help.py')
+ stop = base_app.onecmd_plus_hooks('run_pyscript {}'.format(python_script))
+ assert not stop
+
+ # stop.py runs the quit command which does return True for stop
+ python_script = os.path.join(test_dir, 'pyscript', 'stop.py')
+ stop = base_app.onecmd_plus_hooks('run_pyscript {}'.format(python_script))
+ assert stop