aboutsummaryrefslogtreecommitdiff
path: root/test/functional/lua/overrides_spec.lua
diff options
context:
space:
mode:
Diffstat (limited to 'test/functional/lua/overrides_spec.lua')
-rw-r--r--test/functional/lua/overrides_spec.lua270
1 files changed, 122 insertions, 148 deletions
diff --git a/test/functional/lua/overrides_spec.lua b/test/functional/lua/overrides_spec.lua
index c08f3d06a9..ecbdde3bfd 100644
--- a/test/functional/lua/overrides_spec.lua
+++ b/test/functional/lua/overrides_spec.lua
@@ -3,11 +3,11 @@ local helpers = require('test.functional.helpers')(after_each)
local Screen = require('test.functional.ui.screen')
local eq = helpers.eq
-local NIL = helpers.NIL
+local NIL = vim.NIL
local feed = helpers.feed
local clear = helpers.clear
-local funcs = helpers.funcs
-local meths = helpers.meths
+local fn = helpers.fn
+local api = helpers.api
local command = helpers.command
local write_file = helpers.write_file
local exec_capture = helpers.exec_capture
@@ -25,15 +25,15 @@ end)
describe('print', function()
it('returns nothing', function()
- eq(NIL, funcs.luaeval('print("abc")'))
- eq(0, funcs.luaeval('select("#", print("abc"))'))
+ eq(NIL, fn.luaeval('print("abc")'))
+ eq(0, fn.luaeval('select("#", print("abc"))'))
end)
it('allows catching printed text with :execute', function()
- eq('\nabc', funcs.execute('lua print("abc")'))
- eq('\nabc', funcs.execute('luado print("abc")'))
- eq('\nabc', funcs.execute('call luaeval("print(\'abc\')")'))
+ eq('\nabc', fn.execute('lua print("abc")'))
+ eq('\nabc', fn.execute('luado print("abc")'))
+ eq('\nabc', fn.execute('call luaeval("print(\'abc\')")'))
write_file(fname, 'print("abc")')
- eq('\nabc', funcs.execute('luafile ' .. fname))
+ eq('\nabc', fn.execute('luafile ' .. fname))
eq('abc', exec_capture('lua print("abc")'))
eq('abc', exec_capture('luado print("abc")'))
@@ -42,25 +42,36 @@ describe('print', function()
eq('abc', exec_capture('luafile ' .. fname))
end)
it('handles errors in __tostring', function()
- write_file(fname, [[
+ write_file(
+ fname,
+ [[
local meta_nilerr = { __tostring = function() error(nil) end }
local meta_abcerr = { __tostring = function() error("abc") end }
local meta_tblout = { __tostring = function() return {"TEST"} end }
v_nilerr = setmetatable({}, meta_nilerr)
v_abcerr = setmetatable({}, meta_abcerr)
v_tblout = setmetatable({}, meta_tblout)
- ]])
+ ]]
+ )
eq('', exec_capture('luafile ' .. fname))
-- TODO(bfredl): these look weird, print() should not use "E5114:" style errors..
- eq('Vim(lua):E5108: Error executing lua E5114: Error while converting print argument #2: [NULL]',
- pcall_err(command, 'lua print("foo", v_nilerr, "bar")'))
- eq('Vim(lua):E5108: Error executing lua E5114: Error while converting print argument #2: Xtest-functional-lua-overrides-luafile:2: abc',
- pcall_err(command, 'lua print("foo", v_abcerr, "bar")'))
- eq('Vim(lua):E5108: Error executing lua E5114: Error while converting print argument #2: <Unknown error: lua_tolstring returned NULL for tostring result>',
- pcall_err(command, 'lua print("foo", v_tblout, "bar")'))
+ eq(
+ 'Vim(lua):E5108: Error executing lua E5114: Error while converting print argument #2: [NULL]',
+ pcall_err(command, 'lua print("foo", v_nilerr, "bar")')
+ )
+ eq(
+ 'Vim(lua):E5108: Error executing lua E5114: Error while converting print argument #2: Xtest-functional-lua-overrides-luafile:2: abc',
+ pcall_err(command, 'lua print("foo", v_abcerr, "bar")')
+ )
+ eq(
+ 'Vim(lua):E5108: Error executing lua E5114: Error while converting print argument #2: <Unknown error: lua_tolstring returned NULL for tostring result>',
+ pcall_err(command, 'lua print("foo", v_tblout, "bar")')
+ )
end)
it('coerces error values into strings', function()
- write_file(fname, [[
+ write_file(
+ fname,
+ [[
function string_error() error("my mistake") end
function number_error() error(1234) end
function nil_error() error(nil) end
@@ -82,27 +93,35 @@ describe('print', function()
})
error(err)
end
- ]])
+ ]]
+ )
eq('', exec_capture('luafile ' .. fname))
- eq('Vim(lua):E5108: Error executing lua Xtest-functional-lua-overrides-luafile:1: my mistake',
- pcall_err(command, 'lua string_error()'))
- eq('Vim(lua):E5108: Error executing lua Xtest-functional-lua-overrides-luafile:2: 1234',
- pcall_err(command, 'lua number_error()'))
- eq('Vim(lua):E5108: Error executing lua [NULL]',
- pcall_err(command, 'lua nil_error()'))
- eq('Vim(lua):E5108: Error executing lua [NULL]',
- pcall_err(command, 'lua table_error()'))
- eq('Vim(lua):E5108: Error executing lua Internal Error [11234] my mistake',
- pcall_err(command, 'lua custom_error()'))
- eq('Vim(lua):E5108: Error executing lua [NULL]',
- pcall_err(command, 'lua bad_custom_error()'))
+ eq(
+ 'Vim(lua):E5108: Error executing lua Xtest-functional-lua-overrides-luafile:1: my mistake',
+ pcall_err(command, 'lua string_error()')
+ )
+ eq(
+ 'Vim(lua):E5108: Error executing lua Xtest-functional-lua-overrides-luafile:2: 1234',
+ pcall_err(command, 'lua number_error()')
+ )
+ eq('Vim(lua):E5108: Error executing lua [NULL]', pcall_err(command, 'lua nil_error()'))
+ eq('Vim(lua):E5108: Error executing lua [NULL]', pcall_err(command, 'lua table_error()'))
+ eq(
+ 'Vim(lua):E5108: Error executing lua Internal Error [11234] my mistake',
+ pcall_err(command, 'lua custom_error()')
+ )
+ eq('Vim(lua):E5108: Error executing lua [NULL]', pcall_err(command, 'lua bad_custom_error()'))
end)
it('prints strings with NULs and NLs correctly', function()
- meths.set_option_value('more', true, {})
- eq('abc ^@ def\nghi^@^@^@jkl\nTEST\n\n\nT\n',
- exec_capture([[lua print("abc \0 def\nghi\0\0\0jkl\nTEST\n\n\nT\n")]]))
- eq('abc ^@ def\nghi^@^@^@jkl\nTEST\n\n\nT^@',
- exec_capture([[lua print("abc \0 def\nghi\0\0\0jkl\nTEST\n\n\nT\0")]]))
+ api.nvim_set_option_value('more', true, {})
+ eq(
+ 'abc ^@ def\nghi^@^@^@jkl\nTEST\n\n\nT\n',
+ exec_capture([[lua print("abc \0 def\nghi\0\0\0jkl\nTEST\n\n\nT\n")]])
+ )
+ eq(
+ 'abc ^@ def\nghi^@^@^@jkl\nTEST\n\n\nT^@',
+ exec_capture([[lua print("abc \0 def\nghi\0\0\0jkl\nTEST\n\n\nT\0")]])
+ )
eq('T^@', exec_capture([[lua print("T\0")]]))
eq('T\n', exec_capture([[lua print("T\n")]]))
end)
@@ -114,7 +133,8 @@ describe('print', function()
eq('abc def', exec_capture('lua print("abc", "", "def")'))
end)
it('defers printing in luv event handlers', function()
- exec_lua([[
+ exec_lua(
+ [[
local cmd = ...
function test()
local timer = vim.uv.new_timer()
@@ -133,7 +153,9 @@ describe('print', function()
print("very slow")
vim.api.nvim_command("sleep 1m") -- force deferred event processing
end
- ]], (is_os('win') and "timeout 1") or "sleep 0.1")
+ ]],
+ (is_os('win') and 'timeout 1') or 'sleep 0.1'
+ )
eq('very slow\nvery fast', exec_capture('lua test()'))
end)
@@ -141,33 +163,34 @@ describe('print', function()
local screen = Screen.new(40, 8)
screen:attach()
screen:set_default_attr_ids({
- [0] = {bold = true, foreground=Screen.colors.Blue},
- [1] = {bold = true, foreground = Screen.colors.SeaGreen},
- [2] = {bold = true, reverse = true},
+ [0] = { bold = true, foreground = Screen.colors.Blue },
+ [1] = { bold = true, foreground = Screen.colors.SeaGreen },
+ [2] = { bold = true, reverse = true },
})
feed([[:lua print('\na')<CR>]])
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*3
{2: }|
|
a |
{1:Press ENTER or type command to continue}^ |
- ]]}
+ ]],
+ }
feed('<CR>')
feed([[:lua print('b\n\nc')<CR>]])
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*2
{2: }|
b |
|
c |
{1:Press ENTER or type command to continue}^ |
- ]]}
+ ]],
+ }
end)
end)
@@ -178,10 +201,10 @@ describe('debug.debug', function()
screen = Screen.new()
screen:attach()
screen:set_default_attr_ids {
- [0] = {bold=true, foreground=255};
- [1] = {bold = true, reverse = true};
- E = {foreground = Screen.colors.Grey100, background = Screen.colors.Red};
- cr = {bold = true, foreground = Screen.colors.SeaGreen4};
+ [0] = { bold = true, foreground = 255 },
+ [1] = { bold = true, reverse = true },
+ E = { foreground = Screen.colors.Grey100, background = Screen.colors.Red },
+ cr = { bold = true, foreground = Screen.colors.SeaGreen4 },
}
end)
@@ -194,33 +217,19 @@ describe('debug.debug', function()
end
]])
feed(':lua Test()\n')
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*10
{1: }|
nil |
lua_debug> ^ |
- ]]}
+ ]],
+ }
feed('print("TEST")\n')
screen:expect([[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*8
{1: }|
nil |
lua_debug> print("TEST") |
@@ -228,10 +237,10 @@ describe('debug.debug', function()
lua_debug> ^ |
]])
feed('<C-c>')
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*2
{1: }|
nil |
lua_debug> print("TEST") |
@@ -243,31 +252,21 @@ describe('debug.debug', function()
{E: [string ":lua"]:5: in function 'Test'} |
{E: [string ":lua"]:1: in main chunk} |
Interrupt: {cr:Press ENTER or type command to continue}^ |
- ]]}
+ ]],
+ }
feed('<C-l>:lua Test()\n')
screen:expect([[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*10
{1: }|
nil |
lua_debug> ^ |
]])
feed('\n')
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*4
{1: }|
nil |
lua_debug> |
@@ -277,56 +276,39 @@ describe('debug.debug', function()
{E: [string ":lua"]:5: in function 'Test'} |
{E: [string ":lua"]:1: in main chunk} |
{cr:Press ENTER or type command to continue}^ |
- ]]}
+ ]],
+ }
end)
it("can be safely exited with 'cont'", function()
feed('<cr>')
feed(':lua debug.debug() print("x")<cr>')
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*12
lua_debug> ^ |
- ]]}
+ ]],
+ }
- feed("conttt<cr>") -- misspelled cont; invalid syntax
- screen:expect{grid=[[
+ feed('conttt<cr>') -- misspelled cont; invalid syntax
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*8
{1: }|
lua_debug> conttt |
{E:E5115: Error while loading debug string: (debug comma}|
{E:nd):1: '=' expected near '<eof>'} |
lua_debug> ^ |
- ]]}
+ ]],
+ }
- feed("cont<cr>") -- exactly "cont", exit now
- screen:expect{grid=[[
+ feed('cont<cr>') -- exactly "cont", exit now
+ screen:expect {
+ grid = [[
|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*6
{1: }|
lua_debug> conttt |
{E:E5115: Error while loading debug string: (debug comma}|
@@ -334,41 +316,33 @@ describe('debug.debug', function()
lua_debug> cont |
x |
{cr:Press ENTER or type command to continue}^ |
- ]]}
+ ]],
+ }
feed('<cr>')
- screen:expect{grid=[[
+ screen:expect {
+ grid = [[
^ |
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
- {0:~ }|
+ {0:~ }|*12
|
- ]]}
+ ]],
+ }
end)
end)
describe('os.getenv', function()
it('returns nothing for undefined env var', function()
- eq(NIL, funcs.luaeval('os.getenv("XTEST_1")'))
+ eq(NIL, fn.luaeval('os.getenv("XTEST_1")'))
end)
it('returns env var set by the parent process', function()
local value = 'foo'
- clear({env = {['XTEST_1']=value}})
- eq(value, funcs.luaeval('os.getenv("XTEST_1")'))
+ clear({ env = { ['XTEST_1'] = value } })
+ eq(value, fn.luaeval('os.getenv("XTEST_1")'))
end)
it('returns env var set by let', function()
local value = 'foo'
- meths.command('let $XTEST_1 = "'..value..'"')
- eq(value, funcs.luaeval('os.getenv("XTEST_1")'))
+ command('let $XTEST_1 = "' .. value .. '"')
+ eq(value, fn.luaeval('os.getenv("XTEST_1")'))
end)
end)
@@ -376,6 +350,6 @@ end)
-- luajit or PUC lua 5.1.
describe('bit module', function()
it('works', function()
- eq (9, exec_lua [[ return require'bit'.band(11,13) ]])
+ eq(9, exec_lua [[ return require'bit'.band(11,13) ]])
end)
end)