mirror of
https://github.com/neovim/neovim.git
synced 2024-12-26 14:11:15 -07:00
55844eee10
Co-authored-by: Wayne Rowcliffe (@war1025)
304 lines
9.2 KiB
Lua
304 lines
9.2 KiB
Lua
|
|
local assert = require("luassert")
|
|
local helpers = require("test.unit.helpers")
|
|
|
|
local to_cstr = helpers.to_cstr
|
|
local eq = helpers.eq
|
|
local neq = helpers.neq
|
|
local NULL = helpers.NULL
|
|
|
|
local globals = helpers.cimport("./src/nvim/globals.h")
|
|
local buffer = helpers.cimport("./src/nvim/buffer.h")
|
|
|
|
describe('buffer functions', function()
|
|
|
|
local buflist_new = function(file, flags)
|
|
local c_file = to_cstr(file)
|
|
return buffer.buflist_new(c_file, c_file, 1, flags)
|
|
end
|
|
|
|
local close_buffer = function(win, buf, action, abort_if_last)
|
|
return buffer.close_buffer(win, buf, action, abort_if_last)
|
|
end
|
|
|
|
local path1 = 'test_file_path'
|
|
local path2 = 'file_path_test'
|
|
local path3 = 'path_test_file'
|
|
|
|
before_each(function()
|
|
-- create the files
|
|
io.open(path1, 'w').close()
|
|
io.open(path2, 'w').close()
|
|
io.open(path3, 'w').close()
|
|
end)
|
|
|
|
after_each(function()
|
|
os.remove(path1)
|
|
os.remove(path2)
|
|
os.remove(path3)
|
|
end)
|
|
|
|
describe('buf_valid', function()
|
|
|
|
it('should view NULL as an invalid buffer', function()
|
|
eq(false, buffer.buf_valid(NULL))
|
|
end)
|
|
|
|
it('should view an open buffer as valid', function()
|
|
local buf = buflist_new(path1, buffer.BLN_LISTED)
|
|
|
|
eq(true, buffer.buf_valid(buf))
|
|
end)
|
|
|
|
it('should view a closed and hidden buffer as valid', function()
|
|
local buf = buflist_new(path1, buffer.BLN_LISTED)
|
|
|
|
close_buffer(NULL, buf, 0, 0)
|
|
|
|
eq(true, buffer.buf_valid(buf))
|
|
end)
|
|
|
|
it('should view a closed and unloaded buffer as valid', function()
|
|
local buf = buflist_new(path1, buffer.BLN_LISTED)
|
|
|
|
close_buffer(NULL, buf, buffer.DOBUF_UNLOAD, 0)
|
|
|
|
eq(true, buffer.buf_valid(buf))
|
|
end)
|
|
|
|
it('should view a closed and wiped buffer as invalid', function()
|
|
local buf = buflist_new(path1, buffer.BLN_LISTED)
|
|
|
|
close_buffer(NULL, buf, buffer.DOBUF_WIPE, 0)
|
|
|
|
eq(false, buffer.buf_valid(buf))
|
|
end)
|
|
end)
|
|
|
|
|
|
describe('buflist_findpat', function()
|
|
|
|
local ALLOW_UNLISTED = 1
|
|
local ONLY_LISTED = 0
|
|
|
|
local buflist_findpat = function(pat, allow_unlisted)
|
|
return buffer.buflist_findpat(to_cstr(pat), NULL, allow_unlisted, 0, 0)
|
|
end
|
|
|
|
it('should find exact matches', function()
|
|
local buf = buflist_new(path1, buffer.BLN_LISTED)
|
|
|
|
eq(buf.b_fnum, buflist_findpat(path1, ONLY_LISTED))
|
|
|
|
close_buffer(NULL, buf, buffer.DOBUF_WIPE, 0)
|
|
end)
|
|
|
|
it('should prefer to match the start of a file path', function()
|
|
local buf1 = buflist_new(path1, buffer.BLN_LISTED)
|
|
local buf2 = buflist_new(path2, buffer.BLN_LISTED)
|
|
local buf3 = buflist_new(path3, buffer.BLN_LISTED)
|
|
|
|
eq(buf1.b_fnum, buflist_findpat("test", ONLY_LISTED))
|
|
eq(buf2.b_fnum, buflist_findpat("file", ONLY_LISTED))
|
|
eq(buf3.b_fnum, buflist_findpat("path", ONLY_LISTED))
|
|
|
|
close_buffer(NULL, buf1, buffer.DOBUF_WIPE, 0)
|
|
close_buffer(NULL, buf2, buffer.DOBUF_WIPE, 0)
|
|
close_buffer(NULL, buf3, buffer.DOBUF_WIPE, 0)
|
|
end)
|
|
|
|
it('should prefer to match the end of a file over the middle', function()
|
|
--{ Given: Two buffers, where 'test' appears in both
|
|
-- And: 'test' appears at the end of buf3 but in the middle of buf2
|
|
local buf2 = buflist_new(path2, buffer.BLN_LISTED)
|
|
local buf3 = buflist_new(path3, buffer.BLN_LISTED)
|
|
|
|
-- Then: buf2 is the buffer that is found
|
|
eq(buf2.b_fnum, buflist_findpat("test", ONLY_LISTED))
|
|
--}
|
|
|
|
--{ When: We close buf2
|
|
close_buffer(NULL, buf2, buffer.DOBUF_WIPE, 0)
|
|
|
|
-- And: Open buf1, which has 'file' in the middle of its name
|
|
local buf1 = buflist_new(path1, buffer.BLN_LISTED)
|
|
|
|
-- Then: buf3 is found since 'file' appears at the end of the name
|
|
eq(buf3.b_fnum, buflist_findpat("file", ONLY_LISTED))
|
|
--}
|
|
|
|
close_buffer(NULL, buf1, buffer.DOBUF_WIPE, 0)
|
|
close_buffer(NULL, buf3, buffer.DOBUF_WIPE, 0)
|
|
end)
|
|
|
|
it('should match a unique fragment of a file path', function()
|
|
local buf1 = buflist_new(path1, buffer.BLN_LISTED)
|
|
local buf2 = buflist_new(path2, buffer.BLN_LISTED)
|
|
local buf3 = buflist_new(path3, buffer.BLN_LISTED)
|
|
|
|
eq(buf3.b_fnum, buflist_findpat("_test_", ONLY_LISTED))
|
|
|
|
close_buffer(NULL, buf1, buffer.DOBUF_WIPE, 0)
|
|
close_buffer(NULL, buf2, buffer.DOBUF_WIPE, 0)
|
|
close_buffer(NULL, buf3, buffer.DOBUF_WIPE, 0)
|
|
end)
|
|
|
|
it('should include / ignore unlisted buffers based on the flag.', function()
|
|
--{ Given: A buffer
|
|
local buf3 = buflist_new(path3, buffer.BLN_LISTED)
|
|
|
|
-- Then: We should find the buffer when it is given a unique pattern
|
|
eq(buf3.b_fnum, buflist_findpat("_test_", ONLY_LISTED))
|
|
--}
|
|
|
|
--{ When: We unlist the buffer
|
|
close_buffer(NULL, buf3, buffer.DOBUF_DEL, 0)
|
|
|
|
-- Then: It should not find the buffer when searching only listed buffers
|
|
eq(-1, buflist_findpat("_test_", ONLY_LISTED))
|
|
|
|
-- And: It should find the buffer when including unlisted buffers
|
|
eq(buf3.b_fnum, buflist_findpat("_test_", ALLOW_UNLISTED))
|
|
--}
|
|
|
|
--{ When: We wipe the buffer
|
|
close_buffer(NULL, buf3, buffer.DOBUF_WIPE, 0)
|
|
|
|
-- Then: It should not find the buffer at all
|
|
eq(-1, buflist_findpat("_test_", ONLY_LISTED))
|
|
eq(-1, buflist_findpat("_test_", ALLOW_UNLISTED))
|
|
--}
|
|
end)
|
|
|
|
it('should prefer listed buffers to unlisted buffers.', function()
|
|
--{ Given: Two buffers that match a pattern
|
|
local buf1 = buflist_new(path1, buffer.BLN_LISTED)
|
|
local buf2 = buflist_new(path2, buffer.BLN_LISTED)
|
|
|
|
-- Then: The first buffer is preferred when both are listed
|
|
eq(buf1.b_fnum, buflist_findpat("test", ONLY_LISTED))
|
|
--}
|
|
|
|
--{ When: The first buffer is unlisted
|
|
close_buffer(NULL, buf1, buffer.DOBUF_DEL, 0)
|
|
|
|
-- Then: The second buffer is preferred because
|
|
-- unlisted buffers are not allowed
|
|
eq(buf2.b_fnum, buflist_findpat("test", ONLY_LISTED))
|
|
--}
|
|
|
|
--{ When: We allow unlisted buffers
|
|
-- Then: The second buffer is still preferred
|
|
-- because listed buffers are preferred to unlisted
|
|
eq(buf2.b_fnum, buflist_findpat("test", ALLOW_UNLISTED))
|
|
--}
|
|
|
|
--{ When: We unlist the second buffer
|
|
close_buffer(NULL, buf2, buffer.DOBUF_DEL, 0)
|
|
|
|
-- Then: The first buffer is preferred again
|
|
-- because buf1 matches better which takes precedence
|
|
-- when both buffers have the same listing status.
|
|
eq(buf1.b_fnum, buflist_findpat("test", ALLOW_UNLISTED))
|
|
|
|
-- And: Neither buffer is returned when ignoring unlisted
|
|
eq(-1, buflist_findpat("test", ONLY_LISTED))
|
|
--}
|
|
|
|
close_buffer(NULL, buf1, buffer.DOBUF_WIPE, 0)
|
|
close_buffer(NULL, buf2, buffer.DOBUF_WIPE, 0)
|
|
end)
|
|
end)
|
|
|
|
describe('build_stl_str_hl', function()
|
|
|
|
local output_buffer = to_cstr(string.rep(" ", 100))
|
|
|
|
local build_stl_str_hl = function(pat)
|
|
return buffer.build_stl_str_hl(globals.curwin,
|
|
output_buffer,
|
|
100,
|
|
to_cstr(pat),
|
|
false,
|
|
32,
|
|
80,
|
|
NULL,
|
|
NULL)
|
|
end
|
|
|
|
it('should copy plain text', function()
|
|
local width = build_stl_str_hl("this is a test")
|
|
|
|
eq(14, width)
|
|
eq("this is a test", helpers.ffi.string(output_buffer, width))
|
|
|
|
end)
|
|
|
|
it('should print no file name', function()
|
|
local width = build_stl_str_hl("%f")
|
|
|
|
eq(9, width)
|
|
eq("[No Name]", helpers.ffi.string(output_buffer, width))
|
|
|
|
end)
|
|
|
|
it('should print the relative file name', function()
|
|
buffer.setfname(globals.curbuf, to_cstr("Makefile"), NULL, 1)
|
|
local width = build_stl_str_hl("%f")
|
|
|
|
eq(8, width)
|
|
eq("Makefile", helpers.ffi.string(output_buffer, width))
|
|
|
|
end)
|
|
|
|
it('should print the full file name', function()
|
|
buffer.setfname(globals.curbuf, to_cstr("Makefile"), NULL, 1)
|
|
|
|
local width = build_stl_str_hl("%F")
|
|
|
|
assert.is_true(8 < width)
|
|
neq(NULL, string.find(helpers.ffi.string(output_buffer, width), "Makefile"))
|
|
|
|
end)
|
|
|
|
it('should print the tail file name', function()
|
|
buffer.setfname(globals.curbuf, to_cstr("src/nvim/buffer.c"), NULL, 1)
|
|
|
|
local width = build_stl_str_hl("%t")
|
|
|
|
eq(8, width)
|
|
eq("buffer.c", helpers.ffi.string(output_buffer, width))
|
|
|
|
end)
|
|
|
|
it('should print the buffer number', function()
|
|
buffer.setfname(globals.curbuf, to_cstr("src/nvim/buffer.c"), NULL, 1)
|
|
|
|
local width = build_stl_str_hl("%n")
|
|
|
|
eq(1, width)
|
|
eq("1", helpers.ffi.string(output_buffer, width))
|
|
end)
|
|
|
|
it('should print the current line number in the buffer', function()
|
|
buffer.setfname(globals.curbuf, to_cstr("test/unit/buffer_spec.lua"), NULL, 1)
|
|
|
|
local width = build_stl_str_hl("%l")
|
|
|
|
eq(1, width)
|
|
eq("0", helpers.ffi.string(output_buffer, width))
|
|
|
|
end)
|
|
|
|
it('should print the number of lines in the buffer', function()
|
|
buffer.setfname(globals.curbuf, to_cstr("test/unit/buffer_spec.lua"), NULL, 1)
|
|
|
|
local width = build_stl_str_hl("%L")
|
|
|
|
eq(1, width)
|
|
eq("1", helpers.ffi.string(output_buffer, width))
|
|
|
|
end)
|
|
end)
|
|
end)
|