neovim/test/functional/lua/loader_spec.lua

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

103 lines
2.4 KiB
Lua
Raw Normal View History

-- Test suite for testing interactions with API bindings
local t = require('test.testutil')
local n = require('test.functional.testnvim')()
local exec_lua = n.exec_lua
local command = n.command
local clear = n.clear
local eq = t.eq
describe('vim.loader', function()
before_each(clear)
it('can work in compatibility with --luamod-dev #27413', function()
clear({ args = { '--luamod-dev' } })
exec_lua [[
vim.loader.enable()
require("vim.fs")
-- try to load other vim submodules as well (Nvim Lua stdlib)
for key, _ in pairs(vim._submodules) do
local modname = 'vim.' .. key -- e.g. "vim.fs"
local lhs = vim[key]
local rhs = require(modname)
assert(
lhs == rhs,
('%s != require("%s"), %s != %s'):format(modname, modname, tostring(lhs), tostring(rhs))
)
end
]]
end)
it('handles changing files (#23027)', function()
exec_lua [[
vim.loader.enable()
]]
local tmp = t.tmpname()
command('edit ' .. tmp)
eq(
1,
exec_lua(
[[
vim.api.nvim_buf_set_lines(0, 0, -1, true, {'_G.TEST=1'})
vim.cmd.write()
loadfile(...)()
return _G.TEST
]],
tmp
)
2024-01-02 18:09:18 -07:00
)
-- fs latency
2024-01-12 04:41:09 -07:00
vim.uv.sleep(10)
eq(
2,
exec_lua(
[[
vim.api.nvim_buf_set_lines(0, 0, -1, true, {'_G.TEST=2'})
vim.cmd.write()
loadfile(...)()
return _G.TEST
]],
tmp
)
2024-01-02 18:09:18 -07:00
)
end)
it('handles % signs in modpath (#24491)', function()
exec_lua [[
vim.loader.enable()
]]
local tmp = t.tmpname()
assert(os.remove(tmp))
assert(t.mkdir(tmp))
assert(t.mkdir(tmp .. '/%'))
local tmp1 = tmp .. '/%/x'
local tmp2 = tmp .. '/%%x'
t.write_file(tmp1, 'return 1', true)
t.write_file(tmp2, 'return 2', true)
vim.uv.fs_utime(tmp1, 0, 0)
vim.uv.fs_utime(tmp2, 0, 0)
eq(1, exec_lua('return loadfile(...)()', tmp1))
eq(2, exec_lua('return loadfile(...)()', tmp2))
end)
it('correct indent on error message (#29809)', function()
local errmsg = exec_lua [[
vim.loader.enable()
local _, errmsg = pcall(require, 'non_existent_module')
return errmsg
]]
local errors = vim.split(errmsg, '\n')
eq("\tcache_loader: module 'non_existent_module' not found", errors[3])
eq("\tcache_loader_lib: module 'non_existent_module' not found", errors[4])
end)
end)