xref: /vim-8.2.3635/src/testdir/test_lua.vim (revision f65ed86f)
1d58f03b1SBram Moolenaar" Tests for Lua.
2d58f03b1SBram Moolenaar
3b46fecd3SBram Moolenaarsource check.vim
4c8970b94SBram Moolenaar
5c8970b94SBram Moolenaar" This test also works without the lua feature.
6c8970b94SBram Moolenaarfunc Test_skip_lua()
7c8970b94SBram Moolenaar  if 0
8c8970b94SBram Moolenaar    lua print("Not executed")
9c8970b94SBram Moolenaar  endif
10c8970b94SBram Moolenaarendfunc
11c8970b94SBram Moolenaar
12b46fecd3SBram MoolenaarCheckFeature lua
135feabe00SBram MoolenaarCheckFeature float
14d58f03b1SBram Moolenaar
15*f65ed86fSBram Moolenaar" Depending on the lua version, the error messages are different.
16*f65ed86fSBram Moolenaarlet s:luaver = split(split(systemlist('lua -v')[0], ' ')[1], '\.')
17e49b8e8dSBram Moolenaarlet s:major = str2nr(s:luaver[0])
18e49b8e8dSBram Moolenaarlet s:minor = str2nr(s:luaver[1])
19*f65ed86fSBram Moolenaarlet s:patch = str2nr(s:luaver[2])
20e49b8e8dSBram Moolenaarlet s:lua_53_or_later = 0
21*f65ed86fSBram Moolenaarlet s:lua_543_or_later = 0
22*f65ed86fSBram Moolenaarif (s:major == 5 && s:minor >= 3) || s:major > 5
23e49b8e8dSBram Moolenaar  let s:lua_53_or_later = 1
24*f65ed86fSBram Moolenaar  if (s:major == 5
25*f65ed86fSBram Moolenaar        \ && ((s:minor == 4 && s:patch >= 3) || s:minor > 4))
26*f65ed86fSBram Moolenaar        \ || s:major > 5
27*f65ed86fSBram Moolenaar    let s:lua_543_or_later = 1
28*f65ed86fSBram Moolenaar  endif
29e49b8e8dSBram Moolenaarendif
30e49b8e8dSBram Moolenaar
31e165f635SBram Moolenaarfunc TearDown()
32e165f635SBram Moolenaar  " Run garbage collection after each test to exercise luaV_setref().
33e165f635SBram Moolenaar  call test_garbagecollect_now()
34e165f635SBram Moolenaarendfunc
35e165f635SBram Moolenaar
364ff4814bSBram Moolenaar" Check that switching to another buffer does not trigger ml_get error.
375feabe00SBram Moolenaarfunc Test_lua_command_new_no_ml_get_error()
38d58f03b1SBram Moolenaar  new
39d58f03b1SBram Moolenaar  let wincount = winnr('$')
40d58f03b1SBram Moolenaar  call setline(1, ['one', 'two', 'three'])
41d58f03b1SBram Moolenaar  luado vim.command("new")
42d58f03b1SBram Moolenaar  call assert_equal(wincount + 1, winnr('$'))
434ff4814bSBram Moolenaar  %bwipe!
444ff4814bSBram Moolenaarendfunc
454ff4814bSBram Moolenaar
464ff4814bSBram Moolenaar" Test vim.command()
475feabe00SBram Moolenaarfunc Test_lua_command()
484ff4814bSBram Moolenaar  new
494ff4814bSBram Moolenaar  call setline(1, ['one', 'two', 'three'])
504ff4814bSBram Moolenaar  luado vim.command("1,2d_")
514ff4814bSBram Moolenaar  call assert_equal(['three'], getline(1, '$'))
52d58f03b1SBram Moolenaar  bwipe!
534ff4814bSBram Moolenaarendfunc
544ff4814bSBram Moolenaar
55e49b8e8dSBram Moolenaarfunc Test_lua_luado()
56e49b8e8dSBram Moolenaar  new
57e49b8e8dSBram Moolenaar  call setline(1, ['one', 'two'])
58e49b8e8dSBram Moolenaar  luado return(linenr)
59e49b8e8dSBram Moolenaar  call assert_equal(['1', '2'], getline(1, '$'))
60e49b8e8dSBram Moolenaar  close!
61e49b8e8dSBram Moolenaar
62e49b8e8dSBram Moolenaar  " Error cases
63e49b8e8dSBram Moolenaar  call assert_fails('luado string.format()',
64e49b8e8dSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'format' (string expected, got no value)")
65*f65ed86fSBram Moolenaar  if s:lua_543_or_later
66*f65ed86fSBram Moolenaar    let msg = "[string \"vim chunk\"]:1: global 'func' is not callable (a nil value)"
67*f65ed86fSBram Moolenaar  elseif s:lua_53_or_later
68*f65ed86fSBram Moolenaar    let msg = "[string \"vim chunk\"]:1: attempt to call a nil value (global 'func')"
69*f65ed86fSBram Moolenaar  else
70*f65ed86fSBram Moolenaar    let msg = "[string \"vim chunk\"]:1: attempt to call global 'func' (a nil value)"
71*f65ed86fSBram Moolenaar  endif
72*f65ed86fSBram Moolenaar  call assert_fails('luado func()', msg)
73e49b8e8dSBram Moolenaar  call assert_fails('luado error("failed")', "[string \"vim chunk\"]:1: failed")
74e49b8e8dSBram Moolenaarendfunc
75e49b8e8dSBram Moolenaar
764ff4814bSBram Moolenaar" Test vim.eval()
775feabe00SBram Moolenaarfunc Test_lua_eval()
784ff4814bSBram Moolenaar  " lua.eval with a number
794ff4814bSBram Moolenaar  lua v = vim.eval('123')
804ff4814bSBram Moolenaar  call assert_equal('number', luaeval('vim.type(v)'))
81eb04f089SBram Moolenaar  call assert_equal(123, luaeval('v'))
824ff4814bSBram Moolenaar
834ff4814bSBram Moolenaar  " lua.eval with a string
844ff4814bSBram Moolenaar  lua v = vim.eval('"abc"')
8502b31110SBram Moolenaar  call assert_equal('string', 'vim.type(v)'->luaeval())
864ff4814bSBram Moolenaar  call assert_equal('abc', luaeval('v'))
874ff4814bSBram Moolenaar
884ff4814bSBram Moolenaar  " lua.eval with a list
894ff4814bSBram Moolenaar  lua v = vim.eval("['a']")
904ff4814bSBram Moolenaar  call assert_equal('list', luaeval('vim.type(v)'))
914ff4814bSBram Moolenaar  call assert_equal(['a'], luaeval('v'))
924ff4814bSBram Moolenaar
934ff4814bSBram Moolenaar  " lua.eval with a dict
944ff4814bSBram Moolenaar  lua v = vim.eval("{'a':'b'}")
954ff4814bSBram Moolenaar  call assert_equal('dict', luaeval('vim.type(v)'))
964ff4814bSBram Moolenaar  call assert_equal({'a':'b'}, luaeval('v'))
974ff4814bSBram Moolenaar
98b7828690SBram Moolenaar  " lua.eval with a blob
99b7828690SBram Moolenaar  lua v = vim.eval("0z00112233.deadbeef")
100b7828690SBram Moolenaar  call assert_equal('blob', luaeval('vim.type(v)'))
101b7828690SBram Moolenaar  call assert_equal(0z00112233.deadbeef, luaeval('v'))
102b7828690SBram Moolenaar
103e49b8e8dSBram Moolenaar  " lua.eval with a float
104e49b8e8dSBram Moolenaar  lua v = vim.eval('3.14')
105e49b8e8dSBram Moolenaar  call assert_equal('number', luaeval('vim.type(v)'))
106e49b8e8dSBram Moolenaar  call assert_equal(3.14, luaeval('v'))
107e49b8e8dSBram Moolenaar
108e49b8e8dSBram Moolenaar  " lua.eval with a bool
109e49b8e8dSBram Moolenaar  lua v = vim.eval('v:true')
110e49b8e8dSBram Moolenaar  call assert_equal('number', luaeval('vim.type(v)'))
111e49b8e8dSBram Moolenaar  call assert_equal(1, luaeval('v'))
112e49b8e8dSBram Moolenaar  lua v = vim.eval('v:false')
113e49b8e8dSBram Moolenaar  call assert_equal('number', luaeval('vim.type(v)'))
114e49b8e8dSBram Moolenaar  call assert_equal(0, luaeval('v'))
115e49b8e8dSBram Moolenaar
116e49b8e8dSBram Moolenaar  " lua.eval with a null
117e49b8e8dSBram Moolenaar  lua v = vim.eval('v:null')
118e49b8e8dSBram Moolenaar  call assert_equal('nil', luaeval('vim.type(v)'))
119e49b8e8dSBram Moolenaar  call assert_equal(v:null, luaeval('v'))
120e49b8e8dSBram Moolenaar
1214ff4814bSBram Moolenaar  call assert_fails('lua v = vim.eval(nil)',
1224ff4814bSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'eval' (string expected, got nil)")
1234ff4814bSBram Moolenaar  call assert_fails('lua v = vim.eval(true)',
1244ff4814bSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'eval' (string expected, got boolean)")
1254ff4814bSBram Moolenaar  call assert_fails('lua v = vim.eval({})',
1264ff4814bSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'eval' (string expected, got table)")
1274ff4814bSBram Moolenaar  call assert_fails('lua v = vim.eval(print)',
1284ff4814bSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'eval' (string expected, got function)")
1294ff4814bSBram Moolenaar  call assert_fails('lua v = vim.eval(vim.buffer())',
1304ff4814bSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'eval' (string expected, got userdata)")
1314ff4814bSBram Moolenaar
1324ff4814bSBram Moolenaar  lua v = nil
1334ff4814bSBram Moolenaarendfunc
1344ff4814bSBram Moolenaar
13586c3a216SBram Moolenaar" Test luaeval() with lambda
13686c3a216SBram Moolenaarfunc Test_luaeval_with_lambda()
13786c3a216SBram Moolenaar  lua function hello_luaeval_lambda(a, cb) return a .. cb() end
13886c3a216SBram Moolenaar  call assert_equal('helloworld',
13986c3a216SBram Moolenaar        \ luaeval('hello_luaeval_lambda(_A[1], _A[2])',
14086c3a216SBram Moolenaar        \         ['hello', {->'world'}]))
14186c3a216SBram Moolenaar  lua hello_luaeval_lambda = nil
14286c3a216SBram Moolenaarendfunc
14386c3a216SBram Moolenaar
1444ff4814bSBram Moolenaar" Test vim.window()
1455feabe00SBram Moolenaarfunc Test_lua_window()
1464ff4814bSBram Moolenaar  e Xfoo2
1474ff4814bSBram Moolenaar  new Xfoo1
1484ff4814bSBram Moolenaar
1494ff4814bSBram Moolenaar  " Window 1 (top window) contains Xfoo1
1504ff4814bSBram Moolenaar  " Window 2 (bottom window) contains Xfoo2
1514ff4814bSBram Moolenaar  call assert_equal('Xfoo1', luaeval('vim.window(1):buffer().name'))
1524ff4814bSBram Moolenaar  call assert_equal('Xfoo2', luaeval('vim.window(2):buffer().name'))
1534ff4814bSBram Moolenaar
1544ff4814bSBram Moolenaar  " Window 3 does not exist so vim.window(3) should return nil
1554ff4814bSBram Moolenaar  call assert_equal('nil', luaeval('tostring(vim.window(3))'))
1564ff4814bSBram Moolenaar
157*f65ed86fSBram Moolenaar  if s:lua_543_or_later
158*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: field 'xyz' is not callable (a nil value)"
159*f65ed86fSBram Moolenaar  elseif s:lua_53_or_later
160*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: attempt to call a nil value (field 'xyz')"
161*f65ed86fSBram Moolenaar  else
162*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: attempt to call field 'xyz' (a nil value)"
163*f65ed86fSBram Moolenaar  endif
164*f65ed86fSBram Moolenaar  call assert_fails("let n = luaeval('vim.window().xyz()')", msg)
165e49b8e8dSBram Moolenaar  call assert_fails('lua vim.window().xyz = 1',
166e49b8e8dSBram Moolenaar        \ "[string \"vim chunk\"]:1: invalid window property: `xyz'")
167e49b8e8dSBram Moolenaar
1684ff4814bSBram Moolenaar  %bwipe!
1694ff4814bSBram Moolenaarendfunc
1704ff4814bSBram Moolenaar
1714ff4814bSBram Moolenaar" Test vim.window().height
1725feabe00SBram Moolenaarfunc Test_lua_window_height()
1734ff4814bSBram Moolenaar  new
1744ff4814bSBram Moolenaar  lua vim.window().height = 2
1754ff4814bSBram Moolenaar  call assert_equal(2, winheight(0))
1764ff4814bSBram Moolenaar  lua vim.window().height = vim.window().height + 1
1774ff4814bSBram Moolenaar  call assert_equal(3, winheight(0))
1784ff4814bSBram Moolenaar  bwipe!
1794ff4814bSBram Moolenaarendfunc
1804ff4814bSBram Moolenaar
1814ff4814bSBram Moolenaar" Test vim.window().width
1825feabe00SBram Moolenaarfunc Test_lua_window_width()
1834ff4814bSBram Moolenaar  vert new
1844ff4814bSBram Moolenaar  lua vim.window().width = 2
1854ff4814bSBram Moolenaar  call assert_equal(2, winwidth(0))
1864ff4814bSBram Moolenaar  lua vim.window().width = vim.window().width + 1
1874ff4814bSBram Moolenaar  call assert_equal(3, winwidth(0))
1884ff4814bSBram Moolenaar  bwipe!
1894ff4814bSBram Moolenaarendfunc
1904ff4814bSBram Moolenaar
1914ff4814bSBram Moolenaar" Test vim.window().line and vim.window.col
1925feabe00SBram Moolenaarfunc Test_lua_window_line_col()
1934ff4814bSBram Moolenaar  new
1944ff4814bSBram Moolenaar  call setline(1, ['line1', 'line2', 'line3'])
1954ff4814bSBram Moolenaar  lua vim.window().line = 2
1964ff4814bSBram Moolenaar  lua vim.window().col = 4
1974ff4814bSBram Moolenaar  call assert_equal([0, 2, 4, 0], getpos('.'))
1984ff4814bSBram Moolenaar  lua vim.window().line = vim.window().line + 1
1994ff4814bSBram Moolenaar  lua vim.window().col = vim.window().col - 1
2004ff4814bSBram Moolenaar  call assert_equal([0, 3, 3, 0], getpos('.'))
2014ff4814bSBram Moolenaar
2024ff4814bSBram Moolenaar  call assert_fails('lua vim.window().line = 10',
2034ff4814bSBram Moolenaar        \           '[string "vim chunk"]:1: line out of range')
2044ff4814bSBram Moolenaar  bwipe!
2054ff4814bSBram Moolenaarendfunc
2064ff4814bSBram Moolenaar
207eb04f089SBram Moolenaar" Test vim.call
208eb04f089SBram Moolenaarfunc Test_lua_call()
209eb04f089SBram Moolenaar  call assert_equal(has('lua'), luaeval('vim.call("has", "lua")'))
210eb04f089SBram Moolenaar  call assert_equal(printf("Hello %s", "vim"), luaeval('vim.call("printf", "Hello %s", "vim")'))
211e49b8e8dSBram Moolenaar
212e49b8e8dSBram Moolenaar  " Error cases
213e49b8e8dSBram Moolenaar  call assert_fails("call luaeval('vim.call(\"min\", 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21)')",
214b898a029SBram Moolenaar        \ s:lua_53_or_later
215b898a029SBram Moolenaar        \ ? '[string "luaeval"]:1: Function called with too many arguments'
216b898a029SBram Moolenaar        \ : 'Function called with too many arguments')
217e49b8e8dSBram Moolenaar  lua co = coroutine.create(function () print("hi") end)
218e49b8e8dSBram Moolenaar  call assert_fails("call luaeval('vim.call(\"type\", co)')",
219b898a029SBram Moolenaar        \ s:lua_53_or_later
220b898a029SBram Moolenaar        \ ? '[string "luaeval"]:1: lua: cannot convert value'
221b898a029SBram Moolenaar        \ : 'lua: cannot convert value')
222e49b8e8dSBram Moolenaar  lua co = nil
223b898a029SBram Moolenaar  call assert_fails("call luaeval('vim.call(\"abc\")')",
224b898a029SBram Moolenaar        \ ['E117:', s:lua_53_or_later ? '\[string "luaeval"]:1: lua: call_vim_function failed'
225b898a029SBram Moolenaar        \                             : 'lua: call_vim_function failed'])
226eb04f089SBram Moolenaarendfunc
227eb04f089SBram Moolenaar
228eb04f089SBram Moolenaar" Test vim.fn.*
229eb04f089SBram Moolenaarfunc Test_lua_fn()
230eb04f089SBram Moolenaar  call assert_equal(has('lua'), luaeval('vim.fn.has("lua")'))
231eb04f089SBram Moolenaar  call assert_equal(printf("Hello %s", "vim"), luaeval('vim.fn.printf("Hello %s", "vim")'))
232eb04f089SBram Moolenaarendfunc
233eb04f089SBram Moolenaar
2344ff4814bSBram Moolenaar" Test setting the current window
2355feabe00SBram Moolenaarfunc Test_lua_window_set_current()
2364ff4814bSBram Moolenaar  new Xfoo1
2374ff4814bSBram Moolenaar  lua w1 = vim.window()
2384ff4814bSBram Moolenaar  new Xfoo2
2394ff4814bSBram Moolenaar  lua w2 = vim.window()
2404ff4814bSBram Moolenaar
2414ff4814bSBram Moolenaar  call assert_equal('Xfoo2', bufname('%'))
2424ff4814bSBram Moolenaar  lua w1()
2434ff4814bSBram Moolenaar  call assert_equal('Xfoo1', bufname('%'))
2444ff4814bSBram Moolenaar  lua w2()
2454ff4814bSBram Moolenaar  call assert_equal('Xfoo2', bufname('%'))
2464ff4814bSBram Moolenaar
2472f362bf7SBram Moolenaar  lua w1, w2 = nil
2484ff4814bSBram Moolenaar  %bwipe!
2494ff4814bSBram Moolenaarendfunc
2504ff4814bSBram Moolenaar
2514ff4814bSBram Moolenaar" Test vim.window().buffer
2525feabe00SBram Moolenaarfunc Test_lua_window_buffer()
2534ff4814bSBram Moolenaar  new Xfoo1
2544ff4814bSBram Moolenaar  lua w1 = vim.window()
2554ff4814bSBram Moolenaar  lua b1 = w1.buffer()
2564ff4814bSBram Moolenaar  new Xfoo2
2574ff4814bSBram Moolenaar  lua w2 = vim.window()
2584ff4814bSBram Moolenaar  lua b2 = w2.buffer()
2594ff4814bSBram Moolenaar
2604ff4814bSBram Moolenaar  lua b1()
2614ff4814bSBram Moolenaar  call assert_equal('Xfoo1', bufname('%'))
2624ff4814bSBram Moolenaar  lua b2()
2634ff4814bSBram Moolenaar  call assert_equal('Xfoo2', bufname('%'))
2644ff4814bSBram Moolenaar
2652f362bf7SBram Moolenaar  lua b1, b2, w1, w2 = nil
2664ff4814bSBram Moolenaar  %bwipe!
2674ff4814bSBram Moolenaarendfunc
2684ff4814bSBram Moolenaar
2694ff4814bSBram Moolenaar" Test vim.window():previous() and vim.window():next()
2705feabe00SBram Moolenaarfunc Test_lua_window_next_previous()
2714ff4814bSBram Moolenaar  new Xfoo1
2724ff4814bSBram Moolenaar  new Xfoo2
2734ff4814bSBram Moolenaar  new Xfoo3
2744ff4814bSBram Moolenaar  wincmd j
2754ff4814bSBram Moolenaar
2764ff4814bSBram Moolenaar  call assert_equal('Xfoo2', luaeval('vim.window().buffer().name'))
2774ff4814bSBram Moolenaar  call assert_equal('Xfoo1', luaeval('vim.window():next():buffer().name'))
2784ff4814bSBram Moolenaar  call assert_equal('Xfoo3', luaeval('vim.window():previous():buffer().name'))
2794ff4814bSBram Moolenaar
2804ff4814bSBram Moolenaar  %bwipe!
2814ff4814bSBram Moolenaarendfunc
2824ff4814bSBram Moolenaar
2834ff4814bSBram Moolenaar" Test vim.window():isvalid()
2845feabe00SBram Moolenaarfunc Test_lua_window_isvalid()
2854ff4814bSBram Moolenaar  new Xfoo
2864ff4814bSBram Moolenaar  lua w = vim.window()
2874ff4814bSBram Moolenaar  call assert_true(luaeval('w:isvalid()'))
2884ff4814bSBram Moolenaar
2894ff4814bSBram Moolenaar  " FIXME: how to test the case when isvalid() returns v:false?
2904ff4814bSBram Moolenaar  " isvalid() gives errors when the window is deleted. Is it a bug?
2914ff4814bSBram Moolenaar
2924ff4814bSBram Moolenaar  lua w = nil
2934ff4814bSBram Moolenaar  bwipe!
2944ff4814bSBram Moolenaarendfunc
2954ff4814bSBram Moolenaar
2964ff4814bSBram Moolenaar" Test vim.buffer() with and without argument
2975feabe00SBram Moolenaarfunc Test_lua_buffer()
2984ff4814bSBram Moolenaar  new Xfoo1
2994ff4814bSBram Moolenaar  let bn1 = bufnr('%')
3004ff4814bSBram Moolenaar  new Xfoo2
3014ff4814bSBram Moolenaar  let bn2 = bufnr('%')
3024ff4814bSBram Moolenaar
3034ff4814bSBram Moolenaar  " Test vim.buffer() without argument.
3044ff4814bSBram Moolenaar  call assert_equal('Xfoo2', luaeval("vim.buffer().name"))
3054ff4814bSBram Moolenaar
3064ff4814bSBram Moolenaar  " Test vim.buffer() with string argument.
3074ff4814bSBram Moolenaar  call assert_equal('Xfoo1', luaeval("vim.buffer('Xfoo1').name"))
3084ff4814bSBram Moolenaar  call assert_equal('Xfoo2', luaeval("vim.buffer('Xfoo2').name"))
3094ff4814bSBram Moolenaar
3104ff4814bSBram Moolenaar  " Test vim.buffer() with integer argument.
3114ff4814bSBram Moolenaar  call assert_equal('Xfoo1', luaeval("vim.buffer(" . bn1 . ").name"))
3124ff4814bSBram Moolenaar  call assert_equal('Xfoo2', luaeval("vim.buffer(" . bn2 . ").name"))
3134ff4814bSBram Moolenaar
3142f362bf7SBram Moolenaar  lua bn1, bn2 = nil
3154ff4814bSBram Moolenaar  %bwipe!
3164ff4814bSBram Moolenaarendfunc
3174ff4814bSBram Moolenaar
3184ff4814bSBram Moolenaar" Test vim.buffer().name and vim.buffer().fname
3195feabe00SBram Moolenaarfunc Test_lua_buffer_name()
3204ff4814bSBram Moolenaar  new
321fe08df45SBram Moolenaar  call assert_equal('', luaeval('vim.buffer().name'))
322fe08df45SBram Moolenaar  call assert_equal('', luaeval('vim.buffer().fname'))
3234ff4814bSBram Moolenaar  bwipe!
3244ff4814bSBram Moolenaar
3254ff4814bSBram Moolenaar  new Xfoo
3264ff4814bSBram Moolenaar  call assert_equal('Xfoo', luaeval('vim.buffer().name'))
3274ff4814bSBram Moolenaar  call assert_equal(expand('%:p'), luaeval('vim.buffer().fname'))
3284ff4814bSBram Moolenaar  bwipe!
3294ff4814bSBram Moolenaarendfunc
3304ff4814bSBram Moolenaar
3314ff4814bSBram Moolenaar" Test vim.buffer().number
3325feabe00SBram Moolenaarfunc Test_lua_buffer_number()
3334ff4814bSBram Moolenaar  " All numbers in Lua are floating points number (no integers).
3344ff4814bSBram Moolenaar  call assert_equal(bufnr('%'), float2nr(luaeval('vim.buffer().number')))
3354ff4814bSBram Moolenaarendfunc
3364ff4814bSBram Moolenaar
3374ff4814bSBram Moolenaar" Test inserting lines in buffer.
3385feabe00SBram Moolenaarfunc Test_lua_buffer_insert()
3394ff4814bSBram Moolenaar  new
3404ff4814bSBram Moolenaar  lua vim.buffer()[1] = '3'
3414ff4814bSBram Moolenaar  lua vim.buffer():insert('1', 0)
3424ff4814bSBram Moolenaar  lua vim.buffer():insert('2', 1)
3434ff4814bSBram Moolenaar  lua vim.buffer():insert('4', 10)
3444ff4814bSBram Moolenaar
3454ff4814bSBram Moolenaar  call assert_equal(['1', '2', '3', '4'], getline(1, '$'))
346e49b8e8dSBram Moolenaar  call assert_equal('4', luaeval('vim.buffer()[4]'))
347e49b8e8dSBram Moolenaar  call assert_equal(v:null, luaeval('vim.buffer()[5]'))
348e49b8e8dSBram Moolenaar  call assert_equal(v:null, luaeval('vim.buffer()[{}]'))
349*f65ed86fSBram Moolenaar  if s:lua_543_or_later
350*f65ed86fSBram Moolenaar    let msg = "[string \"vim chunk\"]:1: method 'xyz' is not callable (a nil value)"
351*f65ed86fSBram Moolenaar  elseif s:lua_53_or_later
352*f65ed86fSBram Moolenaar    let msg = "[string \"vim chunk\"]:1: attempt to call a nil value (method 'xyz')"
353*f65ed86fSBram Moolenaar  else
354*f65ed86fSBram Moolenaar    let msg = "[string \"vim chunk\"]:1: attempt to call method 'xyz' (a nil value)"
355*f65ed86fSBram Moolenaar  endif
356*f65ed86fSBram Moolenaar  call assert_fails('lua vim.buffer():xyz()', msg)
357e49b8e8dSBram Moolenaar  call assert_fails('lua vim.buffer()[1] = {}',
358e49b8e8dSBram Moolenaar        \ '[string "vim chunk"]:1: wrong argument to change')
3594ff4814bSBram Moolenaar  bwipe!
3604ff4814bSBram Moolenaarendfunc
3614ff4814bSBram Moolenaar
3624ff4814bSBram Moolenaar" Test deleting line in buffer
3635feabe00SBram Moolenaarfunc Test_lua_buffer_delete()
3644ff4814bSBram Moolenaar  new
3654ff4814bSBram Moolenaar  call setline(1, ['1', '2', '3'])
366e49b8e8dSBram Moolenaar  call cursor(3, 1)
3674ff4814bSBram Moolenaar  lua vim.buffer()[2] = nil
3684ff4814bSBram Moolenaar  call assert_equal(['1', '3'], getline(1, '$'))
3694ff4814bSBram Moolenaar
3704ff4814bSBram Moolenaar  call assert_fails('lua vim.buffer()[3] = nil',
3714ff4814bSBram Moolenaar        \           '[string "vim chunk"]:1: invalid line number')
3724ff4814bSBram Moolenaar  bwipe!
3734ff4814bSBram Moolenaarendfunc
3744ff4814bSBram Moolenaar
3754ff4814bSBram Moolenaar" Test #vim.buffer() i.e. number of lines in buffer
3765feabe00SBram Moolenaarfunc Test_lua_buffer_number_lines()
3774ff4814bSBram Moolenaar  new
3784ff4814bSBram Moolenaar  call setline(1, ['a', 'b', 'c'])
379eb04f089SBram Moolenaar  call assert_equal(3, luaeval('#vim.buffer()'))
3804ff4814bSBram Moolenaar  bwipe!
3814ff4814bSBram Moolenaarendfunc
3824ff4814bSBram Moolenaar
3834ff4814bSBram Moolenaar" Test vim.buffer():next() and vim.buffer():previous()
3844ff4814bSBram Moolenaar" Note that these functions get the next or previous buffers
3854ff4814bSBram Moolenaar" but do not switch buffer.
3865feabe00SBram Moolenaarfunc Test_lua_buffer_next_previous()
3874ff4814bSBram Moolenaar  new Xfoo1
3884ff4814bSBram Moolenaar  new Xfoo2
3894ff4814bSBram Moolenaar  new Xfoo3
3904ff4814bSBram Moolenaar  b Xfoo2
3914ff4814bSBram Moolenaar
3924ff4814bSBram Moolenaar  lua bn = vim.buffer():next()
3934ff4814bSBram Moolenaar  lua bp = vim.buffer():previous()
3944ff4814bSBram Moolenaar
3954ff4814bSBram Moolenaar  call assert_equal('Xfoo2', luaeval('vim.buffer().name'))
3964ff4814bSBram Moolenaar  call assert_equal('Xfoo1', luaeval('bp.name'))
3974ff4814bSBram Moolenaar  call assert_equal('Xfoo3', luaeval('bn.name'))
3984ff4814bSBram Moolenaar
3994ff4814bSBram Moolenaar  call assert_equal('Xfoo2', bufname('%'))
4004ff4814bSBram Moolenaar
4014ff4814bSBram Moolenaar  lua bn()
4024ff4814bSBram Moolenaar  call assert_equal('Xfoo3', luaeval('vim.buffer().name'))
4034ff4814bSBram Moolenaar  call assert_equal('Xfoo3', bufname('%'))
4044ff4814bSBram Moolenaar
4054ff4814bSBram Moolenaar  lua bp()
4064ff4814bSBram Moolenaar  call assert_equal('Xfoo1', luaeval('vim.buffer().name'))
4074ff4814bSBram Moolenaar  call assert_equal('Xfoo1', bufname('%'))
4084ff4814bSBram Moolenaar
4092f362bf7SBram Moolenaar  lua bn, bp = nil
4104ff4814bSBram Moolenaar  %bwipe!
4114ff4814bSBram Moolenaarendfunc
4124ff4814bSBram Moolenaar
4134ff4814bSBram Moolenaar" Test vim.buffer():isvalid()
4145feabe00SBram Moolenaarfunc Test_lua_buffer_isvalid()
4154ff4814bSBram Moolenaar  new Xfoo
4164ff4814bSBram Moolenaar  lua b = vim.buffer()
4174ff4814bSBram Moolenaar  call assert_true(luaeval('b:isvalid()'))
4184ff4814bSBram Moolenaar
4194ff4814bSBram Moolenaar  " FIXME: how to test the case when isvalid() returns v:false?
4204ff4814bSBram Moolenaar  " isvalid() gives errors when the buffer is wiped. Is it a bug?
4214ff4814bSBram Moolenaar
4224ff4814bSBram Moolenaar  lua b = nil
4234ff4814bSBram Moolenaar  bwipe!
4244ff4814bSBram Moolenaarendfunc
4254ff4814bSBram Moolenaar
4265feabe00SBram Moolenaarfunc Test_lua_list()
4274ff4814bSBram Moolenaar  call assert_equal([], luaeval('vim.list()'))
4284ff4814bSBram Moolenaar
4294ff4814bSBram Moolenaar  let l = []
4304ff4814bSBram Moolenaar  lua l = vim.eval('l')
4314ff4814bSBram Moolenaar  lua l:add(123)
4324ff4814bSBram Moolenaar  lua l:add('abc')
4334ff4814bSBram Moolenaar  lua l:add(true)
4344ff4814bSBram Moolenaar  lua l:add(false)
4359067cd6cSBram Moolenaar  lua l:add(nil)
4364ff4814bSBram Moolenaar  lua l:add(vim.eval("[1, 2, 3]"))
4374ff4814bSBram Moolenaar  lua l:add(vim.eval("{'a':1, 'b':2, 'c':3}"))
438eb04f089SBram Moolenaar  call assert_equal([123, 'abc', v:true, v:false, v:null, [1, 2, 3], {'a': 1, 'b': 2, 'c': 3}], l)
439eb04f089SBram Moolenaar  call assert_equal(7, luaeval('#l'))
440a8a60d0cSBram Moolenaar  call assert_match('^list: \%(0x\)\?\x\+$', luaeval('tostring(l)'))
4414ff4814bSBram Moolenaar
442bd84617dSBram Moolenaar  lua l[1] = 124
443bd84617dSBram Moolenaar  lua l[6] = nil
4444ff4814bSBram Moolenaar  lua l:insert('first')
4454ff4814bSBram Moolenaar  lua l:insert('xx', 3)
446e49b8e8dSBram Moolenaar  call assert_fails('lua l:insert("xx", -20)',
447e49b8e8dSBram Moolenaar        \ '[string "vim chunk"]:1: invalid position')
448eb04f089SBram Moolenaar  call assert_equal(['first', 124, 'abc', 'xx', v:true, v:false, v:null, {'a': 1, 'b': 2, 'c': 3}], l)
4494ff4814bSBram Moolenaar
4502f362bf7SBram Moolenaar  lockvar 1 l
4512f362bf7SBram Moolenaar  call assert_fails('lua l:add("x")', '[string "vim chunk"]:1: list is locked')
452e49b8e8dSBram Moolenaar  call assert_fails('lua l:insert(2)', '[string "vim chunk"]:1: list is locked')
453e49b8e8dSBram Moolenaar  call assert_fails('lua l[9] = 1', '[string "vim chunk"]:1: list is locked')
454e49b8e8dSBram Moolenaar
455e49b8e8dSBram Moolenaar  unlockvar l
456e49b8e8dSBram Moolenaar  let l = [1, 2]
457e49b8e8dSBram Moolenaar  lua ll = vim.eval('l')
458e49b8e8dSBram Moolenaar  let x = luaeval("ll[3]")
459e49b8e8dSBram Moolenaar  call assert_equal(v:null, x)
460*f65ed86fSBram Moolenaar  if s:lua_543_or_later
461*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: method 'xyz' is not callable (a nil value)"
462*f65ed86fSBram Moolenaar  elseif s:lua_53_or_later
463*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: attempt to call a nil value (method 'xyz')"
464*f65ed86fSBram Moolenaar  else
465*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: attempt to call method 'xyz' (a nil value)"
466*f65ed86fSBram Moolenaar  endif
467*f65ed86fSBram Moolenaar  call assert_fails('let x = luaeval("ll:xyz(3)")', msg)
468e49b8e8dSBram Moolenaar  let y = luaeval("ll[{}]")
469e49b8e8dSBram Moolenaar  call assert_equal(v:null, y)
4702f362bf7SBram Moolenaar
4714ff4814bSBram Moolenaar  lua l = nil
4724ff4814bSBram Moolenaarendfunc
4734ff4814bSBram Moolenaar
4745feabe00SBram Moolenaarfunc Test_lua_list_table()
4752f362bf7SBram Moolenaar  " See :help lua-vim
4762f362bf7SBram Moolenaar  " Non-numeric keys should not be used to initialize the list
4772f362bf7SBram Moolenaar  " so say = 'hi' should be ignored.
4782f362bf7SBram Moolenaar  lua t = {3.14, 'hello', false, true, say = 'hi'}
4792f362bf7SBram Moolenaar  call assert_equal([3.14, 'hello', v:false, v:true], luaeval('vim.list(t)'))
4802f362bf7SBram Moolenaar  lua t = nil
4812f362bf7SBram Moolenaar
4822f362bf7SBram Moolenaar  call assert_fails('lua vim.list(1)', '[string "vim chunk"]:1: table expected, got number')
4832f362bf7SBram Moolenaar  call assert_fails('lua vim.list("x")', '[string "vim chunk"]:1: table expected, got string')
4842f362bf7SBram Moolenaar  call assert_fails('lua vim.list(print)', '[string "vim chunk"]:1: table expected, got function')
4852f362bf7SBram Moolenaar  call assert_fails('lua vim.list(true)', '[string "vim chunk"]:1: table expected, got boolean')
4862f362bf7SBram Moolenaarendfunc
4872f362bf7SBram Moolenaar
488a1f9f866SBram Moolenaarfunc Test_lua_list_table_insert_remove()
489e49b8e8dSBram Moolenaar  if !s:lua_53_or_later
490a1f9f866SBram Moolenaar    throw 'Skipped: Lua version < 5.3'
491a1f9f866SBram Moolenaar  endif
492a1f9f866SBram Moolenaar
493a1f9f866SBram Moolenaar  let l = [1, 2]
494a1f9f866SBram Moolenaar  lua t = vim.eval('l')
495a1f9f866SBram Moolenaar  lua table.insert(t, 10)
496a1f9f866SBram Moolenaar  lua t[#t + 1] = 20
497a1f9f866SBram Moolenaar  lua table.insert(t, 2, 30)
498a1f9f866SBram Moolenaar  call assert_equal(l, [1, 30, 2, 10, 20])
499a1f9f866SBram Moolenaar  lua table.remove(t, 2)
500a1f9f866SBram Moolenaar  call assert_equal(l, [1, 2, 10, 20])
501a1f9f866SBram Moolenaar  lua t[3] = nil
502a1f9f866SBram Moolenaar  call assert_equal(l, [1, 2, 20])
503a1f9f866SBram Moolenaar  lua removed_value = table.remove(t, 3)
504a1f9f866SBram Moolenaar  call assert_equal(luaeval('removed_value'), 20)
505a1f9f866SBram Moolenaar  lua t = nil
506a1f9f866SBram Moolenaar  lua removed_value = nil
507a1f9f866SBram Moolenaar  unlet l
508a1f9f866SBram Moolenaarendfunc
509a1f9f866SBram Moolenaar
5104ff4814bSBram Moolenaar" Test l() i.e. iterator on list
5115feabe00SBram Moolenaarfunc Test_lua_list_iter()
5124ff4814bSBram Moolenaar  lua l = vim.list():add('foo'):add('bar')
5134ff4814bSBram Moolenaar  lua str = ''
5144ff4814bSBram Moolenaar  lua for v in l() do str = str .. v end
5154ff4814bSBram Moolenaar  call assert_equal('foobar', luaeval('str'))
5164ff4814bSBram Moolenaar
5172f362bf7SBram Moolenaar  lua str, l = nil
5184ff4814bSBram Moolenaarendfunc
5194ff4814bSBram Moolenaar
5205feabe00SBram Moolenaarfunc Test_lua_recursive_list()
5214ff4814bSBram Moolenaar  lua l = vim.list():add(1):add(2)
5224ff4814bSBram Moolenaar  lua l = l:add(l)
5234ff4814bSBram Moolenaar
524bd84617dSBram Moolenaar  call assert_equal(1, luaeval('l[1]'))
525bd84617dSBram Moolenaar  call assert_equal(2, luaeval('l[2]'))
5264ff4814bSBram Moolenaar
527bd84617dSBram Moolenaar  call assert_equal(1, luaeval('l[3][1]'))
528bd84617dSBram Moolenaar  call assert_equal(2, luaeval('l[3][2]'))
5294ff4814bSBram Moolenaar
530bd84617dSBram Moolenaar  call assert_equal(1, luaeval('l[3][3][1]'))
531bd84617dSBram Moolenaar  call assert_equal(2, luaeval('l[3][3][2]'))
5324ff4814bSBram Moolenaar
533eb04f089SBram Moolenaar  call assert_equal('[1, 2, [...]]', string(luaeval('l')))
5344ff4814bSBram Moolenaar
535a8a60d0cSBram Moolenaar  call assert_match('^list: \%(0x\)\?\x\+$', luaeval('tostring(l)'))
536bd84617dSBram Moolenaar  call assert_equal(luaeval('tostring(l)'), luaeval('tostring(l[3])'))
5374ff4814bSBram Moolenaar
538bd84617dSBram Moolenaar  call assert_equal(luaeval('l'), luaeval('l[3]'))
539bd84617dSBram Moolenaar  call assert_equal(luaeval('l'), luaeval('l[3][3]'))
5404ff4814bSBram Moolenaar
5414ff4814bSBram Moolenaar  lua l = nil
5424ff4814bSBram Moolenaarendfunc
5434ff4814bSBram Moolenaar
5445feabe00SBram Moolenaarfunc Test_lua_dict()
5454ff4814bSBram Moolenaar  call assert_equal({}, luaeval('vim.dict()'))
5464ff4814bSBram Moolenaar
5474ff4814bSBram Moolenaar  let d = {}
5484ff4814bSBram Moolenaar  lua d = vim.eval('d')
5494ff4814bSBram Moolenaar  lua d[0] = 123
5504ff4814bSBram Moolenaar  lua d[1] = "abc"
5514ff4814bSBram Moolenaar  lua d[2] = true
5524ff4814bSBram Moolenaar  lua d[3] = false
5534ff4814bSBram Moolenaar  lua d[4] = vim.eval("[1, 2, 3]")
5544ff4814bSBram Moolenaar  lua d[5] = vim.eval("{'a':1, 'b':2, 'c':3}")
555eb04f089SBram Moolenaar  call assert_equal({'0':123, '1':'abc', '2':v:true, '3':v:false, '4': [1, 2, 3], '5': {'a':1, 'b':2, 'c':3}}, d)
556eb04f089SBram Moolenaar  call assert_equal(6, luaeval('#d'))
557a8a60d0cSBram Moolenaar  call assert_match('^dict: \%(0x\)\?\x\+$', luaeval('tostring(d)'))
5584ff4814bSBram Moolenaar
5594ff4814bSBram Moolenaar  call assert_equal('abc', luaeval('d[1]'))
560e49b8e8dSBram Moolenaar  call assert_equal(v:null, luaeval('d[22]'))
5614ff4814bSBram Moolenaar
5624ff4814bSBram Moolenaar  lua d[0] = 124
5634ff4814bSBram Moolenaar  lua d[4] = nil
564eb04f089SBram Moolenaar  call assert_equal({'0':124, '1':'abc', '2':v:true, '3':v:false, '5': {'a':1, 'b':2, 'c':3}}, d)
5654ff4814bSBram Moolenaar
5662f362bf7SBram Moolenaar  lockvar 1 d
5672f362bf7SBram Moolenaar  call assert_fails('lua d[6] = 1', '[string "vim chunk"]:1: dict is locked')
568e49b8e8dSBram Moolenaar  unlockvar d
569e49b8e8dSBram Moolenaar
570e49b8e8dSBram Moolenaar  " Error case
571e49b8e8dSBram Moolenaar  lua d = {}
572e49b8e8dSBram Moolenaar  lua d[''] = 10
573e49b8e8dSBram Moolenaar  call assert_fails("let t = luaeval('vim.dict(d)')",
574b898a029SBram Moolenaar        \ s:lua_53_or_later
575b898a029SBram Moolenaar        \ ? '[string "luaeval"]:1: table has empty key'
576b898a029SBram Moolenaar        \ : 'table has empty key')
577e49b8e8dSBram Moolenaar  let d = {}
578e49b8e8dSBram Moolenaar  lua x = vim.eval('d')
579e49b8e8dSBram Moolenaar  call assert_fails("lua x[''] = 10", '[string "vim chunk"]:1: empty key')
580e49b8e8dSBram Moolenaar  lua x['a'] = nil
581e49b8e8dSBram Moolenaar  call assert_equal({}, d)
582e49b8e8dSBram Moolenaar
583e49b8e8dSBram Moolenaar  " cannot assign funcrefs in the global scope
584e49b8e8dSBram Moolenaar  lua x = vim.eval('g:')
585e49b8e8dSBram Moolenaar  call assert_fails("lua x['min'] = vim.funcref('max')",
586e49b8e8dSBram Moolenaar        \ '[string "vim chunk"]:1: cannot assign funcref to builtin scope')
5872f362bf7SBram Moolenaar
5884ff4814bSBram Moolenaar  lua d = nil
5894ff4814bSBram Moolenaarendfunc
5904ff4814bSBram Moolenaar
5915feabe00SBram Moolenaarfunc Test_lua_dict_table()
5922f362bf7SBram Moolenaar  lua t = {key1 = 'x', key2 = 3.14, key3 = true, key4 = false}
5932f362bf7SBram Moolenaar  call assert_equal({'key1': 'x', 'key2': 3.14, 'key3': v:true, 'key4': v:false},
5942f362bf7SBram Moolenaar        \           luaeval('vim.dict(t)'))
5952f362bf7SBram Moolenaar
5962f362bf7SBram Moolenaar  " Same example as in :help lua-vim.
5972f362bf7SBram Moolenaar  lua t = {math.pi, false, say = 'hi'}
5982f362bf7SBram Moolenaar  " FIXME: commented out as it currently does not work as documented:
5992f362bf7SBram Moolenaar  " Expected {'say': 'hi'}
6002f362bf7SBram Moolenaar  " but got {'1': 3.141593, '2': v:false, 'say': 'hi'}
6012f362bf7SBram Moolenaar  " Is the documentation or the code wrong?
6022f362bf7SBram Moolenaar  "call assert_equal({'say' : 'hi'}, luaeval('vim.dict(t)'))
6032f362bf7SBram Moolenaar  lua t = nil
6042f362bf7SBram Moolenaar
6052f362bf7SBram Moolenaar  call assert_fails('lua vim.dict(1)', '[string "vim chunk"]:1: table expected, got number')
6062f362bf7SBram Moolenaar  call assert_fails('lua vim.dict("x")', '[string "vim chunk"]:1: table expected, got string')
6072f362bf7SBram Moolenaar  call assert_fails('lua vim.dict(print)', '[string "vim chunk"]:1: table expected, got function')
6082f362bf7SBram Moolenaar  call assert_fails('lua vim.dict(true)', '[string "vim chunk"]:1: table expected, got boolean')
6092f362bf7SBram Moolenaarendfunc
6102f362bf7SBram Moolenaar
6114ff4814bSBram Moolenaar" Test d() i.e. iterator on dictionary
6125feabe00SBram Moolenaarfunc Test_lua_dict_iter()
6134ff4814bSBram Moolenaar  let d = {'a': 1, 'b':2}
6144ff4814bSBram Moolenaar  lua d = vim.eval('d')
6154ff4814bSBram Moolenaar  lua str = ''
6164ff4814bSBram Moolenaar  lua for k,v in d() do str = str .. k ..':' .. v .. ',' end
6174ff4814bSBram Moolenaar  call assert_equal('a:1,b:2,', luaeval('str'))
6184ff4814bSBram Moolenaar
6192f362bf7SBram Moolenaar  lua str, d = nil
6204ff4814bSBram Moolenaarendfunc
6214ff4814bSBram Moolenaar
6225feabe00SBram Moolenaarfunc Test_lua_blob()
623b7828690SBram Moolenaar  call assert_equal(0z, luaeval('vim.blob("")'))
624b7828690SBram Moolenaar  call assert_equal(0z31326162, luaeval('vim.blob("12ab")'))
625b7828690SBram Moolenaar  call assert_equal(0z00010203, luaeval('vim.blob("\x00\x01\x02\x03")'))
626b7828690SBram Moolenaar  call assert_equal(0z8081FEFF, luaeval('vim.blob("\x80\x81\xfe\xff")'))
627b7828690SBram Moolenaar
628b7828690SBram Moolenaar  lua b = vim.blob("\x00\x00\x00\x00")
629b7828690SBram Moolenaar  call assert_equal(0z00000000, luaeval('b'))
630eb04f089SBram Moolenaar  call assert_equal(4, luaeval('#b'))
631b7828690SBram Moolenaar  lua b[0], b[1], b[2], b[3] = 1, 32, 256, 0xff
632b7828690SBram Moolenaar  call assert_equal(0z012000ff, luaeval('b'))
633b7828690SBram Moolenaar  lua b[4] = string.byte("z", 1)
634b7828690SBram Moolenaar  call assert_equal(0z012000ff.7a, luaeval('b'))
635eb04f089SBram Moolenaar  call assert_equal(5, luaeval('#b'))
636b7828690SBram Moolenaar  call assert_fails('lua b[#b+1] = 0x80', '[string "vim chunk"]:1: index out of range')
637b7828690SBram Moolenaar  lua b:add("12ab")
638b7828690SBram Moolenaar  call assert_equal(0z012000ff.7a313261.62, luaeval('b'))
639eb04f089SBram Moolenaar  call assert_equal(9, luaeval('#b'))
640b7828690SBram Moolenaar  call assert_fails('lua b:add(nil)', '[string "vim chunk"]:1: string expected, got nil')
641b7828690SBram Moolenaar  call assert_fails('lua b:add(true)', '[string "vim chunk"]:1: string expected, got boolean')
642b7828690SBram Moolenaar  call assert_fails('lua b:add({})', '[string "vim chunk"]:1: string expected, got table')
643b7828690SBram Moolenaar  lua b = nil
644e49b8e8dSBram Moolenaar
645e49b8e8dSBram Moolenaar  let b = 0z0102
646e49b8e8dSBram Moolenaar  lua lb = vim.eval('b')
647e49b8e8dSBram Moolenaar  let n = luaeval('lb[1]')
648e49b8e8dSBram Moolenaar  call assert_equal(2, n)
649e49b8e8dSBram Moolenaar  let n = luaeval('lb[6]')
650e49b8e8dSBram Moolenaar  call assert_equal(v:null, n)
651*f65ed86fSBram Moolenaar  if s:lua_543_or_later
652*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: method 'xyz' is not callable (a nil value)"
653*f65ed86fSBram Moolenaar  elseif s:lua_53_or_later
654*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: attempt to call a nil value (method 'xyz')"
655*f65ed86fSBram Moolenaar  else
656*f65ed86fSBram Moolenaar    let msg = "[string \"luaeval\"]:1: attempt to call method 'xyz' (a nil value)"
657*f65ed86fSBram Moolenaar  endif
658*f65ed86fSBram Moolenaar  call assert_fails('let x = luaeval("lb:xyz(3)")', msg)
659e49b8e8dSBram Moolenaar  let y = luaeval("lb[{}]")
660e49b8e8dSBram Moolenaar  call assert_equal(v:null, y)
661e49b8e8dSBram Moolenaar
662e49b8e8dSBram Moolenaar  lockvar b
663e49b8e8dSBram Moolenaar  call assert_fails('lua lb[1] = 2', '[string "vim chunk"]:1: blob is locked')
664e49b8e8dSBram Moolenaar  call assert_fails('lua lb:add("12")', '[string "vim chunk"]:1: blob is locked')
665e49b8e8dSBram Moolenaar
666e49b8e8dSBram Moolenaar  " Error cases
667e49b8e8dSBram Moolenaar  lua t = {}
668e49b8e8dSBram Moolenaar  call assert_fails('lua b = vim.blob(t)',
669e49b8e8dSBram Moolenaar        \ '[string "vim chunk"]:1: string expected, got table')
670b7828690SBram Moolenaarendfunc
671b7828690SBram Moolenaar
6725feabe00SBram Moolenaarfunc Test_lua_funcref()
673ca06da92SBram Moolenaar  function I(x)
674ca06da92SBram Moolenaar    return a:x
675ca06da92SBram Moolenaar  endfunction
676ca06da92SBram Moolenaar  let R = function('I')
677ca06da92SBram Moolenaar  lua i1 = vim.funcref"I"
678ca06da92SBram Moolenaar  lua i2 = vim.eval"R"
679ca06da92SBram Moolenaar  lua msg = "funcref|test|" .. (#i2(i1) == #i1(i2) and "OK" or "FAIL")
680ca06da92SBram Moolenaar  lua msg = vim.funcref"tr"(msg, "|", " ")
681ca06da92SBram Moolenaar  call assert_equal("funcref test OK", luaeval('msg'))
682ca06da92SBram Moolenaar
683e49b8e8dSBram Moolenaar  " Error cases
684e49b8e8dSBram Moolenaar  call assert_fails('lua f1 = vim.funcref("")',
685e49b8e8dSBram Moolenaar        \ '[string "vim chunk"]:1: invalid function name: ')
686e49b8e8dSBram Moolenaar  call assert_fails('lua f1 = vim.funcref("10")',
687e49b8e8dSBram Moolenaar        \ '[string "vim chunk"]:1: invalid function name: 10')
688e49b8e8dSBram Moolenaar  let fname = test_null_string()
689e49b8e8dSBram Moolenaar  call assert_fails('lua f1 = vim.funcref(fname)',
690e49b8e8dSBram Moolenaar        \ "[string \"vim chunk\"]:1: bad argument #1 to 'funcref' (string expected, got nil)")
691e49b8e8dSBram Moolenaar  call assert_fails('lua vim.funcref("abc")()',
692ecdd14a4SBram Moolenaar        \ ['E117:', '\[string "vim chunk"]:1: cannot call funcref'])
693e49b8e8dSBram Moolenaar
694ca06da92SBram Moolenaar  " dict funcref
695ca06da92SBram Moolenaar  function Mylen() dict
696ca06da92SBram Moolenaar    return len(self.data)
697ca06da92SBram Moolenaar  endfunction
698ca06da92SBram Moolenaar  let l = [0, 1, 2, 3]
699ca06da92SBram Moolenaar  let mydict = {'data': l}
700ca06da92SBram Moolenaar  lua d = vim.eval"mydict"
701ca06da92SBram Moolenaar  lua d.len = vim.funcref"Mylen" -- assign d as 'self'
702ca06da92SBram Moolenaar  lua res = (d.len() == vim.funcref"len"(vim.eval"l")) and "OK" or "FAIL"
703ca06da92SBram Moolenaar  call assert_equal("OK", luaeval('res'))
7044eefe47eSBram Moolenaar  call assert_equal(function('Mylen', {'data': l, 'len': function('Mylen')}), mydict.len)
7052f362bf7SBram Moolenaar
7062f362bf7SBram Moolenaar  lua i1, i2, msg, d, res = nil
707ca06da92SBram Moolenaarendfunc
708ca06da92SBram Moolenaar
7094ff4814bSBram Moolenaar" Test vim.type()
7105feabe00SBram Moolenaarfunc Test_lua_type()
7114ff4814bSBram Moolenaar  " The following values are identical to Lua's type function.
7124ff4814bSBram Moolenaar  call assert_equal('string',   luaeval('vim.type("foo")'))
7134ff4814bSBram Moolenaar  call assert_equal('number',   luaeval('vim.type(1)'))
7144ff4814bSBram Moolenaar  call assert_equal('number',   luaeval('vim.type(1.2)'))
7154ff4814bSBram Moolenaar  call assert_equal('function', luaeval('vim.type(print)'))
7164ff4814bSBram Moolenaar  call assert_equal('table',    luaeval('vim.type({})'))
7174ff4814bSBram Moolenaar  call assert_equal('boolean',  luaeval('vim.type(true)'))
7184ff4814bSBram Moolenaar  call assert_equal('boolean',  luaeval('vim.type(false)'))
7194ff4814bSBram Moolenaar  call assert_equal('nil',      luaeval('vim.type(nil)'))
7204ff4814bSBram Moolenaar
7214ff4814bSBram Moolenaar  " The following values are specific to Vim.
7224ff4814bSBram Moolenaar  call assert_equal('window',   luaeval('vim.type(vim.window())'))
7234ff4814bSBram Moolenaar  call assert_equal('buffer',   luaeval('vim.type(vim.buffer())'))
7244ff4814bSBram Moolenaar  call assert_equal('list',     luaeval('vim.type(vim.list())'))
7254ff4814bSBram Moolenaar  call assert_equal('dict',     luaeval('vim.type(vim.dict())'))
726ca06da92SBram Moolenaar  call assert_equal('funcref',  luaeval('vim.type(vim.funcref("Test_type"))'))
7274ff4814bSBram Moolenaarendfunc
7284ff4814bSBram Moolenaar
7294ff4814bSBram Moolenaar" Test vim.open()
7305feabe00SBram Moolenaarfunc Test_lua_open()
7314ff4814bSBram Moolenaar  call assert_notmatch('XOpen', execute('ls'))
7324ff4814bSBram Moolenaar
7334ff4814bSBram Moolenaar  " Open a buffer XOpen1, but do not jump to it.
7344ff4814bSBram Moolenaar  lua b = vim.open('XOpen1')
7354ff4814bSBram Moolenaar  call assert_equal('XOpen1', luaeval('b.name'))
7364ff4814bSBram Moolenaar  call assert_equal('', bufname('%'))
7374ff4814bSBram Moolenaar
7384ff4814bSBram Moolenaar  call assert_match('XOpen1', execute('ls'))
7394ff4814bSBram Moolenaar  call assert_notequal('XOpen2', bufname('%'))
7404ff4814bSBram Moolenaar
7414ff4814bSBram Moolenaar  " Open a buffer XOpen2 and jump to it.
7424ff4814bSBram Moolenaar  lua b = vim.open('XOpen2')()
7434ff4814bSBram Moolenaar  call assert_equal('XOpen2', luaeval('b.name'))
7444ff4814bSBram Moolenaar  call assert_equal('XOpen2', bufname('%'))
7454ff4814bSBram Moolenaar
7464ff4814bSBram Moolenaar  lua b = nil
7474ff4814bSBram Moolenaar  %bwipe!
7484ff4814bSBram Moolenaarendfunc
7494ff4814bSBram Moolenaar
750788fbb47SBram Moolenaarfunc Test_update_package_paths()
751788fbb47SBram Moolenaar  set runtimepath+=./testluaplugin
752788fbb47SBram Moolenaar  call assert_equal("hello from lua", luaeval("require('testluaplugin').hello()"))
753788fbb47SBram Moolenaarendfunc
754788fbb47SBram Moolenaar
755801ab069SBram Moolenaarfunc Vim_func_call_lua_callback(Concat, Cb)
756801ab069SBram Moolenaar  let l:message = a:Concat("hello", "vim")
757801ab069SBram Moolenaar  call a:Cb(l:message)
758801ab069SBram Moolenaarendfunc
759801ab069SBram Moolenaar
760801ab069SBram Moolenaarfunc Test_pass_lua_callback_to_vim_from_lua()
761801ab069SBram Moolenaar  lua pass_lua_callback_to_vim_from_lua_result = ""
762801ab069SBram Moolenaar  call assert_equal("", luaeval("pass_lua_callback_to_vim_from_lua_result"))
763801ab069SBram Moolenaar  lua <<EOF
764801ab069SBram Moolenaar  vim.funcref('Vim_func_call_lua_callback')(
765801ab069SBram Moolenaar    function(greeting, message)
766801ab069SBram Moolenaar      return greeting .. " " .. message
767801ab069SBram Moolenaar    end,
768801ab069SBram Moolenaar    function(message)
769801ab069SBram Moolenaar      pass_lua_callback_to_vim_from_lua_result = message
770801ab069SBram Moolenaar    end)
771801ab069SBram MoolenaarEOF
772801ab069SBram Moolenaar  call assert_equal("hello vim", luaeval("pass_lua_callback_to_vim_from_lua_result"))
773801ab069SBram Moolenaarendfunc
774801ab069SBram Moolenaar
775801ab069SBram Moolenaarfunc Vim_func_call_metatable_lua_callback(Greet)
776801ab069SBram Moolenaar  return a:Greet("world")
777801ab069SBram Moolenaarendfunc
778801ab069SBram Moolenaar
779801ab069SBram Moolenaarfunc Test_pass_lua_metatable_callback_to_vim_from_lua()
780801ab069SBram Moolenaar  let result = luaeval("vim.funcref('Vim_func_call_metatable_lua_callback')(setmetatable({ space = ' '}, { __call = function(tbl, msg) return 'hello' .. tbl.space .. msg  end }) )")
781801ab069SBram Moolenaar  call assert_equal("hello world", result)
782801ab069SBram Moolenaarendfunc
783801ab069SBram Moolenaar
7844ff4814bSBram Moolenaar" Test vim.line()
7855feabe00SBram Moolenaarfunc Test_lua_line()
7864ff4814bSBram Moolenaar  new
7874ff4814bSBram Moolenaar  call setline(1, ['first line', 'second line'])
7884ff4814bSBram Moolenaar  1
7894ff4814bSBram Moolenaar  call assert_equal('first line', luaeval('vim.line()'))
7904ff4814bSBram Moolenaar  2
7914ff4814bSBram Moolenaar  call assert_equal('second line', luaeval('vim.line()'))
7924ff4814bSBram Moolenaar  bwipe!
7934ff4814bSBram Moolenaarendfunc
7944ff4814bSBram Moolenaar
7954ff4814bSBram Moolenaar" Test vim.beep()
7965feabe00SBram Moolenaarfunc Test_lua_beep()
7974ff4814bSBram Moolenaar  call assert_beeps('lua vim.beep()')
7984ff4814bSBram Moolenaarendfunc
7994ff4814bSBram Moolenaar
8004ff4814bSBram Moolenaar" Test errors in luaeval()
8014ff4814bSBram Moolenaarfunc Test_luaeval_error()
8024ff4814bSBram Moolenaar  " Compile error
8034ff4814bSBram Moolenaar  call assert_fails("call luaeval('-nil')",
8044ff4814bSBram Moolenaar  \ '[string "luaeval"]:1: attempt to perform arithmetic on a nil value')
8054ff4814bSBram Moolenaar  call assert_fails("call luaeval(']')",
8064ff4814bSBram Moolenaar  \ "[string \"luaeval\"]:1: unexpected symbol near ']'")
807e49b8e8dSBram Moolenaar  lua co = coroutine.create(function () print("hi") end)
808e49b8e8dSBram Moolenaar  call assert_fails('let i = luaeval("co")', 'luaeval: cannot convert value')
809e49b8e8dSBram Moolenaar  lua co = nil
810e49b8e8dSBram Moolenaar  call assert_fails('let m = luaeval("{}")', 'luaeval: cannot convert value')
8114ff4814bSBram Moolenaarendfunc
8124ff4814bSBram Moolenaar
8134ff4814bSBram Moolenaar" Test :luafile foo.lua
8144ff4814bSBram Moolenaarfunc Test_luafile()
8154ff4814bSBram Moolenaar  call delete('Xlua_file')
816eb04f089SBram Moolenaar  call writefile(["str = 'hello'", "num = 123" ], 'Xlua_file')
8174ff4814bSBram Moolenaar  call setfperm('Xlua_file', 'r-xr-xr-x')
8184ff4814bSBram Moolenaar
8194ff4814bSBram Moolenaar  luafile Xlua_file
8204ff4814bSBram Moolenaar  call assert_equal('hello', luaeval('str'))
821eb04f089SBram Moolenaar  call assert_equal(123, luaeval('num'))
8224ff4814bSBram Moolenaar
8232f362bf7SBram Moolenaar  lua str, num = nil
8244ff4814bSBram Moolenaar  call delete('Xlua_file')
8254ff4814bSBram Moolenaarendfunc
8264ff4814bSBram Moolenaar
8274ff4814bSBram Moolenaar" Test :luafile %
8284ff4814bSBram Moolenaarfunc Test_luafile_percent()
8294ff4814bSBram Moolenaar  new Xlua_file
8304ff4814bSBram Moolenaar  append
8314ff4814bSBram Moolenaar    str, num = 'foo', 321.0
8324ff4814bSBram Moolenaar    print(string.format('str=%s, num=%d', str, num))
8334ff4814bSBram Moolenaar.
8344ff4814bSBram Moolenaar  w!
8354ff4814bSBram Moolenaar  luafile %
8364ff4814bSBram Moolenaar  let msg = split(execute('message'), "\n")[-1]
8374ff4814bSBram Moolenaar  call assert_equal('str=foo, num=321', msg)
8384ff4814bSBram Moolenaar
8392f362bf7SBram Moolenaar  lua str, num = nil
8402f362bf7SBram Moolenaar  call delete('Xlua_file')
8412f362bf7SBram Moolenaar  bwipe!
8422f362bf7SBram Moolenaarendfunc
8432f362bf7SBram Moolenaar
8442f362bf7SBram Moolenaar" Test :luafile with syntax error
8452f362bf7SBram Moolenaarfunc Test_luafile_error()
8462f362bf7SBram Moolenaar  new Xlua_file
8472f362bf7SBram Moolenaar  call writefile(['nil = 0' ], 'Xlua_file')
8482f362bf7SBram Moolenaar  call setfperm('Xlua_file', 'r-xr-xr-x')
8492f362bf7SBram Moolenaar
8502f362bf7SBram Moolenaar  call assert_fails('luafile Xlua_file', "Xlua_file:1: unexpected symbol near 'nil'")
8512f362bf7SBram Moolenaar
8524ff4814bSBram Moolenaar  call delete('Xlua_file')
853d58f03b1SBram Moolenaar  bwipe!
854d58f03b1SBram Moolenaarendfunc
85553901442SBram Moolenaar
856e49b8e8dSBram Moolenaar" Test for dealing with strings containing newlines and null character
857e49b8e8dSBram Moolenaarfunc Test_lua_string_with_newline()
858e49b8e8dSBram Moolenaar  let x = execute('lua print("Hello\nWorld")')
859e49b8e8dSBram Moolenaar  call assert_equal("\nHello\nWorld", x)
860e49b8e8dSBram Moolenaar  new
861e49b8e8dSBram Moolenaar  lua k = vim.buffer(vim.eval('bufnr()'))
862e49b8e8dSBram Moolenaar  lua k:insert("Hello\0World", 0)
863e49b8e8dSBram Moolenaar  call assert_equal(["Hello\nWorld", ''], getline(1, '$'))
864e49b8e8dSBram Moolenaar  close!
865e49b8e8dSBram Moolenaarendfunc
866e49b8e8dSBram Moolenaar
8675feabe00SBram Moolenaarfunc Test_lua_set_cursor()
86853901442SBram Moolenaar  " Check that setting the cursor position works.
86953901442SBram Moolenaar  new
87053901442SBram Moolenaar  call setline(1, ['first line', 'second line'])
87153901442SBram Moolenaar  normal gg
8726c2b7b80SBram Moolenaar  lua << trim EOF
87353901442SBram Moolenaar    w = vim.window()
87453901442SBram Moolenaar    w.line = 1
87553901442SBram Moolenaar    w.col = 5
87653901442SBram Moolenaar  EOF
87753901442SBram Moolenaar  call assert_equal([1, 5], [line('.'), col('.')])
87853901442SBram Moolenaar
87953901442SBram Moolenaar  " Check that movement after setting cursor position keeps current column.
88053901442SBram Moolenaar  normal j
88153901442SBram Moolenaar  call assert_equal([2, 5], [line('.'), col('.')])
88253901442SBram Moolenaarendfunc
8836c2b7b80SBram Moolenaar
8846c2b7b80SBram Moolenaar" Test for various heredoc syntax
8856c2b7b80SBram Moolenaarfunc Test_lua_heredoc()
8866c2b7b80SBram Moolenaar  lua << END
8876c2b7b80SBram Moolenaarvim.command('let s = "A"')
8886c2b7b80SBram MoolenaarEND
8896c2b7b80SBram Moolenaar  lua <<
8906c2b7b80SBram Moolenaarvim.command('let s ..= "B"')
8916c2b7b80SBram Moolenaar.
8926c2b7b80SBram Moolenaar  lua << trim END
8936c2b7b80SBram Moolenaar    vim.command('let s ..= "C"')
8946c2b7b80SBram Moolenaar  END
8956c2b7b80SBram Moolenaar  lua << trim
8966c2b7b80SBram Moolenaar    vim.command('let s ..= "D"')
8976c2b7b80SBram Moolenaar  .
8986ab0953fSBram Moolenaar  lua << trim eof
8996ab0953fSBram Moolenaar    vim.command('let s ..= "E"')
9006ab0953fSBram Moolenaar  eof
9016ab0953fSBram Moolenaar  call assert_equal('ABCDE', s)
9026c2b7b80SBram Moolenaarendfunc
9036c2b7b80SBram Moolenaar
9046c2b7b80SBram Moolenaar" vim: shiftwidth=2 sts=2 expandtab
905