mirror of
https://github.com/neovim/neovim.git
synced 2026-01-13 15:57:13 +10:00
Merge pull request #28344 from bfredl/wonderland
feat(build): build.zig MVP: build and run functionaltests on linux
This commit is contained in:
@@ -47,7 +47,8 @@ local setup_treesitter = function()
|
||||
end
|
||||
|
||||
before_each(function()
|
||||
clear({ args_rm = { '--cmd' }, args = { '--clean' } })
|
||||
-- avoid options, but we still need TS parsers
|
||||
clear({ args_rm = { '--cmd' }, args = { '--clean', '--cmd', n.runtime_set } })
|
||||
end)
|
||||
|
||||
describe('commenting', function()
|
||||
|
||||
@@ -245,8 +245,8 @@ describe('vim.fs', function()
|
||||
describe('find()', function()
|
||||
it('works', function()
|
||||
eq(
|
||||
{ test_build_dir .. '/build' },
|
||||
vim.fs.find('build', { path = nvim_dir, upward = true, type = 'directory' })
|
||||
{ test_build_dir .. '/bin' },
|
||||
vim.fs.find('bin', { path = nvim_dir, upward = true, type = 'directory' })
|
||||
)
|
||||
eq({ nvim_prog }, vim.fs.find(nvim_prog_basename, { path = test_build_dir, type = 'file' }))
|
||||
|
||||
@@ -255,7 +255,7 @@ describe('vim.fs', function()
|
||||
end)
|
||||
|
||||
it('follows symlinks', function()
|
||||
local build_dir = test_source_path .. '/build' ---@type string
|
||||
local build_dir = test_build_dir ---@type string
|
||||
local symlink = test_source_path .. '/build_link' ---@type string
|
||||
vim.uv.fs_symlink(build_dir, symlink, { junction = true, dir = true })
|
||||
|
||||
@@ -263,8 +263,11 @@ describe('vim.fs', function()
|
||||
vim.uv.fs_unlink(symlink)
|
||||
end)
|
||||
|
||||
local cases = { nvim_prog, symlink .. '/bin/' .. nvim_prog_basename }
|
||||
table.sort(cases)
|
||||
|
||||
eq(
|
||||
{ nvim_prog, symlink .. '/bin/' .. nvim_prog_basename },
|
||||
cases,
|
||||
vim.fs.find(nvim_prog_basename, {
|
||||
path = test_source_path,
|
||||
type = 'file',
|
||||
@@ -273,6 +276,9 @@ describe('vim.fs', function()
|
||||
})
|
||||
)
|
||||
|
||||
if t.is_zig_build() then
|
||||
return pending('broken with build.zig')
|
||||
end
|
||||
eq(
|
||||
{ nvim_prog },
|
||||
vim.fs.find(nvim_prog_basename, {
|
||||
@@ -285,6 +291,9 @@ describe('vim.fs', function()
|
||||
end)
|
||||
|
||||
it('follow=true handles symlink loop', function()
|
||||
if t.is_zig_build() then
|
||||
return pending('broken/slow with build.zig')
|
||||
end
|
||||
local cwd = test_source_path ---@type string
|
||||
local symlink = test_source_path .. '/loop_link' ---@type string
|
||||
vim.uv.fs_symlink(cwd, symlink, { junction = true, dir = true })
|
||||
@@ -304,9 +313,9 @@ describe('vim.fs', function()
|
||||
it('accepts predicate as names', function()
|
||||
local opts = { path = nvim_dir, upward = true, type = 'directory' }
|
||||
eq(
|
||||
{ test_build_dir .. '/build' },
|
||||
{ test_build_dir .. '/bin' },
|
||||
vim.fs.find(function(x)
|
||||
return x == 'build'
|
||||
return x == 'bin'
|
||||
end, opts)
|
||||
)
|
||||
eq(
|
||||
|
||||
@@ -2100,9 +2100,9 @@ describe('lua stdlib', function()
|
||||
eq(false, fn.luaeval "vim.v['false']")
|
||||
eq(NIL, fn.luaeval 'vim.v.null')
|
||||
matches([[attempt to index .* nil value]], pcall_err(exec_lua, 'return vim.v[0].progpath'))
|
||||
eq('Key is read-only: count', pcall_err(exec_lua, [[vim.v.count = 42]]))
|
||||
eq('Dict is locked', pcall_err(exec_lua, [[vim.v.nosuchvar = 42]]))
|
||||
eq('Key is fixed: errmsg', pcall_err(exec_lua, [[vim.v.errmsg = nil]]))
|
||||
matches('Key is read%-only: count$', pcall_err(exec_lua, [[vim.v.count = 42]]))
|
||||
matches('Dict is locked$', pcall_err(exec_lua, [[vim.v.nosuchvar = 42]]))
|
||||
matches('Key is fixed: errmsg$', pcall_err(exec_lua, [[vim.v.errmsg = nil]]))
|
||||
exec_lua([[vim.v.errmsg = 'set by Lua']])
|
||||
eq('set by Lua', eval('v:errmsg'))
|
||||
exec_lua([[vim.v.errmsg = 42]])
|
||||
@@ -2111,7 +2111,10 @@ describe('lua stdlib', function()
|
||||
eq({ 'one', 'two' }, eval('v:oldfiles'))
|
||||
exec_lua([[vim.v.oldfiles = {}]])
|
||||
eq({}, eval('v:oldfiles'))
|
||||
eq('Setting v:oldfiles to value with wrong type', pcall_err(exec_lua, [[vim.v.oldfiles = 'a']]))
|
||||
matches(
|
||||
'Setting v:oldfiles to value with wrong type$',
|
||||
pcall_err(exec_lua, [[vim.v.oldfiles = 'a']])
|
||||
)
|
||||
eq({}, eval('v:oldfiles'))
|
||||
|
||||
feed('i foo foo foo<Esc>0/foo<CR>')
|
||||
|
||||
Reference in New Issue
Block a user