mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-25 20:07:09 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			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)
 | 
