neovim/test/functional/legacy/mapping_spec.lua

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

185 lines
4.9 KiB
Lua
Raw Normal View History

-- Test for mappings and abbreviations
local helpers = require('test.functional.helpers')(after_each)
local clear, feed, insert = helpers.clear, helpers.feed, helpers.insert
local expect, poke_eventloop = helpers.expect, helpers.poke_eventloop
local command, eq, eval, api = helpers.command, helpers.eq, helpers.eval, helpers.api
2024-01-12 04:41:09 -07:00
local sleep = vim.uv.sleep
describe('mapping', function()
before_each(clear)
it('abbreviations with р (0x80)', function()
insert([[
test starts here:
]])
-- Abbreviations with р (0x80) should work.
command('inoreab чкпр vim')
feed('GAчкпр <esc>')
expect([[
test starts here:
vim ]])
end)
it('Ctrl-c works in Insert mode', function()
-- Mapping of ctrl-c in insert mode
command('set cpo-=< cpo-=k')
command('inoremap <c-c> <ctrl-c>')
command('cnoremap <c-c> dummy')
command('cunmap <c-c>')
feed('GA<cr>')
-- XXX: editor must be in Insert mode before <C-C> is put into input buffer
poke_eventloop()
feed('TEST2: CTRL-C |<c-c>A|<cr><esc>')
command('unmap! <c-c>')
expect([[
TEST2: CTRL-C |<ctrl-c>A|
]])
end)
it('Ctrl-c works in Visual mode', function()
command([[vnoremap <c-c> :<C-u>$put ='vmap works'<cr>]])
feed('GV')
-- XXX: editor must be in Visual mode before <C-C> is put into input buffer
poke_eventloop()
feed('vV<c-c>')
command('vunmap <c-c>')
expect([[
vmap works]])
end)
it('langmap', function()
-- langmap should not get remapped in insert mode.
command('inoremap { FAIL_ilangmap')
command('set langmap=+{ langnoremap')
feed('o+<esc>')
-- Insert mode expr mapping with langmap.
command('inoremap <expr> { "FAIL_iexplangmap"')
feed('o+<esc>')
-- langmap should not get remapped in cmdline mode.
command('cnoremap { FAIL_clangmap')
feed('o+<esc>')
command('cunmap {')
-- cmdline mode expr mapping with langmap.
command('cnoremap <expr> { "FAIL_cexplangmap"')
feed('o+<esc>')
command('cunmap {')
-- Assert buffer contents.
expect([[
+
+
+
+]])
end)
it('feedkeys', function()
insert([[
a b c d
a b c d
]])
-- Vim's issue #212 (feedkeys insert mapping at current position)
command('nnoremap . :call feedkeys(".", "in")<cr>')
feed('/^a b<cr>')
feed('0qqdw.ifoo<esc>qj0@q<esc>')
command('unmap .')
expect([[
fooc d
fooc d
]])
end)
it('i_CTRL-G_U', function()
-- <c-g>U<cursor> works only within a single line
command('imapclear')
command('imap ( ()<c-g>U<left>')
feed('G2o<esc>ki<cr>Test1: text with a (here some more text<esc>k.')
-- test undo
feed('G2o<esc>ki<cr>Test2: text wit a (here some more text [und undo]<c-g>u<esc>k.u')
command('imapclear')
command('set whichwrap=<,>,[,]')
feed('G3o<esc>2k')
command(
[[:exe ":norm! iTest3: text with a (parenthesis here\<C-G>U\<Right>new line here\<esc>\<up>\<up>."]]
)
expect([[
Test1: text with a (here some more text)
Test1: text with a (here some more text)
Test2: text wit a (here some more text [und undo])
new line here
Test3: text with a (parenthesis here
new line here
]])
end)
it('dragging starts Select mode even if coming from mapping vim-patch:8.2.4806', function()
command('set mouse=a')
command('set selectmode=mouse')
command('nnoremap <LeftDrag> <LeftDrag><Cmd><CR>')
poke_eventloop()
api.nvim_input_mouse('left', 'press', '', 0, 0, 0)
poke_eventloop()
api.nvim_input_mouse('left', 'drag', '', 0, 0, 1)
poke_eventloop()
eq('s', eval('mode()'))
end)
it('<LeftDrag> mapping in Insert mode works correctly vim-patch:8.2.4692', function()
command('set mouse=a')
command('inoremap <LeftDrag> <LeftDrag><Cmd>let g:dragged = 1<CR>')
feed('i')
poke_eventloop()
api.nvim_input_mouse('left', 'press', '', 0, 0, 0)
poke_eventloop()
api.nvim_input_mouse('left', 'drag', '', 0, 0, 1)
poke_eventloop()
eq(1, eval('g:dragged'))
eq('v', eval('mode()'))
feed([[<C-\><C-N>]])
command([[inoremap <LeftDrag> <LeftDrag><C-\><C-N>]])
feed('i')
poke_eventloop()
api.nvim_input_mouse('left', 'press', '', 0, 0, 0)
poke_eventloop()
api.nvim_input_mouse('left', 'drag', '', 0, 0, 1)
poke_eventloop()
eq('n', eval('mode()'))
end)
it('timeout works after an <Nop> mapping is triggered on timeout vim-patch:8.1.0052', function()
command('set timeout timeoutlen=400')
command('inoremap ab TEST')
command('inoremap a <Nop>')
-- Enter Insert mode
feed('i')
-- Wait for the "a" mapping to time out
feed('a')
sleep(500)
-- Send "a" and wait for a period shorter than 'timeoutlen'
feed('a')
sleep(100)
-- Send "b", should trigger the "ab" mapping
feed('b')
expect('TEST')
end)
end)