xref: /vim-8.2.3635/src/testdir/test_normal.vim (revision 01a6c216)
1" Test for various Normal mode commands
2
3func Setup_NewWindow()
4  10new
5  call setline(1, range(1,100))
6endfunc
7
8func MyFormatExpr()
9  " Adds '->$' at lines having numbers followed by trailing whitespace
10  for ln in range(v:lnum, v:lnum+v:count-1)
11    let line = getline(ln)
12    if getline(ln) =~# '\d\s\+$'
13      call setline(ln, substitute(line, '\s\+$', '', '') . '->$')
14    endif
15  endfor
16endfunc
17
18func CountSpaces(type, ...)
19  " for testing operatorfunc
20  " will count the number of spaces
21  " and return the result in g:a
22  let sel_save = &selection
23  let &selection = "inclusive"
24  let reg_save = @@
25
26  if a:0  " Invoked from Visual mode, use gv command.
27    silent exe "normal! gvy"
28  elseif a:type == 'line'
29    silent exe "normal! '[V']y"
30  else
31    silent exe "normal! `[v`]y"
32  endif
33  let g:a=strlen(substitute(@@, '[^ ]', '', 'g'))
34  let &selection = sel_save
35  let @@ = reg_save
36endfunc
37
38func OpfuncDummy(type, ...)
39  " for testing operatorfunc
40  let g:opt=&linebreak
41
42  if a:0  " Invoked from Visual mode, use gv command.
43    silent exe "normal! gvy"
44  elseif a:type == 'line'
45    silent exe "normal! '[V']y"
46  else
47    silent exe "normal! `[v`]y"
48  endif
49  " Create a new dummy window
50  new
51  let g:bufnr=bufnr('%')
52endfunc
53
54fun! Test_normal00_optrans()
55  new
56  call append(0, ['1 This is a simple test: abcd', '2 This is the second line', '3 this is the third line'])
57  1
58  exe "norm! Sfoobar\<esc>"
59  call assert_equal(['foobar', '2 This is the second line', '3 this is the third line', ''], getline(1,'$'))
60  2
61  exe "norm! $vbsone"
62  call assert_equal(['foobar', '2 This is the second one', '3 this is the third line', ''], getline(1,'$'))
63  norm! VS Second line here
64  call assert_equal(['foobar', ' Second line here', '3 this is the third line', ''], getline(1, '$'))
65  %d
66  call append(0, ['4 This is a simple test: abcd', '5 This is the second line', '6 this is the third line'])
67  call append(0, ['1 This is a simple test: abcd', '2 This is the second line', '3 this is the third line'])
68
69  1
70  norm! 2D
71  call assert_equal(['3 this is the third line', '4 This is a simple test: abcd', '5 This is the second line', '6 this is the third line', ''], getline(1,'$'))
72  set cpo+=#
73  norm! 4D
74  call assert_equal(['', '4 This is a simple test: abcd', '5 This is the second line', '6 this is the third line', ''], getline(1,'$'))
75
76  " clean up
77  set cpo-=#
78  bw!
79endfunc
80
81func Test_normal01_keymodel()
82  call Setup_NewWindow()
83  " Test 1: depending on 'keymodel' <s-down> does something different
84  50
85  call feedkeys("V\<S-Up>y", 'tx')
86  call assert_equal(['47', '48', '49', '50'], getline("'<", "'>"))
87  set keymodel=startsel
88  50
89  call feedkeys("V\<S-Up>y", 'tx')
90  call assert_equal(['49', '50'], getline("'<", "'>"))
91  " Start visual mode when keymodel = startsel
92  50
93  call feedkeys("\<S-Up>y", 'tx')
94  call assert_equal(['49', '5'], getreg(0, 0, 1))
95  " Do not start visual mode when keymodel=
96  set keymodel=
97  50
98  call feedkeys("\<S-Up>y$", 'tx')
99  call assert_equal(['42'], getreg(0, 0, 1))
100  " Stop visual mode when keymodel=stopsel
101  set keymodel=stopsel
102  50
103  call feedkeys("Vkk\<Up>yy", 'tx')
104  call assert_equal(['47'], getreg(0, 0, 1))
105
106  set keymodel=
107  50
108  call feedkeys("Vkk\<Up>yy", 'tx')
109  call assert_equal(['47', '48', '49', '50'], getreg(0, 0, 1))
110
111  " clean up
112  bw!
113endfunc
114
115func Test_normal02_selectmode()
116  " some basic select mode tests
117  call Setup_NewWindow()
118  50
119  norm! gHy
120  call assert_equal('y51', getline('.'))
121  call setline(1, range(1,100))
122  50
123  exe ":norm! V9jo\<c-g>y"
124  call assert_equal('y60', getline('.'))
125  " clean up
126  bw!
127endfunc
128
129func Test_normal02_selectmode2()
130  " some basic select mode tests
131  call Setup_NewWindow()
132  50
133  call feedkeys(":set im\n\<c-o>gHc\<c-o>:set noim\n", 'tx')
134  call assert_equal('c51', getline('.'))
135  " clean up
136  bw!
137endfunc
138
139func Test_normal03_join()
140  " basic join test
141  call Setup_NewWindow()
142  50
143  norm! VJ
144  call assert_equal('50 51', getline('.'))
145  $
146  norm! J
147  call assert_equal('100', getline('.'))
148  $
149  norm! V9-gJ
150  call assert_equal('919293949596979899100', getline('.'))
151  call setline(1, range(1,100))
152  $
153  :j 10
154  call assert_equal('100', getline('.'))
155  " clean up
156  bw!
157endfunc
158
159func Test_normal04_filter()
160  " basic filter test
161  " only test on non windows platform
162  if has('win32')
163    return
164  endif
165  call Setup_NewWindow()
166  1
167  call feedkeys("!!sed -e 's/^/|    /'\n", 'tx')
168  call assert_equal('|    1', getline('.'))
169  90
170  :sil :!echo one
171  call feedkeys('.', 'tx')
172  call assert_equal('|    90', getline('.'))
173  95
174  set cpo+=!
175  " 2 <CR>, 1: for executing the command,
176  "         2: clear hit-enter-prompt
177  call feedkeys("!!\n", 'tx')
178  call feedkeys(":!echo one\n\n", 'tx')
179  call feedkeys(".", 'tx')
180  call assert_equal('one', getline('.'))
181  set cpo-=!
182  bw!
183endfunc
184
185func Test_normal05_formatexpr()
186  " basic formatexpr test
187  call Setup_NewWindow()
188  %d_
189  call setline(1, ['here: 1   ', '2', 'here: 3   ', '4', 'not here:   '])
190  1
191  set formatexpr=MyFormatExpr()
192  norm! gqG
193  call assert_equal(['here: 1->$', '2', 'here: 3->$', '4', 'not here:   '], getline(1,'$'))
194  set formatexpr=
195  bw!
196endfunc
197
198func Test_normal05_formatexpr_newbuf()
199  " Edit another buffer in the 'formatexpr' function
200  new
201  func! Format()
202    edit another
203  endfunc
204  set formatexpr=Format()
205  norm gqG
206  bw!
207  set formatexpr=
208endfunc
209
210func Test_normal05_formatexpr_setopt()
211  " Change the 'formatexpr' value in the function
212  new
213  func! Format()
214    set formatexpr=
215  endfunc
216  set formatexpr=Format()
217  norm gqG
218  bw!
219  set formatexpr=
220endfunc
221
222func Test_normal06_formatprg()
223  " basic test for formatprg
224  " only test on non windows platform
225  if has('win32')
226    return
227  endif
228
229  " uses sed to number non-empty lines
230  call writefile(['#!/bin/sh', 'sed ''/./=''|sed ''/./{', 'N', 's/\n/    /', '}'''], 'Xsed_format.sh')
231  call system('chmod +x ./Xsed_format.sh')
232  let text = ['a', '', 'c', '', ' ', 'd', 'e']
233  let expected = ['1    a', '', '3    c', '', '5     ', '6    d', '7    e']
234
235  10new
236  call setline(1, text)
237  set formatprg=./Xsed_format.sh
238  norm! gggqG
239  call assert_equal(expected, getline(1, '$'))
240  bw!
241
242  10new
243  call setline(1, text)
244  set formatprg=donothing
245  setlocal formatprg=./Xsed_format.sh
246  norm! gggqG
247  call assert_equal(expected, getline(1, '$'))
248  bw!
249
250  " clean up
251  set formatprg=
252  setlocal formatprg=
253  call delete('Xsed_format.sh')
254endfunc
255
256func Test_normal07_internalfmt()
257  " basic test for internal formmatter to textwidth of 12
258  let list=range(1,11)
259  call map(list, 'v:val."    "')
260  10new
261  call setline(1, list)
262  set tw=12
263  norm! gggqG
264  call assert_equal(['1    2    3', '4    5    6', '7    8    9', '10    11    '], getline(1, '$'))
265  " clean up
266  set tw=0
267  bw!
268endfunc
269
270func Test_normal08_fold()
271  " basic tests for foldopen/folddelete
272  if !has("folding")
273    return
274  endif
275  call Setup_NewWindow()
276  50
277  setl foldenable fdm=marker
278  " First fold
279  norm! V4jzf
280  " check that folds have been created
281  call assert_equal(['50/*{{{*/', '51', '52', '53', '54/*}}}*/'], getline(50,54))
282  " Second fold
283  46
284  norm! V10jzf
285  " check that folds have been created
286  call assert_equal('46/*{{{*/', getline(46))
287  call assert_equal('60/*}}}*/', getline(60))
288  norm! k
289  call assert_equal('45', getline('.'))
290  norm! j
291  call assert_equal('46/*{{{*/', getline('.'))
292  norm! j
293  call assert_equal('61', getline('.'))
294  norm! k
295  " open a fold
296  norm! Vzo
297  norm! k
298  call assert_equal('45', getline('.'))
299  norm! j
300  call assert_equal('46/*{{{*/', getline('.'))
301  norm! j
302  call assert_equal('47', getline('.'))
303  norm! k
304  norm! zcVzO
305  call assert_equal('46/*{{{*/', getline('.'))
306  norm! j
307  call assert_equal('47', getline('.'))
308  norm! j
309  call assert_equal('48', getline('.'))
310  norm! j
311  call assert_equal('49', getline('.'))
312  norm! j
313  call assert_equal('50/*{{{*/', getline('.'))
314  norm! j
315  call assert_equal('51', getline('.'))
316  " delete folds
317  :46
318  " collapse fold
319  norm! V14jzC
320  " delete all folds recursively
321  norm! VzD
322  call assert_equal(['46', '47', '48', '49', '50', '51', '52', '53', '54', '55', '56', '57', '58', '59', '60'], getline(46,60))
323
324  " clean up
325  setl nofoldenable fdm=marker
326  bw!
327endfunc
328
329func Test_normal09_operatorfunc()
330  " Test operatorfunc
331  call Setup_NewWindow()
332  " Add some spaces for counting
333  50,60s/$/  /
334  unlet! g:a
335  let g:a=0
336  nmap <buffer><silent> ,, :set opfunc=CountSpaces<CR>g@
337  vmap <buffer><silent> ,, :<C-U>call CountSpaces(visualmode(), 1)<CR>
338  50
339  norm V2j,,
340  call assert_equal(6, g:a)
341  norm V,,
342  call assert_equal(2, g:a)
343  norm ,,l
344  call assert_equal(0, g:a)
345  50
346  exe "norm 0\<c-v>10j2l,,"
347  call assert_equal(11, g:a)
348  50
349  norm V10j,,
350  call assert_equal(22, g:a)
351
352  " clean up
353  unmap <buffer> ,,
354  set opfunc=
355  unlet! g:a
356  bw!
357endfunc
358
359func Test_normal09a_operatorfunc()
360  " Test operatorfunc
361  call Setup_NewWindow()
362  " Add some spaces for counting
363  50,60s/$/  /
364  unlet! g:opt
365  set linebreak
366  nmap <buffer><silent> ,, :set opfunc=OpfuncDummy<CR>g@
367  50
368  norm ,,j
369  exe "bd!" g:bufnr
370  call assert_true(&linebreak)
371  call assert_equal(g:opt, &linebreak)
372  set nolinebreak
373  norm ,,j
374  exe "bd!" g:bufnr
375  call assert_false(&linebreak)
376  call assert_equal(g:opt, &linebreak)
377
378  " clean up
379  unmap <buffer> ,,
380  set opfunc=
381  bw!
382  unlet! g:opt
383endfunc
384
385func Test_normal10_expand()
386  " Test for expand()
387  10new
388  call setline(1, ['1', 'ifooar,,cbar'])
389  2
390  norm! $
391  call assert_equal('cbar', expand('<cword>'))
392  call assert_equal('ifooar,,cbar', expand('<cWORD>'))
393
394  call setline(1, ['prx = list[idx];'])
395  1
396  let expected = ['', 'prx', 'prx', 'prx',
397	\ 'list', 'list', 'list', 'list', 'list', 'list', 'list',
398	\ 'idx', 'idx', 'idx', 'idx',
399	\ 'list[idx]',
400	\ '];',
401	\ ]
402  for i in range(1, 16)
403    exe 'norm ' . i . '|'
404    call assert_equal(expected[i], expand('<cexpr>'), 'i == ' . i)
405  endfor
406
407  if executable('echo')
408    " Test expand(`...`) i.e. backticks command expansion.
409    " MS-Windows has a trailing space.
410    call assert_match('^abcde *$', expand('`echo abcde`'))
411  endif
412
413  " Test expand(`=...`) i.e. backticks expression expansion
414  call assert_equal('5', expand('`=2+3`'))
415
416  " clean up
417  bw!
418endfunc
419
420func Test_normal11_showcmd()
421  " test for 'showcmd'
422  10new
423  exe "norm! ofoobar\<esc>"
424  call assert_equal(2, line('$'))
425  set showcmd
426  exe "norm! ofoobar2\<esc>"
427  call assert_equal(3, line('$'))
428  exe "norm! VAfoobar3\<esc>"
429  call assert_equal(3, line('$'))
430  exe "norm! 0d3\<del>2l"
431  call assert_equal('obar2foobar3', getline('.'))
432  bw!
433endfunc
434
435func Test_normal12_nv_error()
436  " Test for nv_error
437  10new
438  call setline(1, range(1,5))
439  " should not do anything, just beep
440  exe "norm! <c-k>"
441  call assert_equal(map(range(1,5), 'string(v:val)'), getline(1,'$'))
442  bw!
443endfunc
444
445func Test_normal13_help()
446  " Test for F1
447  call assert_equal(1, winnr())
448  call feedkeys("\<f1>", 'txi')
449  call assert_match('help\.txt', bufname('%'))
450  call assert_equal(2, winnr('$'))
451  bw!
452endfunc
453
454func Test_normal14_page()
455  " basic test for Ctrl-F and Ctrl-B
456  call Setup_NewWindow()
457  exe "norm! \<c-f>"
458  call assert_equal('9', getline('.'))
459  exe "norm! 2\<c-f>"
460  call assert_equal('25', getline('.'))
461  exe "norm! 2\<c-b>"
462  call assert_equal('18', getline('.'))
463  1
464  set scrolloff=5
465  exe "norm! 2\<c-f>"
466  call assert_equal('21', getline('.'))
467  exe "norm! \<c-b>"
468  call assert_equal('13', getline('.'))
469  1
470  set scrolloff=99
471  exe "norm! \<c-f>"
472  call assert_equal('13', getline('.'))
473  set scrolloff=0
474  100
475  exe "norm! $\<c-b>"
476  call assert_equal('92', getline('.'))
477  call assert_equal([0, 92, 1, 0, 1], getcurpos())
478  100
479  set nostartofline
480  exe "norm! $\<c-b>"
481  call assert_equal('92', getline('.'))
482  call assert_equal([0, 92, 2, 0, 2147483647], getcurpos())
483  " cleanup
484  set startofline
485  bw!
486endfunc
487
488func Test_normal14_page_eol()
489  10new
490  norm oxxxxxxx
491  exe "norm 2\<c-f>"
492  " check with valgrind that cursor is put back in column 1
493  exe "norm 2\<c-b>"
494  bw!
495endfunc
496
497func Test_normal15_z_scroll_vert()
498  " basic test for z commands that scroll the window
499  call Setup_NewWindow()
500  100
501  norm! >>
502  " Test for z<cr>
503  exe "norm! z\<cr>"
504  call assert_equal('	100', getline('.'))
505  call assert_equal(100, winsaveview()['topline'])
506  call assert_equal([0, 100, 2, 0, 9], getcurpos())
507
508  " Test for zt
509  21
510  norm! >>0zt
511  call assert_equal('	21', getline('.'))
512  call assert_equal(21, winsaveview()['topline'])
513  call assert_equal([0, 21, 1, 0, 8], getcurpos())
514
515  " Test for zb
516  30
517  norm! >>$ztzb
518  call assert_equal('	30', getline('.'))
519  call assert_equal(30, winsaveview()['topline']+winheight(0)-1)
520  call assert_equal([0, 30, 3, 0, 2147483647], getcurpos())
521
522  " Test for z-
523  1
524  30
525  norm! 0z-
526  call assert_equal('	30', getline('.'))
527  call assert_equal(30, winsaveview()['topline']+winheight(0)-1)
528  call assert_equal([0, 30, 2, 0, 9], getcurpos())
529
530  " Test for z{height}<cr>
531  call assert_equal(10, winheight(0))
532  exe "norm! z12\<cr>"
533  call assert_equal(12, winheight(0))
534  exe "norm! z10\<cr>"
535  call assert_equal(10, winheight(0))
536
537  " Test for z.
538  1
539  21
540  norm! 0z.
541  call assert_equal('	21', getline('.'))
542  call assert_equal(17, winsaveview()['topline'])
543  call assert_equal([0, 21, 2, 0, 9], getcurpos())
544
545  " Test for zz
546  1
547  21
548  norm! 0zz
549  call assert_equal('	21', getline('.'))
550  call assert_equal(17, winsaveview()['topline'])
551  call assert_equal([0, 21, 1, 0, 8], getcurpos())
552
553  " Test for z+
554  11
555  norm! zt
556  norm! z+
557  call assert_equal('	21', getline('.'))
558  call assert_equal(21, winsaveview()['topline'])
559  call assert_equal([0, 21, 2, 0, 9], getcurpos())
560
561  " Test for [count]z+
562  1
563  norm! 21z+
564  call assert_equal('	21', getline('.'))
565  call assert_equal(21, winsaveview()['topline'])
566  call assert_equal([0, 21, 2, 0, 9], getcurpos())
567
568  " Test for z^
569  norm! 22z+0
570  norm! z^
571  call assert_equal('	21', getline('.'))
572  call assert_equal(12, winsaveview()['topline'])
573  call assert_equal([0, 21, 2, 0, 9], getcurpos())
574
575  " Test for [count]z^
576  1
577  norm! 30z^
578  call assert_equal('	21', getline('.'))
579  call assert_equal(12, winsaveview()['topline'])
580  call assert_equal([0, 21, 2, 0, 9], getcurpos())
581
582  " cleanup
583  bw!
584endfunc
585
586func Test_normal16_z_scroll_hor()
587  " basic test for z commands that scroll the window
588  10new
589  15vsp
590  set nowrap listchars=
591  let lineA='abcdefghijklmnopqrstuvwxyz'
592  let lineB='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
593  $put =lineA
594  $put =lineB
595  1d
596
597  " Test for zl
598  1
599  norm! 5zl
600  call assert_equal(lineA, getline('.'))
601  call assert_equal(6, col('.'))
602  call assert_equal(5, winsaveview()['leftcol'])
603  norm! yl
604  call assert_equal('f', @0)
605
606  " Test for zh
607  norm! 2zh
608  call assert_equal(lineA, getline('.'))
609  call assert_equal(6, col('.'))
610  norm! yl
611  call assert_equal('f', @0)
612  call assert_equal(3, winsaveview()['leftcol'])
613
614  " Test for zL
615  norm! zL
616  call assert_equal(11, col('.'))
617  norm! yl
618  call assert_equal('k', @0)
619  call assert_equal(10, winsaveview()['leftcol'])
620  norm! 2zL
621  call assert_equal(25, col('.'))
622  norm! yl
623  call assert_equal('y', @0)
624  call assert_equal(24, winsaveview()['leftcol'])
625
626  " Test for zH
627  norm! 2zH
628  call assert_equal(25, col('.'))
629  call assert_equal(10, winsaveview()['leftcol'])
630  norm! yl
631  call assert_equal('y', @0)
632
633  " Test for zs
634  norm! $zs
635  call assert_equal(26, col('.'))
636  call assert_equal(25, winsaveview()['leftcol'])
637  norm! yl
638  call assert_equal('z', @0)
639
640  " Test for ze
641  norm! ze
642  call assert_equal(26, col('.'))
643  call assert_equal(11, winsaveview()['leftcol'])
644  norm! yl
645  call assert_equal('z', @0)
646
647  " cleanup
648  set wrap listchars=eol:$
649  bw!
650endfunc
651
652func Test_normal17_z_scroll_hor2()
653  " basic test for z commands that scroll the window
654  " using 'sidescrolloff' setting
655  10new
656  20vsp
657  set nowrap listchars= sidescrolloff=5
658  let lineA='abcdefghijklmnopqrstuvwxyz'
659  let lineB='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
660  $put =lineA
661  $put =lineB
662  1d
663
664  " Test for zl
665  1
666  norm! 5zl
667  call assert_equal(lineA, getline('.'))
668  call assert_equal(11, col('.'))
669  call assert_equal(5, winsaveview()['leftcol'])
670  norm! yl
671  call assert_equal('k', @0)
672
673  " Test for zh
674  norm! 2zh
675  call assert_equal(lineA, getline('.'))
676  call assert_equal(11, col('.'))
677  norm! yl
678  call assert_equal('k', @0)
679  call assert_equal(3, winsaveview()['leftcol'])
680
681  " Test for zL
682  norm! 0zL
683  call assert_equal(16, col('.'))
684  norm! yl
685  call assert_equal('p', @0)
686  call assert_equal(10, winsaveview()['leftcol'])
687  norm! 2zL
688  call assert_equal(26, col('.'))
689  norm! yl
690  call assert_equal('z', @0)
691  call assert_equal(15, winsaveview()['leftcol'])
692
693  " Test for zH
694  norm! 2zH
695  call assert_equal(15, col('.'))
696  call assert_equal(0, winsaveview()['leftcol'])
697  norm! yl
698  call assert_equal('o', @0)
699
700  " Test for zs
701  norm! $zs
702  call assert_equal(26, col('.'))
703  call assert_equal(20, winsaveview()['leftcol'])
704  norm! yl
705  call assert_equal('z', @0)
706
707  " Test for ze
708  norm! ze
709  call assert_equal(26, col('.'))
710  call assert_equal(11, winsaveview()['leftcol'])
711  norm! yl
712  call assert_equal('z', @0)
713
714  " cleanup
715  set wrap listchars=eol:$ sidescrolloff=0
716  bw!
717endfunc
718
719func Test_normal18_z_fold()
720  " basic tests for foldopen/folddelete
721  if !has("folding")
722    return
723  endif
724  call Setup_NewWindow()
725  50
726  setl foldenable fdm=marker foldlevel=5
727
728  " Test for zF
729  " First fold
730  norm! 4zF
731  " check that folds have been created
732  call assert_equal(['50/*{{{*/', '51', '52', '53/*}}}*/'], getline(50,53))
733
734  " Test for zd
735  51
736  norm! 2zF
737  call assert_equal(2, foldlevel('.'))
738  norm! kzd
739  call assert_equal(['50', '51/*{{{*/', '52/*}}}*/', '53'], getline(50,53))
740  norm! j
741  call assert_equal(1, foldlevel('.'))
742
743  " Test for zD
744  " also deletes partially selected folds recursively
745  51
746  norm! zF
747  call assert_equal(2, foldlevel('.'))
748  norm! kV2jzD
749  call assert_equal(['50', '51', '52', '53'], getline(50,53))
750
751  " Test for zE
752  85
753  norm! 4zF
754  86
755  norm! 2zF
756  90
757  norm! 4zF
758  call assert_equal(['85/*{{{*/', '86/*{{{*/', '87/*}}}*/', '88/*}}}*/', '89', '90/*{{{*/', '91', '92', '93/*}}}*/'], getline(85,93))
759  norm! zE
760  call assert_equal(['85', '86', '87', '88', '89', '90', '91', '92', '93'], getline(85,93))
761
762  " Test for zn
763  50
764  set foldlevel=0
765  norm! 2zF
766  norm! zn
767  norm! k
768  call assert_equal('49', getline('.'))
769  norm! j
770  call assert_equal('50/*{{{*/', getline('.'))
771  norm! j
772  call assert_equal('51/*}}}*/', getline('.'))
773  norm! j
774  call assert_equal('52', getline('.'))
775  call assert_equal(0, &foldenable)
776
777  " Test for zN
778  49
779  norm! zN
780  call assert_equal('49', getline('.'))
781  norm! j
782  call assert_equal('50/*{{{*/', getline('.'))
783  norm! j
784  call assert_equal('52', getline('.'))
785  call assert_equal(1, &foldenable)
786
787  " Test for zi
788  norm! zi
789  call assert_equal(0, &foldenable)
790  norm! zi
791  call assert_equal(1, &foldenable)
792  norm! zi
793  call assert_equal(0, &foldenable)
794  norm! zi
795  call assert_equal(1, &foldenable)
796
797  " Test for za
798  50
799  norm! za
800  norm! k
801  call assert_equal('49', getline('.'))
802  norm! j
803  call assert_equal('50/*{{{*/', getline('.'))
804  norm! j
805  call assert_equal('51/*}}}*/', getline('.'))
806  norm! j
807  call assert_equal('52', getline('.'))
808  50
809  norm! za
810  norm! k
811  call assert_equal('49', getline('.'))
812  norm! j
813  call assert_equal('50/*{{{*/', getline('.'))
814  norm! j
815  call assert_equal('52', getline('.'))
816
817  49
818  norm! 5zF
819  norm! k
820  call assert_equal('48', getline('.'))
821  norm! j
822  call assert_equal('49/*{{{*/', getline('.'))
823  norm! j
824  call assert_equal('55', getline('.'))
825  49
826  norm! za
827  call assert_equal('49/*{{{*/', getline('.'))
828  norm! j
829  call assert_equal('50/*{{{*/', getline('.'))
830  norm! j
831  call assert_equal('52', getline('.'))
832  set nofoldenable
833  " close fold and set foldenable
834  norm! za
835  call assert_equal(1, &foldenable)
836
837  50
838  " have to use {count}za to open all folds and make the cursor visible
839  norm! 2za
840  norm! 2k
841  call assert_equal('48', getline('.'))
842  norm! j
843  call assert_equal('49/*{{{*/', getline('.'))
844  norm! j
845  call assert_equal('50/*{{{*/', getline('.'))
846  norm! j
847  call assert_equal('51/*}}}*/', getline('.'))
848  norm! j
849  call assert_equal('52', getline('.'))
850
851  " Test for zA
852  49
853  set foldlevel=0
854  50
855  norm! zA
856  norm! 2k
857  call assert_equal('48', getline('.'))
858  norm! j
859  call assert_equal('49/*{{{*/', getline('.'))
860  norm! j
861  call assert_equal('50/*{{{*/', getline('.'))
862  norm! j
863  call assert_equal('51/*}}}*/', getline('.'))
864  norm! j
865  call assert_equal('52', getline('.'))
866
867  " zA on a opened fold when foldenable is not set
868  50
869  set nofoldenable
870  norm! zA
871  call assert_equal(1, &foldenable)
872  norm! k
873  call assert_equal('48', getline('.'))
874  norm! j
875  call assert_equal('49/*{{{*/', getline('.'))
876  norm! j
877  call assert_equal('55', getline('.'))
878
879  " Test for zc
880  norm! zE
881  50
882  norm! 2zF
883  49
884  norm! 5zF
885  set nofoldenable
886  50
887  " There most likely is a bug somewhere:
888  " https://groups.google.com/d/msg/vim_dev/v2EkfJ_KQjI/u-Cvv94uCAAJ
889  " TODO: Should this only close the inner most fold or both folds?
890  norm! zc
891  call assert_equal(1, &foldenable)
892  norm! k
893  call assert_equal('48', getline('.'))
894  norm! j
895  call assert_equal('49/*{{{*/', getline('.'))
896  norm! j
897  call assert_equal('55', getline('.'))
898  set nofoldenable
899  50
900  norm! Vjzc
901  norm! k
902  call assert_equal('48', getline('.'))
903  norm! j
904  call assert_equal('49/*{{{*/', getline('.'))
905  norm! j
906  call assert_equal('55', getline('.'))
907
908  " Test for zC
909  set nofoldenable
910  50
911  norm! zCk
912  call assert_equal('48', getline('.'))
913  norm! j
914  call assert_equal('49/*{{{*/', getline('.'))
915  norm! j
916  call assert_equal('55', getline('.'))
917
918  " Test for zx
919  " 1) close folds at line 49-54
920  set nofoldenable
921  48
922  norm! zx
923  call assert_equal(1, &foldenable)
924  norm! j
925  call assert_equal('49/*{{{*/', getline('.'))
926  norm! j
927  call assert_equal('55', getline('.'))
928
929  " 2) do not close fold under cursor
930  51
931  set nofoldenable
932  norm! zx
933  call assert_equal(1, &foldenable)
934  norm! 3k
935  call assert_equal('48', getline('.'))
936  norm! j
937  call assert_equal('49/*{{{*/', getline('.'))
938  norm! j
939  call assert_equal('50/*{{{*/', getline('.'))
940  norm! j
941  call assert_equal('51/*}}}*/', getline('.'))
942  norm! j
943  call assert_equal('52', getline('.'))
944  norm! j
945  call assert_equal('53', getline('.'))
946  norm! j
947  call assert_equal('54/*}}}*/', getline('.'))
948  norm! j
949  call assert_equal('55', getline('.'))
950
951  " 3) close one level of folds
952  48
953  set nofoldenable
954  set foldlevel=1
955  norm! zx
956  call assert_equal(1, &foldenable)
957  call assert_equal('48', getline('.'))
958  norm! j
959  call assert_equal('49/*{{{*/', getline('.'))
960  norm! j
961  call assert_equal('50/*{{{*/', getline('.'))
962  norm! j
963  call assert_equal('52', getline('.'))
964  norm! j
965  call assert_equal('53', getline('.'))
966  norm! j
967  call assert_equal('54/*}}}*/', getline('.'))
968  norm! j
969  call assert_equal('55', getline('.'))
970
971  " Test for zX
972  " Close all folds
973  set foldlevel=0 nofoldenable
974  50
975  norm! zX
976  call assert_equal(1, &foldenable)
977  norm! k
978  call assert_equal('48', getline('.'))
979  norm! j
980  call assert_equal('49/*{{{*/', getline('.'))
981  norm! j
982  call assert_equal('55', getline('.'))
983
984  " Test for zm
985  50
986  set nofoldenable foldlevel=2
987  norm! zm
988  call assert_equal(1, &foldenable)
989  call assert_equal(1, &foldlevel)
990  norm! zm
991  call assert_equal(0, &foldlevel)
992  norm! zm
993  call assert_equal(0, &foldlevel)
994  norm! k
995  call assert_equal('48', getline('.'))
996  norm! j
997  call assert_equal('49/*{{{*/', getline('.'))
998  norm! j
999  call assert_equal('55', getline('.'))
1000
1001  " Test for zM
1002  48
1003  set nofoldenable foldlevel=99
1004  norm! zM
1005  call assert_equal(1, &foldenable)
1006  call assert_equal(0, &foldlevel)
1007  call assert_equal('48', getline('.'))
1008  norm! j
1009  call assert_equal('49/*{{{*/', getline('.'))
1010  norm! j
1011  call assert_equal('55', getline('.'))
1012
1013  " Test for zr
1014  48
1015  set nofoldenable foldlevel=0
1016  norm! zr
1017  call assert_equal(0, &foldenable)
1018  call assert_equal(1, &foldlevel)
1019  set foldlevel=0 foldenable
1020  norm! zr
1021  call assert_equal(1, &foldenable)
1022  call assert_equal(1, &foldlevel)
1023  norm! zr
1024  call assert_equal(2, &foldlevel)
1025  call assert_equal('48', getline('.'))
1026  norm! j
1027  call assert_equal('49/*{{{*/', getline('.'))
1028  norm! j
1029  call assert_equal('50/*{{{*/', getline('.'))
1030  norm! j
1031  call assert_equal('51/*}}}*/', getline('.'))
1032  norm! j
1033  call assert_equal('52', getline('.'))
1034
1035  " Test for zR
1036  48
1037  set nofoldenable foldlevel=0
1038  norm! zR
1039  call assert_equal(0, &foldenable)
1040  call assert_equal(2, &foldlevel)
1041  set foldenable foldlevel=0
1042  norm! zR
1043  call assert_equal(1, &foldenable)
1044  call assert_equal(2, &foldlevel)
1045  call assert_equal('48', getline('.'))
1046  norm! j
1047  call assert_equal('49/*{{{*/', getline('.'))
1048  norm! j
1049  call assert_equal('50/*{{{*/', getline('.'))
1050  norm! j
1051  call assert_equal('51/*}}}*/', getline('.'))
1052  norm! j
1053  call assert_equal('52', getline('.'))
1054  call append(50, ['a /*{{{*/', 'b /*}}}*/'])
1055  48
1056  call assert_equal('48', getline('.'))
1057  norm! j
1058  call assert_equal('49/*{{{*/', getline('.'))
1059  norm! j
1060  call assert_equal('50/*{{{*/', getline('.'))
1061  norm! j
1062  call assert_equal('a /*{{{*/', getline('.'))
1063  norm! j
1064  call assert_equal('51/*}}}*/', getline('.'))
1065  norm! j
1066  call assert_equal('52', getline('.'))
1067  48
1068  norm! zR
1069  call assert_equal(1, &foldenable)
1070  call assert_equal(3, &foldlevel)
1071  call assert_equal('48', getline('.'))
1072  norm! j
1073  call assert_equal('49/*{{{*/', getline('.'))
1074  norm! j
1075  call assert_equal('50/*{{{*/', getline('.'))
1076  norm! j
1077  call assert_equal('a /*{{{*/', getline('.'))
1078  norm! j
1079  call assert_equal('b /*}}}*/', getline('.'))
1080  norm! j
1081  call assert_equal('51/*}}}*/', getline('.'))
1082  norm! j
1083  call assert_equal('52', getline('.'))
1084
1085  " clean up
1086  setl nofoldenable fdm=marker foldlevel=0
1087  bw!
1088endfunc
1089
1090func Test_normal19_z_spell()
1091  if !has("spell") || !has('syntax')
1092    return
1093  endif
1094  new
1095  call append(0, ['1 good', '2 goood', '3 goood'])
1096  set spell spellfile=./Xspellfile.add spelllang=en
1097  let oldlang=v:lang
1098  lang C
1099
1100  " Test for zg
1101  1
1102  norm! ]s
1103  call assert_equal('2 goood', getline('.'))
1104  norm! zg
1105  1
1106  let a=execute('unsilent :norm! ]s')
1107  call assert_equal('1 good', getline('.'))
1108  call assert_equal('search hit BOTTOM, continuing at TOP', a[1:])
1109  let cnt=readfile('./Xspellfile.add')
1110  call assert_equal('goood', cnt[0])
1111
1112  " Test for zw
1113  2
1114  norm! $zw
1115  1
1116  norm! ]s
1117  call assert_equal('2 goood', getline('.'))
1118  let cnt=readfile('./Xspellfile.add')
1119  call assert_equal('#oood', cnt[0])
1120  call assert_equal('goood/!', cnt[1])
1121
1122  " Test for zg in visual mode
1123  let a=execute('unsilent :norm! V$zg')
1124  call assert_equal("Word '2 goood' added to ./Xspellfile.add", a[1:])
1125  1
1126  norm! ]s
1127  call assert_equal('3 goood', getline('.'))
1128  let cnt=readfile('./Xspellfile.add')
1129  call assert_equal('2 goood', cnt[2])
1130  " Remove "2 good" from spellfile
1131  2
1132  let a=execute('unsilent norm! V$zw')
1133  call assert_equal("Word '2 goood' added to ./Xspellfile.add", a[1:])
1134  let cnt=readfile('./Xspellfile.add')
1135  call assert_equal('2 goood/!', cnt[3])
1136
1137  " Test for zG
1138  let a=execute('unsilent norm! V$zG')
1139  call assert_match("Word '2 goood' added to .*", a)
1140  let fname=matchstr(a, 'to\s\+\zs\f\+$')
1141  let cnt=readfile(fname)
1142  call assert_equal('2 goood', cnt[0])
1143
1144  " Test for zW
1145  let a=execute('unsilent norm! V$zW')
1146  call assert_match("Word '2 goood' added to .*", a)
1147  let cnt=readfile(fname)
1148  call assert_equal('# goood', cnt[0])
1149  call assert_equal('2 goood/!', cnt[1])
1150
1151  " Test for zuW
1152  let a=execute('unsilent norm! V$zuW')
1153  call assert_match("Word '2 goood' removed from .*", a)
1154  let cnt=readfile(fname)
1155  call assert_equal('# goood', cnt[0])
1156  call assert_equal('# goood/!', cnt[1])
1157
1158  " Test for zuG
1159  let a=execute('unsilent norm! $zG')
1160  call assert_match("Word 'goood' added to .*", a)
1161  let cnt=readfile(fname)
1162  call assert_equal('# goood', cnt[0])
1163  call assert_equal('# goood/!', cnt[1])
1164  call assert_equal('goood', cnt[2])
1165  let a=execute('unsilent norm! $zuG')
1166  let cnt=readfile(fname)
1167  call assert_match("Word 'goood' removed from .*", a)
1168  call assert_equal('# goood', cnt[0])
1169  call assert_equal('# goood/!', cnt[1])
1170  call assert_equal('#oood', cnt[2])
1171  " word not found in wordlist
1172  let a=execute('unsilent norm! V$zuG')
1173  let cnt=readfile(fname)
1174  call assert_match("", a)
1175  call assert_equal('# goood', cnt[0])
1176  call assert_equal('# goood/!', cnt[1])
1177  call assert_equal('#oood', cnt[2])
1178
1179  " Test for zug
1180  call delete('./Xspellfile.add')
1181  2
1182  let a=execute('unsilent norm! $zg')
1183  let cnt=readfile('./Xspellfile.add')
1184  call assert_equal('goood', cnt[0])
1185  let a=execute('unsilent norm! $zug')
1186  call assert_match("Word 'goood' removed from \./Xspellfile.add", a)
1187  let cnt=readfile('./Xspellfile.add')
1188  call assert_equal('#oood', cnt[0])
1189  " word not in wordlist
1190  let a=execute('unsilent norm! V$zug')
1191  call assert_match('', a)
1192  let cnt=readfile('./Xspellfile.add')
1193  call assert_equal('#oood', cnt[0])
1194
1195  " Test for zuw
1196  call delete('./Xspellfile.add')
1197  2
1198  let a=execute('unsilent norm! Vzw')
1199  let cnt=readfile('./Xspellfile.add')
1200  call assert_equal('2 goood/!', cnt[0])
1201  let a=execute('unsilent norm! Vzuw')
1202  call assert_match("Word '2 goood' removed from \./Xspellfile.add", a)
1203  let cnt=readfile('./Xspellfile.add')
1204  call assert_equal('# goood/!', cnt[0])
1205  " word not in wordlist
1206  let a=execute('unsilent norm! $zug')
1207  call assert_match('', a)
1208  let cnt=readfile('./Xspellfile.add')
1209  call assert_equal('# goood/!', cnt[0])
1210
1211  " add second entry to spellfile setting
1212  set spellfile=./Xspellfile.add,./Xspellfile2.add
1213  call delete('./Xspellfile.add')
1214  2
1215  let a=execute('unsilent norm! $2zg')
1216  let cnt=readfile('./Xspellfile2.add')
1217  call assert_match("Word 'goood' added to ./Xspellfile2.add", a)
1218  call assert_equal('goood', cnt[0])
1219
1220  " Test for :spellgood!
1221  let temp = execute(':spe!0/0')
1222  call assert_match('Invalid region', temp)
1223  let spellfile = matchstr(temp, 'Invalid region nr in \zs.*\ze line \d: 0')
1224  call assert_equal(['# goood', '# goood/!', '#oood', '0/0'], readfile(spellfile))
1225  call delete(spellfile)
1226
1227  " clean up
1228  exe "lang" oldlang
1229  call delete("./Xspellfile.add")
1230  call delete("./Xspellfile2.add")
1231  call delete("./Xspellfile.add.spl")
1232  call delete("./Xspellfile2.add.spl")
1233
1234  " zux -> no-op
1235  2
1236  norm! $zux
1237  call assert_equal([], glob('Xspellfile.add',0,1))
1238  call assert_equal([], glob('Xspellfile2.add',0,1))
1239
1240  set spellfile=
1241  bw!
1242endfunc
1243
1244func Test_normal20_exmode()
1245  if !has("unix")
1246    " Reading from redirected file doesn't work on MS-Windows
1247    return
1248  endif
1249  call writefile(['1a', 'foo', 'bar', '.', 'w! Xfile2', 'q!'], 'Xscript')
1250  call writefile(['1', '2'], 'Xfile')
1251  call system(v:progpath .' -e -s < Xscript Xfile')
1252  let a=readfile('Xfile2')
1253  call assert_equal(['1', 'foo', 'bar', '2'], a)
1254
1255  " clean up
1256  for file in ['Xfile', 'Xfile2', 'Xscript']
1257    call delete(file)
1258  endfor
1259  bw!
1260endfunc
1261
1262func Test_normal21_nv_hat()
1263
1264  " Edit a fresh file and wipe the buffer list so that there is no alternate
1265  " file present.  Next, check for the expected command failures.
1266  edit Xfoo | %bw
1267  call assert_fails(':buffer #', 'E86')
1268  call assert_fails(':execute "normal! \<C-^>"', 'E23')
1269
1270  " Test for the expected behavior when switching between two named buffers.
1271  edit Xfoo | edit Xbar
1272  call feedkeys("\<C-^>", 'tx')
1273  call assert_equal('Xfoo', fnamemodify(bufname('%'), ':t'))
1274  call feedkeys("\<C-^>", 'tx')
1275  call assert_equal('Xbar', fnamemodify(bufname('%'), ':t'))
1276
1277  " Test for the expected behavior when only one buffer is named.
1278  enew | let l:nr = bufnr('%')
1279  call feedkeys("\<C-^>", 'tx')
1280  call assert_equal('Xbar', fnamemodify(bufname('%'), ':t'))
1281  call feedkeys("\<C-^>", 'tx')
1282  call assert_equal('', bufname('%'))
1283  call assert_equal(l:nr, bufnr('%'))
1284
1285  " Test that no action is taken by "<C-^>" when an operator is pending.
1286  edit Xfoo
1287  call feedkeys("ci\<C-^>", 'tx')
1288  call assert_equal('Xfoo', fnamemodify(bufname('%'), ':t'))
1289
1290  %bw!
1291endfunc
1292
1293func Test_normal22_zet()
1294  " Test for ZZ
1295  " let shell = &shell
1296  " let &shell = 'sh'
1297  call writefile(['1', '2'], 'Xfile')
1298  let args = ' -u NONE -N -U NONE -i NONE --noplugins -X --not-a-term'
1299  call system(v:progpath . args . ' -c "%d" -c ":norm! ZZ" Xfile')
1300  let a = readfile('Xfile')
1301  call assert_equal([], a)
1302  " Test for ZQ
1303  call writefile(['1', '2'], 'Xfile')
1304  call system(v:progpath . args . ' -c "%d" -c ":norm! ZQ" Xfile')
1305  let a = readfile('Xfile')
1306  call assert_equal(['1', '2'], a)
1307
1308  " clean up
1309  for file in ['Xfile']
1310    call delete(file)
1311  endfor
1312  " let &shell = shell
1313endfunc
1314
1315func Test_normal23_K()
1316  " Test for K command
1317  new
1318  call append(0, ['version8.txt', 'man', 'aa%bb', 'cc|dd'])
1319  let k = &keywordprg
1320  set keywordprg=:help
1321  1
1322  norm! VK
1323  call assert_equal('version8.txt', fnamemodify(bufname('%'), ':t'))
1324  call assert_equal('help', &ft)
1325  call assert_match('\*version8.txt\*', getline('.'))
1326  helpclose
1327  norm! 0K
1328  call assert_equal('version8.txt', fnamemodify(bufname('%'), ':t'))
1329  call assert_equal('help', &ft)
1330  call assert_match('\*version8\.\d\*', getline('.'))
1331  helpclose
1332
1333  set keywordprg=:new
1334  set iskeyword+=%
1335  set iskeyword+=\|
1336  2
1337  norm! K
1338  call assert_equal('man', fnamemodify(bufname('%'), ':t'))
1339  bwipe!
1340  3
1341  norm! K
1342  call assert_equal('aa%bb', fnamemodify(bufname('%'), ':t'))
1343  bwipe!
1344  if !has('win32')
1345    4
1346    norm! K
1347    call assert_equal('cc|dd', fnamemodify(bufname('%'), ':t'))
1348    bwipe!
1349  endif
1350  set iskeyword-=%
1351  set iskeyword-=\|
1352
1353  " Only expect "man" to work on Unix
1354  if !has("unix")
1355    let &keywordprg = k
1356    bw!
1357    return
1358  endif
1359  set keywordprg=man\ --pager=cat
1360  " Test for using man
1361  2
1362  let a = execute('unsilent norm! K')
1363  call assert_match("man --pager=cat 'man'", a)
1364
1365  " clean up
1366  let &keywordprg = k
1367  bw!
1368endfunc
1369
1370func Test_normal24_rot13()
1371  " Testing for g?? g?g?
1372  new
1373  call append(0, 'abcdefghijklmnopqrstuvwxyzäüö')
1374  1
1375  norm! g??
1376  call assert_equal('nopqrstuvwxyzabcdefghijklmäüö', getline('.'))
1377  norm! g?g?
1378  call assert_equal('abcdefghijklmnopqrstuvwxyzäüö', getline('.'))
1379
1380  " clean up
1381  bw!
1382endfunc
1383
1384func Test_normal25_tag()
1385  " Testing for CTRL-] g CTRL-] g]
1386  " CTRL-W g] CTRL-W CTRL-] CTRL-W g CTRL-]
1387  h
1388  " Test for CTRL-]
1389  call search('\<x\>$')
1390  exe "norm! \<c-]>"
1391  call assert_equal("change.txt", fnamemodify(bufname('%'), ':t'))
1392  norm! yiW
1393  call assert_equal("*x*", @0)
1394  exe ":norm \<c-o>"
1395
1396  " Test for g_CTRL-]
1397  call search('\<v_u\>$')
1398  exe "norm! g\<c-]>"
1399  call assert_equal("change.txt", fnamemodify(bufname('%'), ':t'))
1400  norm! yiW
1401  call assert_equal("*v_u*", @0)
1402  exe ":norm \<c-o>"
1403
1404  " Test for g]
1405  call search('\<i_<Esc>$')
1406  let a = execute(":norm! g]")
1407  call assert_match('i_<Esc>.*insert.txt', a)
1408
1409  if !empty(exepath('cscope')) && has('cscope')
1410    " setting cscopetag changes how g] works
1411    set cst
1412    exe "norm! g]"
1413    call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1414    norm! yiW
1415    call assert_equal("*i_<Esc>*", @0)
1416    exe ":norm \<c-o>"
1417    " Test for CTRL-W g]
1418    exe "norm! \<C-W>g]"
1419    call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1420    norm! yiW
1421    call assert_equal("*i_<Esc>*", @0)
1422    call assert_equal(3, winnr('$'))
1423    helpclose
1424    set nocst
1425  endif
1426
1427  " Test for CTRL-W g]
1428  let a = execute("norm! \<C-W>g]")
1429  call assert_match('i_<Esc>.*insert.txt', a)
1430
1431  " Test for CTRL-W CTRL-]
1432  exe "norm! \<C-W>\<C-]>"
1433  call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1434  norm! yiW
1435  call assert_equal("*i_<Esc>*", @0)
1436  call assert_equal(3, winnr('$'))
1437  helpclose
1438
1439  " Test for CTRL-W g CTRL-]
1440  exe "norm! \<C-W>g\<C-]>"
1441  call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1442  norm! yiW
1443  call assert_equal("*i_<Esc>*", @0)
1444  call assert_equal(3, winnr('$'))
1445  helpclose
1446
1447  " clean up
1448  helpclose
1449endfunc
1450
1451func Test_normal26_put()
1452  " Test for ]p ]P [p and [P
1453  new
1454  call append(0, ['while read LINE', 'do', '  ((count++))', '  if [ $? -ne 0 ]; then', "    echo 'Error writing file'", '  fi', 'done'])
1455  1
1456  /Error/y a
1457  2
1458  norm! "a]pj"a[p
1459  call assert_equal(['do', "echo 'Error writing file'", "  echo 'Error writing file'", '  ((count++))'], getline(2,5))
1460  1
1461  /^\s\{4}/
1462  exe "norm!  \"a]P3Eldt'"
1463  exe "norm! j\"a[P2Eldt'"
1464  call assert_equal(['  if [ $? -ne 0 ]; then', "    echo 'Error writing'", "    echo 'Error'", "    echo 'Error writing file'", '  fi'], getline(6,10))
1465
1466  " clean up
1467  bw!
1468endfunc
1469
1470func Test_normal27_bracket()
1471  " Test for [' [` ]' ]`
1472  call Setup_NewWindow()
1473  1,21s/.\+/  &   b/
1474  1
1475  norm! $ma
1476  5
1477  norm! $mb
1478  10
1479  norm! $mc
1480  15
1481  norm! $md
1482  20
1483  norm! $me
1484
1485  " Test for ['
1486  9
1487  norm! 2['
1488  call assert_equal('  1   b', getline('.'))
1489  call assert_equal(1, line('.'))
1490  call assert_equal(3, col('.'))
1491
1492  " Test for ]'
1493  norm! ]'
1494  call assert_equal('  5   b', getline('.'))
1495  call assert_equal(5, line('.'))
1496  call assert_equal(3, col('.'))
1497
1498  " No mark after line 21, cursor moves to first non blank on current line
1499  21
1500  norm! $]'
1501  call assert_equal('  21   b', getline('.'))
1502  call assert_equal(21, line('.'))
1503  call assert_equal(3, col('.'))
1504
1505  " Test for [`
1506  norm! 2[`
1507  call assert_equal('  15   b', getline('.'))
1508  call assert_equal(15, line('.'))
1509  call assert_equal(8, col('.'))
1510
1511  " Test for ]`
1512  norm! ]`
1513  call assert_equal('  20   b', getline('.'))
1514  call assert_equal(20, line('.'))
1515  call assert_equal(8, col('.'))
1516
1517  " clean up
1518  bw!
1519endfunc
1520
1521func Test_normal28_parenthesis()
1522  " basic testing for ( and )
1523  new
1524  call append(0, ['This is a test. With some sentences!', '', 'Even with a question? And one more. And no sentence here'])
1525
1526  $
1527  norm! d(
1528  call assert_equal(['This is a test. With some sentences!', '', 'Even with a question? And one more. ', ''], getline(1, '$'))
1529  norm! 2d(
1530  call assert_equal(['This is a test. With some sentences!', '', ' ', ''], getline(1, '$'))
1531  1
1532  norm! 0d)
1533  call assert_equal(['With some sentences!', '', ' ', ''], getline(1, '$'))
1534
1535  call append('$', ['This is a long sentence', '', 'spanning', 'over several lines. '])
1536  $
1537  norm! $d(
1538  call assert_equal(['With some sentences!', '', ' ', '', 'This is a long sentence', ''], getline(1, '$'))
1539
1540  " clean up
1541  bw!
1542endfunc
1543
1544fun! Test_normal29_brace()
1545  " basic test for { and } movements
1546  let text= ['A paragraph begins after each empty line, and also at each of a set of',
1547  \ 'paragraph macros, specified by the pairs of characters in the ''paragraphs''',
1548  \ 'option.  The default is "IPLPPPQPP TPHPLIPpLpItpplpipbp", which corresponds to',
1549  \ 'the macros ".IP", ".LP", etc.  (These are nroff macros, so the dot must be in',
1550  \ 'the first column).  A section boundary is also a paragraph boundary.',
1551  \ 'Note that a blank line (only containing white space) is NOT a paragraph',
1552  \ 'boundary.',
1553  \ '',
1554  \ '',
1555  \ 'Also note that this does not include a ''{'' or ''}'' in the first column.  When',
1556  \ 'the ''{'' flag is in ''cpoptions'' then ''{'' in the first column is used as a',
1557  \ 'paragraph boundary |posix|.',
1558  \ '{',
1559  \ 'This is no paragraph',
1560  \ 'unless the ''{'' is set',
1561  \ 'in ''cpoptions''',
1562  \ '}',
1563  \ '.IP',
1564  \ 'The nroff macros IP separates a paragraph',
1565  \ 'That means, it must be a ''.''',
1566  \ 'followed by IP',
1567  \ '.LPIt does not matter, if afterwards some',
1568  \ 'more characters follow.',
1569  \ '.SHAlso section boundaries from the nroff',
1570  \ 'macros terminate a paragraph. That means',
1571  \ 'a character like this:',
1572  \ '.NH',
1573  \ 'End of text here']
1574  new
1575  call append(0, text)
1576  1
1577  norm! 0d2}
1578  call assert_equal(['.IP',
1579    \  'The nroff macros IP separates a paragraph', 'That means, it must be a ''.''', 'followed by IP',
1580    \ '.LPIt does not matter, if afterwards some', 'more characters follow.', '.SHAlso section boundaries from the nroff',
1581    \  'macros terminate a paragraph. That means', 'a character like this:', '.NH', 'End of text here', ''], getline(1,'$'))
1582  norm! 0d}
1583  call assert_equal(['.LPIt does not matter, if afterwards some', 'more characters follow.',
1584    \ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means',
1585    \ 'a character like this:', '.NH', 'End of text here', ''], getline(1, '$'))
1586  $
1587  norm! d{
1588  call assert_equal(['.LPIt does not matter, if afterwards some', 'more characters follow.',
1589	\ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means', 'a character like this:', ''], getline(1, '$'))
1590  norm! d{
1591  call assert_equal(['.LPIt does not matter, if afterwards some', 'more characters follow.', ''], getline(1,'$'))
1592  " Test with { in cpooptions
1593  %d
1594  call append(0, text)
1595  set cpo+={
1596  1
1597  norm! 0d2}
1598  call assert_equal(['{', 'This is no paragraph', 'unless the ''{'' is set', 'in ''cpoptions''', '}',
1599    \ '.IP', 'The nroff macros IP separates a paragraph', 'That means, it must be a ''.''',
1600    \ 'followed by IP', '.LPIt does not matter, if afterwards some', 'more characters follow.',
1601    \ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means',
1602    \ 'a character like this:', '.NH', 'End of text here', ''], getline(1,'$'))
1603  $
1604  norm! d}
1605  call assert_equal(['{', 'This is no paragraph', 'unless the ''{'' is set', 'in ''cpoptions''', '}',
1606    \ '.IP', 'The nroff macros IP separates a paragraph', 'That means, it must be a ''.''',
1607    \ 'followed by IP', '.LPIt does not matter, if afterwards some', 'more characters follow.',
1608    \ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means',
1609    \ 'a character like this:', '.NH', 'End of text here', ''], getline(1,'$'))
1610  norm! gg}
1611  norm! d5}
1612  call assert_equal(['{', 'This is no paragraph', 'unless the ''{'' is set', 'in ''cpoptions''', '}', ''], getline(1,'$'))
1613
1614  " clean up
1615  set cpo-={
1616  bw!
1617endfunc
1618
1619fun! Test_normal30_changecase()
1620  new
1621  call append(0, 'This is a simple test: äüöß')
1622  norm! 1ggVu
1623  call assert_equal('this is a simple test: äüöß', getline('.'))
1624  norm! VU
1625  call assert_equal('THIS IS A SIMPLE TEST: ÄÜÖSS', getline('.'))
1626  norm! guu
1627  call assert_equal('this is a simple test: äüöss', getline('.'))
1628  norm! gUgU
1629  call assert_equal('THIS IS A SIMPLE TEST: ÄÜÖSS', getline('.'))
1630  norm! gugu
1631  call assert_equal('this is a simple test: äüöss', getline('.'))
1632  norm! gUU
1633  call assert_equal('THIS IS A SIMPLE TEST: ÄÜÖSS', getline('.'))
1634  norm! 010~
1635  call assert_equal('this is a SIMPLE TEST: ÄÜÖSS', getline('.'))
1636  norm! V~
1637  call assert_equal('THIS IS A simple test: äüöss', getline('.'))
1638
1639  " Turkish ASCII turns to multi-byte.  On some systems Turkish locale
1640  " is available but toupper()/tolower() don't do the right thing.
1641  try
1642    lang tr_TR.UTF-8
1643    set casemap=
1644    let iupper = toupper('i')
1645    if iupper == "\u0130"
1646      call setline(1, 'iI')
1647      1normal gUU
1648      call assert_equal("\u0130I", getline(1))
1649      call assert_equal("\u0130I", toupper("iI"))
1650
1651      call setline(1, 'iI')
1652      1normal guu
1653      call assert_equal("i\u0131", getline(1))
1654      call assert_equal("i\u0131", tolower("iI"))
1655    elseif iupper == "I"
1656      call setline(1, 'iI')
1657      1normal gUU
1658      call assert_equal("II", getline(1))
1659      call assert_equal("II", toupper("iI"))
1660
1661      call setline(1, 'iI')
1662      1normal guu
1663      call assert_equal("ii", getline(1))
1664      call assert_equal("ii", tolower("iI"))
1665    else
1666      call assert_true(false, "expected toupper('i') to be either 'I' or '\u0130'")
1667    endif
1668    set casemap&
1669    call setline(1, 'iI')
1670    1normal gUU
1671    call assert_equal("II", getline(1))
1672    call assert_equal("II", toupper("iI"))
1673
1674    call setline(1, 'iI')
1675    1normal guu
1676    call assert_equal("ii", getline(1))
1677    call assert_equal("ii", tolower("iI"))
1678
1679    lang en_US.UTF-8
1680  catch /E197:/
1681    " can't use Turkish locale
1682    throw 'Skipped: Turkish locale not available'
1683  endtry
1684
1685  " clean up
1686  bw!
1687endfunc
1688
1689fun! Test_normal31_r_cmd()
1690  " Test for r command
1691  new
1692  call append(0, 'This is a simple test: abcd')
1693  exe "norm! 1gg$r\<cr>"
1694  call assert_equal(['This is a simple test: abc', '', ''], getline(1,'$'))
1695  exe "norm! 1gg2wlr\<cr>"
1696  call assert_equal(['This is a', 'simple test: abc', '', ''], getline(1,'$'))
1697  exe "norm! 2gg0W5r\<cr>"
1698  call assert_equal(['This is a', 'simple ', ' abc', '', ''], getline('1', '$'))
1699  set autoindent
1700  call setline(2, ['simple test: abc', ''])
1701  exe "norm! 2gg0W5r\<cr>"
1702  call assert_equal(['This is a', 'simple ', 'abc', '', '', ''], getline('1', '$'))
1703  exe "norm! 1ggVr\<cr>"
1704  call assert_equal('^M^M^M^M^M^M^M^M^M', strtrans(getline(1)))
1705  call setline(1, 'This is a')
1706  exe "norm! 1gg05rf"
1707  call assert_equal('fffffis a', getline(1))
1708
1709  " clean up
1710  set noautoindent
1711  bw!
1712endfunc
1713
1714func Test_normal32_g_cmd1()
1715  " Test for g*, g#
1716  new
1717  call append(0, ['abc.x_foo', 'x_foobar.abc'])
1718  1
1719  norm! $g*
1720  call assert_equal('x_foo', @/)
1721  call assert_equal('x_foobar.abc', getline('.'))
1722  norm! $g#
1723  call assert_equal('abc', @/)
1724  call assert_equal('abc.x_foo', getline('.'))
1725
1726  " clean up
1727  bw!
1728endfunc
1729
1730fun! Test_normal33_g_cmd2()
1731  if !has("jumplist")
1732    return
1733  endif
1734  " Tests for g cmds
1735  call Setup_NewWindow()
1736  " Test for g`
1737  clearjumps
1738  norm! ma10j
1739  let a=execute(':jumps')
1740  " empty jumplist
1741  call assert_equal('>', a[-1:])
1742  norm! g`a
1743  call assert_equal('>', a[-1:])
1744  call assert_equal(1, line('.'))
1745  call assert_equal('1', getline('.'))
1746
1747  " Test for g; and g,
1748  norm! g;
1749  " there is only one change in the changelist
1750  " currently, when we setup the window
1751  call assert_equal(2, line('.'))
1752  call assert_fails(':norm! g;', 'E662')
1753  call assert_fails(':norm! g,', 'E663')
1754  let &ul=&ul
1755  call append('$', ['a', 'b', 'c', 'd'])
1756  let &ul=&ul
1757  call append('$', ['Z', 'Y', 'X', 'W'])
1758  let a = execute(':changes')
1759  call assert_match('2\s\+0\s\+2', a)
1760  call assert_match('101\s\+0\s\+a', a)
1761  call assert_match('105\s\+0\s\+Z', a)
1762  norm! 3g;
1763  call assert_equal(2, line('.'))
1764  norm! 2g,
1765  call assert_equal(105, line('.'))
1766
1767  " Test for g& - global substitute
1768  %d
1769  call setline(1, range(1,10))
1770  call append('$', ['a', 'b', 'c', 'd'])
1771  $s/\w/&&/g
1772  exe "norm! /[1-8]\<cr>"
1773  norm! g&
1774  call assert_equal(['11', '22', '33', '44', '55', '66', '77', '88', '9', '110', 'a', 'b', 'c', 'dd'], getline(1, '$'))
1775
1776  " Test for gv
1777  %d
1778  call append('$', repeat(['abcdefgh'], 8))
1779  exe "norm! 2gg02l\<c-v>2j2ly"
1780  call assert_equal(['cde', 'cde', 'cde'], getreg(0, 1, 1))
1781  " in visual mode, gv swaps current and last selected region
1782  exe "norm! G0\<c-v>4k4lgvd"
1783  call assert_equal(['', 'abfgh', 'abfgh', 'abfgh', 'abcdefgh', 'abcdefgh', 'abcdefgh', 'abcdefgh', 'abcdefgh'], getline(1,'$'))
1784  exe "norm! G0\<c-v>4k4ly"
1785  exe "norm! gvood"
1786  call assert_equal(['', 'abfgh', 'abfgh', 'abfgh', 'fgh', 'fgh', 'fgh', 'fgh', 'fgh'], getline(1,'$'))
1787
1788  " Test for gk/gj
1789  %d
1790  15vsp
1791  set wrap listchars= sbr=
1792  let lineA='abcdefghijklmnopqrstuvwxyz'
1793  let lineB='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
1794  $put =lineA
1795  $put =lineB
1796
1797  norm! 3gg0dgk
1798  call assert_equal(['', 'abcdefghijklmno', '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'], getline(1, '$'))
1799  set nu
1800  norm! 3gg0gjdgj
1801  call assert_equal(['', 'abcdefghijklmno', '0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1802
1803  " Test for gJ
1804  norm! 2gggJ
1805  call assert_equal(['', 'abcdefghijklmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1806  call assert_equal(16, col('.'))
1807  " shouldn't do anything
1808  norm! 10gJ
1809  call assert_equal(1, col('.'))
1810
1811  " Test for g0 g^ gm g$
1812  exe "norm! 2gg0gji   "
1813  call assert_equal(['', 'abcdefghijk   lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1814  norm! g0yl
1815  call assert_equal(12, col('.'))
1816  call assert_equal(' ', getreg(0))
1817  norm! g$yl
1818  call assert_equal(22, col('.'))
1819  call assert_equal('3', getreg(0))
1820  norm! gmyl
1821  call assert_equal(17, col('.'))
1822  call assert_equal('n', getreg(0))
1823  norm! g^yl
1824  call assert_equal(15, col('.'))
1825  call assert_equal('l', getreg(0))
1826
1827  " Test for gI
1828  norm! gIfoo
1829  call assert_equal(['', 'fooabcdefghijk   lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1830
1831  " Test for gi
1832  wincmd c
1833  %d
1834  set tw=0
1835  call setline(1, ['foobar', 'new line'])
1836  norm! A next word
1837  $put ='third line'
1838  norm! gi another word
1839  call assert_equal(['foobar next word another word', 'new line', 'third line'], getline(1,'$'))
1840
1841  " clean up
1842  bw!
1843endfunc
1844
1845func Test_g_ctrl_g()
1846  new
1847
1848  let a = execute(":norm! g\<c-g>")
1849  call assert_equal("\n--No lines in buffer--", a)
1850
1851  call setline(1, ['first line', 'second line'])
1852
1853  " Test g CTRL-g with dos, mac and unix file type.
1854  norm! gojll
1855  set ff=dos
1856  let a = execute(":norm! g\<c-g>")
1857  call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 15 of 25", a)
1858
1859  set ff=mac
1860  let a = execute(":norm! g\<c-g>")
1861  call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 14 of 23", a)
1862
1863  set ff=unix
1864  let a = execute(":norm! g\<c-g>")
1865  call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 14 of 23", a)
1866
1867  " Test g CTRL-g in visual mode (v)
1868  let a = execute(":norm! gojllvlg\<c-g>")
1869  call assert_equal("\nSelected 1 of 2 Lines; 1 of 4 Words; 2 of 23 Bytes", a)
1870
1871  " Test g CTRL-g in visual mode (CTRL-V) with end col > start col
1872  let a = execute(":norm! \<Esc>gojll\<C-V>kllg\<c-g>")
1873  call assert_equal("\nSelected 3 Cols; 2 of 2 Lines; 2 of 4 Words; 6 of 23 Bytes", a)
1874
1875  " Test g_CTRL-g in visual mode (CTRL-V) with end col < start col
1876  let a = execute(":norm! \<Esc>goll\<C-V>jhhg\<c-g>")
1877  call assert_equal("\nSelected 3 Cols; 2 of 2 Lines; 2 of 4 Words; 6 of 23 Bytes", a)
1878
1879  " Test g CTRL-g in visual mode (CTRL-V) with end_vcol being MAXCOL
1880  let a = execute(":norm! \<Esc>gojll\<C-V>k$g\<c-g>")
1881  call assert_equal("\nSelected 2 of 2 Lines; 4 of 4 Words; 17 of 23 Bytes", a)
1882
1883  " There should be one byte less with noeol
1884  set bin noeol
1885  let a = execute(":norm! \<Esc>gog\<c-g>")
1886  call assert_equal("\nCol 1 of 10; Line 1 of 2; Word 1 of 4; Char 1 of 23; Byte 1 of 22", a)
1887  set bin & eol&
1888
1889  call setline(1, ['Français', '日本語'])
1890
1891  let a = execute(":norm! \<Esc>gojlg\<c-g>")
1892  call assert_equal("\nCol 4-3 of 9-6; Line 2 of 2; Word 2 of 2; Char 11 of 13; Byte 16 of 20", a)
1893
1894  let a = execute(":norm! \<Esc>gojvlg\<c-g>")
1895  call assert_equal("\nSelected 1 of 2 Lines; 1 of 2 Words; 2 of 13 Chars; 6 of 20 Bytes", a)
1896
1897  let a = execute(":norm! \<Esc>goll\<c-v>jlg\<c-g>")
1898  call assert_equal("\nSelected 4 Cols; 2 of 2 Lines; 2 of 2 Words; 6 of 13 Chars; 11 of 20 Bytes", a)
1899
1900  set fenc=utf8 bomb
1901  let a = execute(":norm! \<Esc>gojlg\<c-g>")
1902  call assert_equal("\nCol 4-3 of 9-6; Line 2 of 2; Word 2 of 2; Char 11 of 13; Byte 16 of 20(+3 for BOM)", a)
1903
1904  set fenc=utf16 bomb
1905  let a = execute(":norm! g\<c-g>")
1906  call assert_equal("\nCol 4-3 of 9-6; Line 2 of 2; Word 2 of 2; Char 11 of 13; Byte 16 of 20(+2 for BOM)", a)
1907
1908  set fenc=utf32 bomb
1909  let a = execute(":norm! g\<c-g>")
1910  call assert_equal("\nCol 4-3 of 9-6; Line 2 of 2; Word 2 of 2; Char 11 of 13; Byte 16 of 20(+4 for BOM)", a)
1911
1912  set fenc& bomb&
1913
1914  set ff&
1915  bwipe!
1916endfunc
1917
1918fun! Test_normal34_g_cmd3()
1919  " Test for g8
1920  new
1921  let a=execute(':norm! 1G0g8')
1922  call assert_equal("\nNUL", a)
1923
1924  call setline(1, 'abcdefghijklmnopqrstuvwxyzäüö')
1925  let a=execute(':norm! 1G$g8')
1926  call assert_equal("\nc3 b6 ", a)
1927
1928  call setline(1, "a\u0302")
1929  let a=execute(':norm! 1G0g8')
1930  call assert_equal("\n61 + cc 82 ", a)
1931
1932  " clean up
1933  bw!
1934endfunc
1935
1936func Test_normal_8g8()
1937  new
1938
1939  " Test 8g8 which finds invalid utf8 at or after the cursor.
1940
1941  " With invalid byte.
1942  call setline(1, "___\xff___")
1943  norm! 1G08g8g
1944  call assert_equal([0, 1, 4, 0, 1], getcurpos())
1945
1946  " With invalid byte before the cursor.
1947  call setline(1, "___\xff___")
1948  norm! 1G$h8g8g
1949  call assert_equal([0, 1, 6, 0, 9], getcurpos())
1950
1951  " With truncated sequence.
1952  call setline(1, "___\xE2\x82___")
1953  norm! 1G08g8g
1954  call assert_equal([0, 1, 4, 0, 1], getcurpos())
1955
1956  " With overlong sequence.
1957  call setline(1, "___\xF0\x82\x82\xAC___")
1958  norm! 1G08g8g
1959  call assert_equal([0, 1, 4, 0, 1], getcurpos())
1960
1961  " With valid utf8.
1962  call setline(1, "café")
1963  norm! 1G08g8
1964  call assert_equal([0, 1, 1, 0, 1], getcurpos())
1965
1966  bw!
1967endfunc
1968
1969fun! Test_normal35_g_cmd4()
1970  " Test for g<
1971  " Cannot capture its output,
1972  " probably a bug, therefore, test disabled:
1973  throw "Skipped: output of g< can't be tested currently"
1974  echo "a\nb\nc\nd"
1975  let b=execute(':norm! g<')
1976  call assert_true(!empty(b), 'failed `execute(g<)`')
1977endfunc
1978
1979fun! Test_normal36_g_cmd5()
1980  new
1981  call append(0, 'abcdefghijklmnopqrstuvwxyz')
1982  set ff=unix
1983  " Test for gp gP
1984  call append(1, range(1,10))
1985  1
1986  norm! 1yy
1987  3
1988  norm! gp
1989  call assert_equal([0, 5, 1, 0, 1], getcurpos())
1990  $
1991  norm! gP
1992  call assert_equal([0, 14, 1, 0, 1], getcurpos())
1993
1994  " Test for go
1995  norm! 26go
1996  call assert_equal([0, 1, 26, 0, 26], getcurpos())
1997  norm! 27go
1998  call assert_equal([0, 1, 26, 0, 26], getcurpos())
1999  norm! 28go
2000  call assert_equal([0, 2, 1, 0, 1], getcurpos())
2001  set ff=dos
2002  norm! 29go
2003  call assert_equal([0, 2, 1, 0, 1], getcurpos())
2004  set ff=unix
2005  norm! gg0
2006  norm! 101go
2007  call assert_equal([0, 13, 26, 0, 26], getcurpos())
2008  norm! 103go
2009  call assert_equal([0, 14, 1, 0, 1], getcurpos())
2010  " count > buffer content
2011  norm! 120go
2012  call assert_equal([0, 14, 1, 0, 2147483647], getcurpos())
2013  " clean up
2014  bw!
2015endfunc
2016
2017fun! Test_normal37_g_cmd6()
2018  " basic test for gt and gT
2019  tabnew 1.txt
2020  tabnew 2.txt
2021  tabnew 3.txt
2022  norm! 1gt
2023  call assert_equal(1, tabpagenr())
2024  norm! 3gt
2025  call assert_equal(3, tabpagenr())
2026  norm! 1gT
2027  " count gT goes not to the absolute tabpagenumber
2028  " but, but goes to the count previous tabpagenumber
2029  call assert_equal(2, tabpagenr())
2030  " wrap around
2031  norm! 3gT
2032  call assert_equal(3, tabpagenr())
2033  " gt does not wrap around
2034  norm! 5gt
2035  call assert_equal(3, tabpagenr())
2036
2037  for i in range(3)
2038    tabclose
2039  endfor
2040  " clean up
2041  call assert_fails(':tabclose', 'E784')
2042endfunc
2043
2044fun! Test_normal38_nvhome()
2045  " Test for <Home> and <C-Home> key
2046  new
2047  call setline(1, range(10))
2048  $
2049  setl et sw=2
2050  norm! V10>$
2051  " count is ignored
2052  exe "norm! 10\<home>"
2053  call assert_equal(1, col('.'))
2054  exe "norm! \<home>"
2055  call assert_equal([0, 10, 1, 0, 1], getcurpos())
2056  exe "norm! 5\<c-home>"
2057  call assert_equal([0, 5, 1, 0, 1], getcurpos())
2058  exe "norm! \<c-home>"
2059  call assert_equal([0, 1, 1, 0, 1], getcurpos())
2060
2061  " clean up
2062  bw!
2063endfunc
2064
2065fun! Test_normal39_cw()
2066  " Test for cw and cW on whitespace
2067  " and cpo+=w setting
2068  new
2069  set tw=0
2070  call append(0, 'here      are   some words')
2071  norm! 1gg0elcwZZZ
2072  call assert_equal('hereZZZare   some words', getline('.'))
2073  norm! 1gg0elcWYYY
2074  call assert_equal('hereZZZareYYYsome words', getline('.'))
2075  set cpo+=w
2076  call setline(1, 'here      are   some words')
2077  norm! 1gg0elcwZZZ
2078  call assert_equal('hereZZZ     are   some words', getline('.'))
2079  norm! 1gg2elcWYYY
2080  call assert_equal('hereZZZ     areYYY  some words', getline('.'))
2081  set cpo-=w
2082  norm! 2gg0cwfoo
2083  call assert_equal('foo', getline('.'))
2084
2085  " clean up
2086  bw!
2087endfunc
2088
2089fun! Test_normal40_ctrl_bsl()
2090  " Basic test for CTRL-\ commands
2091  new
2092  call append(0, 'here      are   some words')
2093  exe "norm! 1gg0a\<C-\>\<C-N>"
2094  call assert_equal('n', mode())
2095  call assert_equal(1, col('.'))
2096  call assert_equal('', visualmode())
2097  exe "norm! 1gg0viw\<C-\>\<C-N>"
2098  call assert_equal('n', mode())
2099  call assert_equal(4, col('.'))
2100  exe "norm! 1gg0a\<C-\>\<C-G>"
2101  call assert_equal('n', mode())
2102  call assert_equal(1, col('.'))
2103  "imap <buffer> , <c-\><c-n>
2104  set im
2105  exe ":norm! \<c-\>\<c-n>dw"
2106  set noim
2107  call assert_equal('are   some words', getline(1))
2108  call assert_false(&insertmode)
2109
2110  " clean up
2111  bw!
2112endfunc
2113
2114fun! Test_normal41_insert_reg()
2115  " Test for <c-r>=, <c-r><c-r>= and <c-r><c-o>=
2116  " in insert mode
2117  new
2118  set sts=2 sw=2 ts=8 tw=0
2119  call append(0, ["aaa\tbbb\tccc", '', '', ''])
2120  let a=getline(1)
2121  norm! 2gg0
2122  exe "norm! a\<c-r>=a\<cr>"
2123  norm! 3gg0
2124  exe "norm! a\<c-r>\<c-r>=a\<cr>"
2125  norm! 4gg0
2126  exe "norm! a\<c-r>\<c-o>=a\<cr>"
2127  call assert_equal(['aaa	bbb	ccc', 'aaa bbb	ccc', 'aaa bbb	ccc', 'aaa	bbb	ccc', ''], getline(1, '$'))
2128
2129  " clean up
2130  set sts=0 sw=8 ts=8
2131  bw!
2132endfunc
2133
2134func Test_normal42_halfpage()
2135  " basic test for Ctrl-D and Ctrl-U
2136  call Setup_NewWindow()
2137  call assert_equal(5, &scroll)
2138  exe "norm! \<c-d>"
2139  call assert_equal('6', getline('.'))
2140  exe "norm! 2\<c-d>"
2141  call assert_equal('8', getline('.'))
2142  call assert_equal(2, &scroll)
2143  set scroll=5
2144  exe "norm! \<c-u>"
2145  call assert_equal('3', getline('.'))
2146  1
2147  set scrolloff=5
2148  exe "norm! \<c-d>"
2149  call assert_equal('10', getline('.'))
2150  exe "norm! \<c-u>"
2151  call assert_equal('5', getline('.'))
2152  1
2153  set scrolloff=99
2154  exe "norm! \<c-d>"
2155  call assert_equal('10', getline('.'))
2156  set scrolloff=0
2157  100
2158  exe "norm! $\<c-u>"
2159  call assert_equal('95', getline('.'))
2160  call assert_equal([0, 95, 1, 0, 1], getcurpos())
2161  100
2162  set nostartofline
2163  exe "norm! $\<c-u>"
2164  call assert_equal('95', getline('.'))
2165  call assert_equal([0, 95, 2, 0, 2147483647], getcurpos())
2166  " cleanup
2167  set startofline
2168  bw!
2169endfunc
2170
2171fun! Test_normal43_textobject1()
2172  " basic tests for text object aw
2173  new
2174  call append(0, ['foobar,eins,foobar', 'foo,zwei,foo    '])
2175  " diw
2176  norm! 1gg0diw
2177  call assert_equal([',eins,foobar', 'foo,zwei,foo    ', ''], getline(1,'$'))
2178  " daw
2179  norm! 2ggEdaw
2180  call assert_equal([',eins,foobar', 'foo,zwei,', ''], getline(1, '$'))
2181  %d
2182  call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo   "])
2183  " diW
2184  norm! 2ggwd2iW
2185  call assert_equal(['foo	eins	foobar', 'foo	foo   ', ''], getline(1,'$'))
2186  " daW
2187  norm! 1ggd2aW
2188  call assert_equal(['foobar', 'foo	foo   ', ''], getline(1,'$'))
2189
2190  %d
2191  call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo   "])
2192  " aw in visual line mode switches to characterwise mode
2193  norm! 2gg$Vawd
2194  call assert_equal(['foo	eins	foobar', 'foo	zwei	foo'], getline(1,'$'))
2195  norm! 1gg$Viwd
2196  call assert_equal(['foo	eins	', 'foo	zwei	foo'], getline(1,'$'))
2197
2198  " clean up
2199  bw!
2200endfunc
2201
2202func Test_normal44_textobjects2()
2203  " basic testing for is and as text objects
2204  new
2205  call append(0, ['This is a test. With some sentences!', '', 'Even with a question? And one more. And no sentence here'])
2206  " Test for dis - does not remove trailing whitespace
2207  norm! 1gg0dis
2208  call assert_equal([' With some sentences!', '', 'Even with a question? And one more. And no sentence here', ''], getline(1,'$'))
2209  " Test for das - removes leading whitespace
2210  norm! 3ggf?ldas
2211  call assert_equal([' With some sentences!', '', 'Even with a question? And no sentence here', ''], getline(1,'$'))
2212  " when used in visual mode, is made characterwise
2213  norm! 3gg$Visy
2214  call assert_equal('v', visualmode())
2215  " reset visualmode()
2216  norm! 3ggVy
2217  norm! 3gg$Vasy
2218  call assert_equal('v', visualmode())
2219  " basic testing for textobjects a< and at
2220  %d
2221  call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>','    </div>', ' '])
2222  " a<
2223  norm! 1gg0da<
2224  call assert_equal([' ', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2225  norm! 1pj
2226  call assert_equal([' <div>', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2227  " at
2228  norm! d2at
2229  call assert_equal([' '], getline(1,'$'))
2230  %d
2231  call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>','    </div>', ' '])
2232  " i<
2233  norm! 1gg0di<
2234  call assert_equal(['<> ', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2235  norm! 1Pj
2236  call assert_equal(['<div> ', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2237  norm! d2it
2238  call assert_equal(['<div></div>',' '], getline(1,'$'))
2239  " basic testing for a[ and i[ text object
2240  %d
2241  call setline(1, [' ', '[', 'one [two]', 'thre', ']'])
2242  norm! 3gg0di[
2243  call assert_equal([' ', '[', ']'], getline(1,'$'))
2244  call setline(1, [' ', '[', 'one [two]', 'thre', ']'])
2245  norm! 3gg0ftd2a[
2246  call assert_equal([' '], getline(1,'$'))
2247  %d
2248  " Test for i" when cursor is in front of a quoted object
2249  call append(0, 'foo "bar"')
2250  norm! 1gg0di"
2251  call assert_equal(['foo ""', ''], getline(1,'$'))
2252
2253  " clean up
2254  bw!
2255endfunc
2256
2257func Test_normal45_drop()
2258  if !has('dnd')
2259    " The ~ register does not exist
2260    call assert_beeps('norm! "~')
2261    return
2262  endif
2263
2264  " basic test for drag-n-drop
2265  " unfortunately, without a gui, we can't really test much here,
2266  " so simply test that ~p fails (which uses the drop register)
2267  new
2268  call assert_fails(':norm! "~p', 'E353')
2269  call assert_equal([],  getreg('~', 1, 1))
2270  " the ~ register is read only
2271  call assert_fails(':let @~="1"', 'E354')
2272  bw!
2273endfunc
2274
2275func Test_normal46_ignore()
2276  new
2277  " How to test this?
2278  " let's just for now test, that the buffer
2279  " does not change
2280  call feedkeys("\<c-s>", 't')
2281  call assert_equal([''], getline(1,'$'))
2282
2283  " no valid commands
2284  exe "norm! \<char-0x100>"
2285  call assert_equal([''], getline(1,'$'))
2286
2287  exe "norm! ä"
2288  call assert_equal([''], getline(1,'$'))
2289
2290  " clean up
2291  bw!
2292endfunc
2293
2294func Test_normal47_visual_buf_wipe()
2295  " This was causing a crash or ml_get error.
2296  enew!
2297  call setline(1,'xxx')
2298  normal $
2299  new
2300  call setline(1, range(1,2))
2301  2
2302  exe "norm \<C-V>$"
2303  bw!
2304  norm yp
2305  set nomodified
2306endfunc
2307
2308func Test_normal47_autocmd()
2309  " disabled, does not seem to be possible currently
2310  throw "Skipped: not possible to test cursorhold autocmd while waiting for input in normal_cmd"
2311  new
2312  call append(0, repeat('-',20))
2313  au CursorHold * call feedkeys('2l', '')
2314  1
2315  set updatetime=20
2316  " should delete 12 chars (d12l)
2317  call feedkeys('d1', '!')
2318  call assert_equal('--------', getline(1))
2319
2320  " clean up
2321  au! CursorHold
2322  set updatetime=4000
2323  bw!
2324endfunc
2325
2326func Test_normal48_wincmd()
2327  new
2328  exe "norm! \<c-w>c"
2329  call assert_equal(1, winnr('$'))
2330  call assert_fails(":norm! \<c-w>c", "E444")
2331endfunc
2332
2333func Test_normal49_counts()
2334  new
2335  call setline(1, 'one two three four five six seven eight nine ten')
2336  1
2337  norm! 3d2w
2338  call assert_equal('seven eight nine ten', getline(1))
2339  bw!
2340endfunc
2341
2342func Test_normal50_commandline()
2343  if !has("timers") || !has("cmdline_hist")
2344    return
2345  endif
2346  func! DoTimerWork(id)
2347    call assert_equal('[Command Line]', bufname(''))
2348    " should fail, with E11, but does fail with E23?
2349    "call feedkeys("\<c-^>", 'tm')
2350
2351    " should also fail with E11
2352    call assert_fails(":wincmd p", 'E11')
2353    " return from commandline window
2354    call feedkeys("\<cr>")
2355  endfunc
2356
2357  let oldlang=v:lang
2358  lang C
2359  set updatetime=20
2360  call timer_start(100, 'DoTimerWork')
2361  try
2362    " throws E23, for whatever reason...
2363    call feedkeys('q:', 'x!')
2364  catch /E23/
2365    " no-op
2366  endtry
2367  " clean up
2368  set updatetime=4000
2369  exe "lang" oldlang
2370  bw!
2371endfunc
2372
2373func Test_normal51_FileChangedRO()
2374  if !has("autocmd")
2375    return
2376  endif
2377  " Don't sleep after the warning message.
2378  call test_settime(1)
2379  call writefile(['foo'], 'Xreadonly.log')
2380  new Xreadonly.log
2381  setl ro
2382  au FileChangedRO <buffer> :call feedkeys("\<c-^>", 'tix')
2383  call assert_fails(":norm! Af", 'E788')
2384  call assert_equal(['foo'], getline(1,'$'))
2385  call assert_equal('Xreadonly.log', bufname(''))
2386
2387  " cleanup
2388  call test_settime(0)
2389  bw!
2390  call delete("Xreadonly.log")
2391endfunc
2392
2393func Test_normal52_rl()
2394  if !has("rightleft")
2395    return
2396  endif
2397  new
2398  call setline(1, 'abcde fghij klmnopq')
2399  norm! 1gg$
2400  set rl
2401  call assert_equal(19, col('.'))
2402  call feedkeys('l', 'tx')
2403  call assert_equal(18, col('.'))
2404  call feedkeys('h', 'tx')
2405  call assert_equal(19, col('.'))
2406  call feedkeys("\<right>", 'tx')
2407  call assert_equal(18, col('.'))
2408  call feedkeys("\<s-right>", 'tx')
2409  call assert_equal(13, col('.'))
2410  call feedkeys("\<c-right>", 'tx')
2411  call assert_equal(7, col('.'))
2412  call feedkeys("\<c-left>", 'tx')
2413  call assert_equal(13, col('.'))
2414  call feedkeys("\<s-left>", 'tx')
2415  call assert_equal(19, col('.'))
2416  call feedkeys("<<", 'tx')
2417  call assert_equal('	abcde fghij klmnopq',getline(1))
2418  call feedkeys(">>", 'tx')
2419  call assert_equal('abcde fghij klmnopq',getline(1))
2420
2421  " cleanup
2422  set norl
2423  bw!
2424endfunc
2425
2426func Test_normal53_digraph()
2427  if !has('digraphs')
2428    return
2429  endif
2430  new
2431  call setline(1, 'abcdefgh|')
2432  exe "norm! 1gg0f\<c-k>!!"
2433  call assert_equal(9, col('.'))
2434  set cpo+=D
2435  exe "norm! 1gg0f\<c-k>!!"
2436  call assert_equal(1, col('.'))
2437
2438  set cpo-=D
2439  bw!
2440endfunc
2441
2442func Test_normal54_Ctrl_bsl()
2443  new
2444  call setline(1, 'abcdefghijklmn')
2445  exe "norm! df\<c-\>\<c-n>"
2446  call assert_equal(['abcdefghijklmn'], getline(1,'$'))
2447  exe "norm! df\<c-\>\<c-g>"
2448  call assert_equal(['abcdefghijklmn'], getline(1,'$'))
2449  exe "norm! df\<c-\>m"
2450  call assert_equal(['abcdefghijklmn'], getline(1,'$'))
2451
2452  call setline(2, 'abcdefghijklmnāf')
2453  norm! 2gg0
2454  exe "norm! df\<Char-0x101>"
2455  call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$'))
2456  norm! 1gg0
2457  exe "norm! df\<esc>"
2458  call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$'))
2459
2460  " clean up
2461  bw!
2462endfunc
2463
2464func Test_normal_large_count()
2465  " This may fail with 32bit long, how do we detect that?
2466  new
2467  normal o
2468  normal 6666666666dL
2469  bwipe!
2470endfunc
2471
2472func Test_delete_until_paragraph()
2473  new
2474  normal grádv}
2475  call assert_equal('á', getline(1))
2476  normal grád}
2477  call assert_equal('', getline(1))
2478  bwipe!
2479endfunc
2480
2481" Test for the gr (virtual replace) command
2482" Test for the bug fixed by 7.4.387
2483func Test_gr_command()
2484  enew!
2485  let save_cpo = &cpo
2486  call append(0, ['First line', 'Second line', 'Third line'])
2487  exe "normal i\<C-G>u"
2488  call cursor(2, 1)
2489  set cpo-=X
2490  normal 4gro
2491  call assert_equal('oooond line', getline(2))
2492  undo
2493  set cpo+=X
2494  normal 4gro
2495  call assert_equal('ooooecond line', getline(2))
2496  let &cpo = save_cpo
2497  enew!
2498endfunc
2499
2500" When splitting a window the changelist position is wrong.
2501" Test the changelist position after splitting a window.
2502" Test for the bug fixed by 7.4.386
2503func Test_changelist()
2504  let save_ul = &ul
2505  enew!
2506  call append('$', ['1', '2'])
2507  exe "normal i\<C-G>u"
2508  exe "normal Gkylpa\<C-G>u"
2509  set ul=100
2510  exe "normal Gylpa\<C-G>u"
2511  set ul=100
2512  normal gg
2513  vsplit
2514  normal g;
2515  call assert_equal([3, 2], [line('.'), col('.')])
2516  normal g;
2517  call assert_equal([2, 2], [line('.'), col('.')])
2518  call assert_fails('normal g;', 'E662:')
2519  %bwipe!
2520  let &ul = save_ul
2521endfunc
2522
2523func Test_nv_hat_count()
2524  %bwipeout!
2525  let l:nr = bufnr('%') + 1
2526  call assert_fails(':execute "normal! ' . l:nr . '\<C-^>"', 'E92')
2527
2528  edit Xfoo
2529  let l:foo_nr = bufnr('Xfoo')
2530
2531  edit Xbar
2532  let l:bar_nr = bufnr('Xbar')
2533
2534  " Make sure we are not just using the alternate file.
2535  edit Xbaz
2536
2537  call feedkeys(l:foo_nr . "\<C-^>", 'tx')
2538  call assert_equal('Xfoo', fnamemodify(bufname('%'), ':t'))
2539
2540  call feedkeys(l:bar_nr . "\<C-^>", 'tx')
2541  call assert_equal('Xbar', fnamemodify(bufname('%'), ':t'))
2542
2543  %bwipeout!
2544endfunc
2545