mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 12:27:24 +00:00 
			
		
		
		
	 052498ed42
			
		
	
	052498ed42
	
	
	
		
			
			Specifically, functions that are run in the context of the test runner are put in module `test/testutil.lua` while the functions that are run in the context of the test session are put in `test/functional/testnvim.lua`. Closes https://github.com/neovim/neovim/issues/27004.
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| local t = require('test.testutil')
 | |
| local n = require('test.functional.testnvim')()
 | |
| 
 | |
| local clear = n.clear
 | |
| local eq = t.eq
 | |
| local exec = n.exec
 | |
| local exec_lua = n.exec_lua
 | |
| local feed = n.feed
 | |
| local api = n.api
 | |
| local poke_eventloop = n.poke_eventloop
 | |
| 
 | |
| before_each(clear)
 | |
| 
 | |
| describe('state() function', function()
 | |
|   -- oldtest: Test_state()
 | |
|   it('works', function()
 | |
|     api.nvim_ui_attach(80, 24, {}) -- Allow hit-enter-prompt
 | |
| 
 | |
|     exec_lua([[
 | |
|       function _G.Get_state_mode()
 | |
|         _G.res = { vim.fn.state(), vim.api.nvim_get_mode().mode:sub(1, 1) }
 | |
|       end
 | |
|       function _G.Run_timer()
 | |
|         local timer = vim.uv.new_timer()
 | |
|         timer:start(0, 0, function()
 | |
|           _G.Get_state_mode()
 | |
|           timer:close()
 | |
|         end)
 | |
|       end
 | |
|     ]])
 | |
|     exec([[
 | |
|       call setline(1, ['one', 'two', 'three'])
 | |
|       map ;; gg
 | |
|       set complete=.
 | |
|       func RunTimer()
 | |
|         call timer_start(0, {id -> v:lua.Get_state_mode()})
 | |
|       endfunc
 | |
|       au Filetype foobar call v:lua.Get_state_mode()
 | |
|     ]])
 | |
| 
 | |
|     -- Using a ":" command Vim is busy, thus "S" is returned
 | |
|     feed([[:call v:lua.Get_state_mode()<CR>]])
 | |
|     eq({ 'S', 'n' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- Using a timer callback
 | |
|     feed([[:call RunTimer()<CR>]])
 | |
|     poke_eventloop() -- Process pending input
 | |
|     poke_eventloop() -- Process time_event
 | |
|     eq({ 'c', 'n' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- Halfway a mapping
 | |
|     feed([[:call v:lua.Run_timer()<CR>;]])
 | |
|     api.nvim_get_mode() -- Process pending input and luv timer callback
 | |
|     feed(';')
 | |
|     eq({ 'mS', 'n' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- An operator is pending
 | |
|     feed([[:call RunTimer()<CR>y]])
 | |
|     poke_eventloop() -- Process pending input
 | |
|     poke_eventloop() -- Process time_event
 | |
|     feed('y')
 | |
|     eq({ 'oSc', 'n' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- A register was specified
 | |
|     feed([[:call RunTimer()<CR>"r]])
 | |
|     poke_eventloop() -- Process pending input
 | |
|     poke_eventloop() -- Process time_event
 | |
|     feed('yy')
 | |
|     eq({ 'oSc', 'n' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- Insert mode completion
 | |
|     feed([[:call RunTimer()<CR>Got<C-N>]])
 | |
|     poke_eventloop() -- Process pending input
 | |
|     poke_eventloop() -- Process time_event
 | |
|     feed('<Esc>')
 | |
|     eq({ 'aSc', 'i' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- Autocommand executing
 | |
|     feed([[:set filetype=foobar<CR>]])
 | |
|     eq({ 'xS', 'n' }, exec_lua('return _G.res'))
 | |
| 
 | |
|     -- messages scrolled
 | |
|     feed([[:call v:lua.Run_timer() | echo "one\ntwo\nthree"<CR>]])
 | |
|     api.nvim_get_mode() -- Process pending input and luv timer callback
 | |
|     feed('<CR>')
 | |
|     eq({ 'Ss', 'r' }, exec_lua('return _G.res'))
 | |
|   end)
 | |
| end)
 |