diff options
author | Jan Edmund Lazo <jan.lazo@mail.utoronto.ca> | 2020-12-11 23:36:15 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-11 23:36:15 -0500 |
commit | cacdef5ff18e7123a9e734537a831839bf4ef0ec (patch) | |
tree | 5d4f1683e7678c1ba339992438def2a16e59adb9 /test/functional/eval/exepath_spec.lua | |
parent | 062576f679a1bd5cb546bb8081dc97caefe7b51f (diff) | |
parent | da58242fb8e432415778e3eeab96a9d63edfdf06 (diff) | |
download | rneovim-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.lua | 40 |
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) |