diff options
Diffstat (limited to 'test/functional/autocmd/textchanged_spec.lua')
-rw-r--r-- | test/functional/autocmd/textchanged_spec.lua | 27 |
1 files changed, 19 insertions, 8 deletions
diff --git a/test/functional/autocmd/textchanged_spec.lua b/test/functional/autocmd/textchanged_spec.lua index ffeb76835d..b90a0fd020 100644 --- a/test/functional/autocmd/textchanged_spec.lua +++ b/test/functional/autocmd/textchanged_spec.lua @@ -25,14 +25,15 @@ it('TextChangedI and TextChangedP autocommands', function() feed('o') poke_eventloop() feed('<esc>') - eq('I', eval('g:autocmd')) + -- TextChangedI triggers only if text is actually changed in Insert mode + eq('', eval('g:autocmd')) command([[let g:autocmd = '']]) feed('S') poke_eventloop() feed('f') poke_eventloop() - eq('II', eval('g:autocmd')) + eq('I', eval('g:autocmd')) feed('<esc>') command([[let g:autocmd = '']]) @@ -42,7 +43,7 @@ it('TextChangedI and TextChangedP autocommands', function() poke_eventloop() feed('<C-N>') poke_eventloop() - eq('IIP', eval('g:autocmd')) + eq('IP', eval('g:autocmd')) feed('<esc>') command([[let g:autocmd = '']]) @@ -54,7 +55,7 @@ it('TextChangedI and TextChangedP autocommands', function() poke_eventloop() feed('<C-N>') poke_eventloop() - eq('IIPP', eval('g:autocmd')) + eq('IPP', eval('g:autocmd')) feed('<esc>') command([[let g:autocmd = '']]) @@ -68,7 +69,7 @@ it('TextChangedI and TextChangedP autocommands', function() poke_eventloop() feed('<C-N>') poke_eventloop() - eq('IIPPP', eval('g:autocmd')) + eq('IPPP', eval('g:autocmd')) feed('<esc>') command([[let g:autocmd = '']]) @@ -83,7 +84,7 @@ it('TextChangedI and TextChangedP autocommands', function() feed('<C-N>') poke_eventloop() feed('<C-N>') - eq('IIPPPP', eval('g:autocmd')) + eq('IPPPP', eval('g:autocmd')) feed('<esc>') eq({'foo', 'bar', 'foobar', 'foo'}, eval('getline(1, "$")')) @@ -117,7 +118,7 @@ it('TextChangedI with setline()', function() end) -- oldtest: Test_Changed_ChangedI() -it('TextChanged is triggerd after TextChangedI', function() +it('TextChangedI and TextChanged', function() exec([[ let [g:autocmd_i, g:autocmd_n] = ['',''] @@ -141,10 +142,20 @@ it('TextChanged is triggerd after TextChangedI', function() feed('o') poke_eventloop() feed('<esc>') - eq('N5', eval('g:autocmd_n')) + eq('', eval('g:autocmd_n')) eq('I5', eval('g:autocmd_i')) command([[call feedkeys("yyp", 'tnix')]]) eq('N6', eval('g:autocmd_n')) eq('I5', eval('g:autocmd_i')) + + -- TextChangedI should only trigger if change was done in Insert mode + command([[let g:autocmd_i = '']]) + command([[call feedkeys("yypi\<esc>", 'tnix')]]) + eq('', eval('g:autocmd_i')) + + -- TextChanged should only trigger if change was done in Normal mode + command([[let g:autocmd_n = '']]) + command([[call feedkeys("ibar\<esc>", 'tnix')]]) + eq('', eval('g:autocmd_n')) end) |