aboutsummaryrefslogtreecommitdiff
path: root/test/functional/terminal/ex_terminal_spec.lua
diff options
context:
space:
mode:
authorScott Prager <splinterofchaos@gmail.com>2015-04-13 23:53:16 -0400
committerScott Prager <splinterofchaos@gmail.com>2015-05-02 09:47:29 -0400
commit74aef8972048c3288a3cbd6a8dadf17a8df3c08c (patch)
tree85397b18d46b464466ba0dad85bd7ca0000b2f4f /test/functional/terminal/ex_terminal_spec.lua
parent205466830207a920c62146b7b689fac2e395431a (diff)
downloadrneovim-74aef8972048c3288a3cbd6a8dadf17a8df3c08c.tar.gz
rneovim-74aef8972048c3288a3cbd6a8dadf17a8df3c08c.tar.bz2
rneovim-74aef8972048c3288a3cbd6a8dadf17a8df3c08c.zip
term: use an argument vector for termopen().
Old behaviour: termopen('cmd') would run `&shell &shcf "cmd"`, which caused the functional tests to fail on some systems due to the process not "owning" the terminal. Also, it is inconsistent with jobstart(). Modify termopen() so that &shell is not invoked, but maintain the old behaviour with :terminal. Factor the common code for building the argument vector from jobstart() and modify the functional tests to call termopen() instead of :terminal (fixes #2354). Also: * Add a 'name' option for termopen() so that `:terminal {cmd}` produces a buffer named "term//{cwd}/{cmd}" and termopen() users can customize the name. * Update the documentation. * Add functional tests for `:terminal` sinse its behaviour now differs from termopen(). Add "test/functional/fixtures/shell-test.c" and move "test/functional/job/tty-test.c" there, too. Helped-by: Justin M. Keyes <@justinmk>
Diffstat (limited to 'test/functional/terminal/ex_terminal_spec.lua')
-rw-r--r--test/functional/terminal/ex_terminal_spec.lua61
1 files changed, 61 insertions, 0 deletions
diff --git a/test/functional/terminal/ex_terminal_spec.lua b/test/functional/terminal/ex_terminal_spec.lua
new file mode 100644
index 0000000000..3855cf4b65
--- /dev/null
+++ b/test/functional/terminal/ex_terminal_spec.lua
@@ -0,0 +1,61 @@
+local helpers = require('test.functional.helpers')
+local Screen = require('test.functional.ui.screen')
+local clear, wait, nvim = helpers.clear, helpers.wait, helpers.nvim
+local nvim_dir = helpers.nvim_dir
+local execute, source = helpers.execute, helpers.source
+local eq, neq = helpers.eq, helpers.neq
+
+describe(':terminal', function()
+ local screen
+
+ before_each(function()
+ clear()
+ screen = Screen.new(50, 7)
+ screen:attach(false)
+ nvim('set_option', 'shell', nvim_dir..'/shell-test')
+ nvim('set_option', 'shellcmdflag', 'EXE')
+
+ end)
+
+ it('with no argument, acts like termopen()', function()
+ execute('terminal')
+ wait()
+ screen:expect([[
+ ready $ |
+ [Program exited, press any key to close] |
+ |
+ |
+ |
+ |
+ -- TERMINAL -- |
+ ]])
+ end)
+
+ it('executes a given command through the shell', function()
+ execute('terminal echo hi')
+ wait()
+ screen:expect([[
+ ready $ echo hi |
+ |
+ [Program exited, press any key to close] |
+ |
+ |
+ |
+ -- TERMINAL -- |
+ ]])
+ end)
+
+ it('allows quotes and slashes', function()
+ execute([[terminal echo 'hello' \ "world"]])
+ wait()
+ screen:expect([[
+ ready $ echo 'hello' \ "world" |
+ |
+ [Program exited, press any key to close] |
+ |
+ |
+ |
+ -- TERMINAL -- |
+ ]])
+ end)
+end)