mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:7.4.2208
Problem: Test for mappings is old style.
Solution: Convert the test to new style.
2d1a248762
This commit is contained in:
parent
3f555cce3d
commit
ec4c12570c
@ -16,6 +16,7 @@ source test_lambda.vim
|
||||
source test_match.vim
|
||||
source test_matchadd_conceal_utf8.vim
|
||||
source test_menu.vim
|
||||
source test_mapping.vim
|
||||
source test_messages.vim
|
||||
source test_options.vim
|
||||
source test_partial.vim
|
||||
|
100
src/nvim/testdir/test_mapping.vim
Normal file
100
src/nvim/testdir/test_mapping.vim
Normal file
@ -0,0 +1,100 @@
|
||||
" Tests for mappings and abbreviations
|
||||
|
||||
if !has('multi_byte')
|
||||
finish
|
||||
endif
|
||||
|
||||
func Test_abbreviation()
|
||||
" abbreviation with 0x80 should work
|
||||
inoreab чкпр vim
|
||||
call feedkeys("Goчкпр \<Esc>", "xt")
|
||||
call assert_equal('vim ', getline('$'))
|
||||
iunab чкпр
|
||||
set nomodified
|
||||
endfunc
|
||||
|
||||
func Test_map_ctrl_c_insert()
|
||||
" mapping of ctrl-c in Insert mode
|
||||
set cpo-=< cpo-=k
|
||||
inoremap <c-c> <ctrl-c>
|
||||
cnoremap <c-c> dummy
|
||||
cunmap <c-c>
|
||||
call feedkeys("GoTEST2: CTRL-C |\<C-C>A|\<Esc>", "xt")
|
||||
call assert_equal('TEST2: CTRL-C |<ctrl-c>A|', getline('$'))
|
||||
unmap! <c-c>
|
||||
set nomodified
|
||||
endfunc
|
||||
|
||||
func Test_map_ctrl_c_visual()
|
||||
" mapping of ctrl-c in Visual mode
|
||||
vnoremap <c-c> :<C-u>$put ='vmap works'
|
||||
call feedkeys("GV\<C-C>\<CR>", "xt")
|
||||
call assert_equal('vmap works', getline('$'))
|
||||
vunmap <c-c>
|
||||
set nomodified
|
||||
endfunc
|
||||
|
||||
func Test_map_langmap()
|
||||
" langmap should not get remapped in insert mode
|
||||
inoremap { FAIL_ilangmap
|
||||
set langmap=+{ langnoremap
|
||||
call feedkeys("Go+\<Esc>", "xt")
|
||||
call assert_equal('+', getline('$'))
|
||||
|
||||
" Insert-mode expr mapping with langmap
|
||||
inoremap <expr> { "FAIL_iexplangmap"
|
||||
call feedkeys("Go+\<Esc>", "xt")
|
||||
call assert_equal('+', getline('$'))
|
||||
iunmap <expr> {
|
||||
|
||||
" langmap should not get remapped in Command-line mode
|
||||
cnoremap { FAIL_clangmap
|
||||
call feedkeys(":call append(line('$'), '+')\<CR>", "xt")
|
||||
call assert_equal('+', getline('$'))
|
||||
cunmap {
|
||||
|
||||
" Command-line mode expr mapping with langmap
|
||||
cnoremap <expr> { "FAIL_cexplangmap"
|
||||
call feedkeys(":call append(line('$'), '+')\<CR>", "xt")
|
||||
call assert_equal('+', getline('$'))
|
||||
cunmap {
|
||||
set nomodified
|
||||
endfunc
|
||||
|
||||
func Test_map_feedkeys()
|
||||
" issue #212 (feedkeys insert mapping at current position)
|
||||
nnoremap . :call feedkeys(".", "in")<cr>
|
||||
call setline('$', ['a b c d', 'a b c d'])
|
||||
$-1
|
||||
call feedkeys("0qqdw.ifoo\<Esc>qj0@q\<Esc>", "xt")
|
||||
call assert_equal(['fooc d', 'fooc d'], getline(line('$') - 1, line('$')))
|
||||
unmap .
|
||||
set nomodified
|
||||
endfunc
|
||||
|
||||
func Test_map_cursor()
|
||||
" <c-g>U<cursor> works only within a single line
|
||||
imapclear
|
||||
imap ( ()<c-g>U<left>
|
||||
call feedkeys("G2o\<Esc>ki\<CR>Test1: text with a (here some more text\<Esc>k.", "xt")
|
||||
call assert_equal('Test1: text with a (here some more text)', getline(line('$') - 2))
|
||||
call assert_equal('Test1: text with a (here some more text)', getline(line('$') - 1))
|
||||
|
||||
" test undo
|
||||
call feedkeys("G2o\<Esc>ki\<CR>Test2: text wit a (here some more text [und undo]\<C-G>u\<Esc>k.u", "xt")
|
||||
call assert_equal('', getline(line('$') - 2))
|
||||
call assert_equal('Test2: text wit a (here some more text [und undo])', getline(line('$') - 1))
|
||||
set nomodified
|
||||
imapclear
|
||||
endfunc
|
||||
|
||||
" This isn't actually testing a mapping, but similar use of CTRL-G U as above.
|
||||
func Test_break_undo()
|
||||
:set whichwrap=<,>,[,]
|
||||
call feedkeys("G4o2k", "xt")
|
||||
exe ":norm! iTest3: text with a (parenthesis here\<C-G>U\<Right>new line here\<esc>\<up>\<up>."
|
||||
call assert_equal('new line here', getline(line('$') - 3))
|
||||
call assert_equal('Test3: text with a (parenthesis here', getline(line('$') - 2))
|
||||
call assert_equal('new line here', getline(line('$') - 1))
|
||||
set nomodified
|
||||
endfunc
|
@ -232,7 +232,7 @@ static int included_patches[] = {
|
||||
// 2211 NA
|
||||
// 2210 NA
|
||||
// 2209,
|
||||
// 2208,
|
||||
2208,
|
||||
// 2207 NA
|
||||
// 2206 NA
|
||||
2205,
|
||||
|
Loading…
Reference in New Issue
Block a user