aboutsummaryrefslogtreecommitdiff
path: root/test/functional/eval/exepath_spec.lua
diff options
context:
space:
mode:
authorJan Edmund Lazo <jan.lazo@mail.utoronto.ca>2020-12-11 23:36:15 -0500
committerGitHub <noreply@github.com>2020-12-11 23:36:15 -0500
commitcacdef5ff18e7123a9e734537a831839bf4ef0ec (patch)
tree5d4f1683e7678c1ba339992438def2a16e59adb9 /test/functional/eval/exepath_spec.lua
parent062576f679a1bd5cb546bb8081dc97caefe7b51f (diff)
parentda58242fb8e432415778e3eeab96a9d63edfdf06 (diff)
downloadrneovim-cacdef5ff18e7123a9e734537a831839bf4ef0ec.tar.gz
rneovim-cacdef5ff18e7123a9e734537a831839bf4ef0ec.tar.bz2
rneovim-cacdef5ff18e7123a9e734537a831839bf4ef0ec.zip
Merge pull request #13489 from janlazo/issue-13485
eval: executable(), exepath() accept strings only
Diffstat (limited to 'test/functional/eval/exepath_spec.lua')
-rw-r--r--test/functional/eval/exepath_spec.lua40
1 files changed, 33 insertions, 7 deletions
diff --git a/test/functional/eval/exepath_spec.lua b/test/functional/eval/exepath_spec.lua
index 10a11aeacc..08d2c59af8 100644
--- a/test/functional/eval/exepath_spec.lua
+++ b/test/functional/eval/exepath_spec.lua
@@ -1,14 +1,40 @@
local helpers = require('test.functional.helpers')(after_each)
local eq, clear, call, iswin =
helpers.eq, helpers.clear, helpers.call, helpers.iswin
+local command = helpers.command
+local exc_exec = helpers.exc_exec
+local matches = helpers.matches
-describe('exepath() (Windows)', function()
- if not iswin() then return end -- N/A for Unix.
+describe('exepath()', function()
+ before_each(clear)
- it('append extension if omitted', function()
- local filename = 'cmd'
- local pathext = '.exe'
- clear({env={PATHEXT=pathext}})
- eq(call('exepath', filename..pathext), call('exepath', filename))
+ it('returns 1 for commands in $PATH', function()
+ local exe = iswin() and 'ping' or 'ls'
+ local ext_pat = iswin() and '%.EXE$' or '$'
+ matches(exe .. ext_pat, call('exepath', exe))
+ command('let $PATH = fnamemodify("./test/functional/fixtures/bin", ":p")')
+ ext_pat = iswin() and '%.CMD$' or '$'
+ matches('null' .. ext_pat, call('exepath', 'null'))
+ matches('true' .. ext_pat, call('exepath', 'true'))
+ matches('false' .. ext_pat, call('exepath', 'false'))
end)
+
+ it('fails for invalid values', function()
+ for _, input in ipairs({'""', 'v:null', 'v:true', 'v:false', '{}', '[]'}) do
+ eq('Vim(call):E928: String required', exc_exec('call exepath('..input..')'))
+ end
+ command('let $PATH = fnamemodify("./test/functional/fixtures/bin", ":p")')
+ for _, input in ipairs({'v:null', 'v:true', 'v:false'}) do
+ eq('Vim(call):E928: String required', exc_exec('call exepath('..input..')'))
+ end
+ end)
+
+ if iswin() then
+ it('append extension if omitted', function()
+ local filename = 'cmd'
+ local pathext = '.exe'
+ clear({env={PATHEXT=pathext}})
+ eq(call('exepath', filename..pathext), call('exepath', filename))
+ end)
+ end
end)