xref: /vim-8.2.3635/src/testdir/test_normal.vim (revision fc65cabb)
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  set hidden
1264  new
1265  " to many buffers opened already, will not work
1266  "call assert_fails(":b#", 'E23')
1267  "call assert_equal('', @#)
1268  e Xfoobar
1269  e Xfile2
1270  call feedkeys("\<c-^>", 't')
1271  call assert_equal("Xfile2", fnamemodify(bufname('%'), ':t'))
1272  call feedkeys("f\<c-^>", 't')
1273  call assert_equal("Xfile2", fnamemodify(bufname('%'), ':t'))
1274  " clean up
1275  set nohidden
1276  bw!
1277endfunc
1278
1279func! Test_normal22_zet()
1280  " Test for ZZ
1281  " let shell = &shell
1282  " let &shell = 'sh'
1283  call writefile(['1', '2'], 'Xfile')
1284  let args = ' -u NONE -N -U NONE -i NONE --noplugins -X --not-a-term'
1285  call system(v:progpath . args . ' -c "%d" -c ":norm! ZZ" Xfile')
1286  let a = readfile('Xfile')
1287  call assert_equal([], a)
1288  " Test for ZQ
1289  call writefile(['1', '2'], 'Xfile')
1290  call system(v:progpath . args . ' -c "%d" -c ":norm! ZQ" Xfile')
1291  let a = readfile('Xfile')
1292  call assert_equal(['1', '2'], a)
1293
1294  " clean up
1295  for file in ['Xfile']
1296    call delete(file)
1297  endfor
1298  " let &shell = shell
1299endfunc
1300
1301func! Test_normal23_K()
1302  " Test for K command
1303  new
1304  call append(0, ['version8.txt', 'man', 'aa%bb', 'cc|dd'])
1305  let k = &keywordprg
1306  set keywordprg=:help
1307  1
1308  norm! VK
1309  call assert_equal('version8.txt', fnamemodify(bufname('%'), ':t'))
1310  call assert_equal('help', &ft)
1311  call assert_match('\*version8.txt\*', getline('.'))
1312  helpclose
1313  norm! 0K
1314  call assert_equal('version8.txt', fnamemodify(bufname('%'), ':t'))
1315  call assert_equal('help', &ft)
1316  call assert_match('\*version8\.\d\*', getline('.'))
1317  helpclose
1318
1319  set keywordprg=:new
1320  set iskeyword+=%
1321  set iskeyword+=\|
1322  2
1323  norm! K
1324  call assert_equal('man', fnamemodify(bufname('%'), ':t'))
1325  bwipe!
1326  3
1327  norm! K
1328  call assert_equal('aa%bb', fnamemodify(bufname('%'), ':t'))
1329  bwipe!
1330  if !has('win32')
1331    4
1332    norm! K
1333    call assert_equal('cc|dd', fnamemodify(bufname('%'), ':t'))
1334    bwipe!
1335  endif
1336  set iskeyword-=%
1337  set iskeyword-=\|
1338
1339  " Only expect "man" to work on Unix
1340  if !has("unix")
1341    let &keywordprg = k
1342    bw!
1343    return
1344  endif
1345  set keywordprg=man\ --pager=cat
1346  " Test for using man
1347  2
1348  let a = execute('unsilent norm! K')
1349  call assert_match("man --pager=cat 'man'", a)
1350
1351  " clean up
1352  let &keywordprg = k
1353  bw!
1354endfunc
1355
1356func! Test_normal24_rot13()
1357  " This test uses multi byte characters
1358  if !has("multi_byte")
1359    return
1360  endif
1361  " Testing for g?? g?g?
1362  new
1363  call append(0, 'abcdefghijklmnopqrstuvwxyzäüö')
1364  1
1365  norm! g??
1366  call assert_equal('nopqrstuvwxyzabcdefghijklmäüö', getline('.'))
1367  norm! g?g?
1368  call assert_equal('abcdefghijklmnopqrstuvwxyzäüö', getline('.'))
1369
1370  " clean up
1371  bw!
1372endfunc
1373
1374func! Test_normal25_tag()
1375  " Testing for CTRL-] g CTRL-] g]
1376  " CTRL-W g] CTRL-W CTRL-] CTRL-W g CTRL-]
1377  h
1378  " Test for CTRL-]
1379  call search('\<x\>$')
1380  exe "norm! \<c-]>"
1381  call assert_equal("change.txt", fnamemodify(bufname('%'), ':t'))
1382  norm! yiW
1383  call assert_equal("*x*", @0)
1384  exe ":norm \<c-o>"
1385
1386  " Test for g_CTRL-]
1387  call search('\<v_u\>$')
1388  exe "norm! g\<c-]>"
1389  call assert_equal("change.txt", fnamemodify(bufname('%'), ':t'))
1390  norm! yiW
1391  call assert_equal("*v_u*", @0)
1392  exe ":norm \<c-o>"
1393
1394  " Test for g]
1395  call search('\<i_<Esc>$')
1396  let a = execute(":norm! g]")
1397  call assert_match('i_<Esc>.*insert.txt', a)
1398
1399  if !empty(exepath('cscope')) && has('cscope')
1400    " setting cscopetag changes how g] works
1401    set cst
1402    exe "norm! g]"
1403    call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1404    norm! yiW
1405    call assert_equal("*i_<Esc>*", @0)
1406    exe ":norm \<c-o>"
1407    " Test for CTRL-W g]
1408    exe "norm! \<C-W>g]"
1409    call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1410    norm! yiW
1411    call assert_equal("*i_<Esc>*", @0)
1412    call assert_equal(3, winnr('$'))
1413    helpclose
1414    set nocst
1415  endif
1416
1417  " Test for CTRL-W g]
1418  let a = execute("norm! \<C-W>g]")
1419  call assert_match('i_<Esc>.*insert.txt', a)
1420
1421  " Test for CTRL-W CTRL-]
1422  exe "norm! \<C-W>\<C-]>"
1423  call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1424  norm! yiW
1425  call assert_equal("*i_<Esc>*", @0)
1426  call assert_equal(3, winnr('$'))
1427  helpclose
1428
1429  " Test for CTRL-W g CTRL-]
1430  exe "norm! \<C-W>g\<C-]>"
1431  call assert_equal("insert.txt", fnamemodify(bufname('%'), ':t'))
1432  norm! yiW
1433  call assert_equal("*i_<Esc>*", @0)
1434  call assert_equal(3, winnr('$'))
1435  helpclose
1436
1437  " clean up
1438  helpclose
1439endfunc
1440
1441func! Test_normal26_put()
1442  " Test for ]p ]P [p and [P
1443  new
1444  call append(0, ['while read LINE', 'do', '  ((count++))', '  if [ $? -ne 0 ]; then', "    echo 'Error writing file'", '  fi', 'done'])
1445  1
1446  /Error/y a
1447  2
1448  norm! "a]pj"a[p
1449  call assert_equal(['do', "echo 'Error writing file'", "  echo 'Error writing file'", '  ((count++))'], getline(2,5))
1450  1
1451  /^\s\{4}/
1452  exe "norm!  \"a]P3Eldt'"
1453  exe "norm! j\"a[P2Eldt'"
1454  call assert_equal(['  if [ $? -ne 0 ]; then', "    echo 'Error writing'", "    echo 'Error'", "    echo 'Error writing file'", '  fi'], getline(6,10))
1455
1456  " clean up
1457  bw!
1458endfunc
1459
1460func! Test_normal27_bracket()
1461  " Test for [' [` ]' ]`
1462  call Setup_NewWindow()
1463  1,21s/.\+/  &   b/
1464  1
1465  norm! $ma
1466  5
1467  norm! $mb
1468  10
1469  norm! $mc
1470  15
1471  norm! $md
1472  20
1473  norm! $me
1474
1475  " Test for ['
1476  9
1477  norm! 2['
1478  call assert_equal('  1   b', getline('.'))
1479  call assert_equal(1, line('.'))
1480  call assert_equal(3, col('.'))
1481
1482  " Test for ]'
1483  norm! ]'
1484  call assert_equal('  5   b', getline('.'))
1485  call assert_equal(5, line('.'))
1486  call assert_equal(3, col('.'))
1487
1488  " No mark after line 21, cursor moves to first non blank on current line
1489  21
1490  norm! $]'
1491  call assert_equal('  21   b', getline('.'))
1492  call assert_equal(21, line('.'))
1493  call assert_equal(3, col('.'))
1494
1495  " Test for [`
1496  norm! 2[`
1497  call assert_equal('  15   b', getline('.'))
1498  call assert_equal(15, line('.'))
1499  call assert_equal(8, col('.'))
1500
1501  " Test for ]`
1502  norm! ]`
1503  call assert_equal('  20   b', getline('.'))
1504  call assert_equal(20, line('.'))
1505  call assert_equal(8, col('.'))
1506
1507  " clean up
1508  bw!
1509endfunc
1510
1511func! Test_normal28_parenthesis()
1512  " basic testing for ( and )
1513  new
1514  call append(0, ['This is a test. With some sentences!', '', 'Even with a question? And one more. And no sentence here'])
1515
1516  $
1517  norm! d(
1518  call assert_equal(['This is a test. With some sentences!', '', 'Even with a question? And one more. ', ''], getline(1, '$'))
1519  norm! 2d(
1520  call assert_equal(['This is a test. With some sentences!', '', ' ', ''], getline(1, '$'))
1521  1
1522  norm! 0d)
1523  call assert_equal(['With some sentences!', '', ' ', ''], getline(1, '$'))
1524
1525  call append('$', ['This is a long sentence', '', 'spanning', 'over several lines. '])
1526  $
1527  norm! $d(
1528  call assert_equal(['With some sentences!', '', ' ', '', 'This is a long sentence', ''], getline(1, '$'))
1529
1530  " clean up
1531  bw!
1532endfunc
1533
1534fun! Test_normal29_brace()
1535  " basic test for { and } movements
1536  let text= ['A paragraph begins after each empty line, and also at each of a set of',
1537  \ 'paragraph macros, specified by the pairs of characters in the ''paragraphs''',
1538  \ 'option.  The default is "IPLPPPQPP TPHPLIPpLpItpplpipbp", which corresponds to',
1539  \ 'the macros ".IP", ".LP", etc.  (These are nroff macros, so the dot must be in',
1540  \ 'the first column).  A section boundary is also a paragraph boundary.',
1541  \ 'Note that a blank line (only containing white space) is NOT a paragraph',
1542  \ 'boundary.',
1543  \ '',
1544  \ '',
1545  \ 'Also note that this does not include a ''{'' or ''}'' in the first column.  When',
1546  \ 'the ''{'' flag is in ''cpoptions'' then ''{'' in the first column is used as a',
1547  \ 'paragraph boundary |posix|.',
1548  \ '{',
1549  \ 'This is no paragraph',
1550  \ 'unless the ''{'' is set',
1551  \ 'in ''cpoptions''',
1552  \ '}',
1553  \ '.IP',
1554  \ 'The nroff macros IP separates a paragraph',
1555  \ 'That means, it must be a ''.''',
1556  \ 'followed by IP',
1557  \ '.LPIt does not matter, if afterwards some',
1558  \ 'more characters follow.',
1559  \ '.SHAlso section boundaries from the nroff',
1560  \ 'macros terminate a paragraph. That means',
1561  \ 'a character like this:',
1562  \ '.NH',
1563  \ 'End of text here']
1564  new
1565  call append(0, text)
1566  1
1567  norm! 0d2}
1568  call assert_equal(['.IP',
1569    \  'The nroff macros IP separates a paragraph', 'That means, it must be a ''.''', 'followed by IP',
1570    \ '.LPIt does not matter, if afterwards some', 'more characters follow.', '.SHAlso section boundaries from the nroff',
1571    \  'macros terminate a paragraph. That means', 'a character like this:', '.NH', 'End of text here', ''], getline(1,'$'))
1572  norm! 0d}
1573  call assert_equal(['.LPIt does not matter, if afterwards some', 'more characters follow.',
1574    \ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means',
1575    \ 'a character like this:', '.NH', 'End of text here', ''], getline(1, '$'))
1576  $
1577  norm! d{
1578  call assert_equal(['.LPIt does not matter, if afterwards some', 'more characters follow.',
1579	\ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means', 'a character like this:', ''], getline(1, '$'))
1580  norm! d{
1581  call assert_equal(['.LPIt does not matter, if afterwards some', 'more characters follow.', ''], getline(1,'$'))
1582  " Test with { in cpooptions
1583  %d
1584  call append(0, text)
1585  set cpo+={
1586  1
1587  norm! 0d2}
1588  call assert_equal(['{', 'This is no paragraph', 'unless the ''{'' is set', 'in ''cpoptions''', '}',
1589    \ '.IP', 'The nroff macros IP separates a paragraph', 'That means, it must be a ''.''',
1590    \ 'followed by IP', '.LPIt does not matter, if afterwards some', 'more characters follow.',
1591    \ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means',
1592    \ 'a character like this:', '.NH', 'End of text here', ''], getline(1,'$'))
1593  $
1594  norm! d}
1595  call assert_equal(['{', 'This is no paragraph', 'unless the ''{'' is set', 'in ''cpoptions''', '}',
1596    \ '.IP', 'The nroff macros IP separates a paragraph', 'That means, it must be a ''.''',
1597    \ 'followed by IP', '.LPIt does not matter, if afterwards some', 'more characters follow.',
1598    \ '.SHAlso section boundaries from the nroff', 'macros terminate a paragraph. That means',
1599    \ 'a character like this:', '.NH', 'End of text here', ''], getline(1,'$'))
1600  norm! gg}
1601  norm! d5}
1602  call assert_equal(['{', 'This is no paragraph', 'unless the ''{'' is set', 'in ''cpoptions''', '}', ''], getline(1,'$'))
1603
1604  " clean up
1605  set cpo-={
1606  bw!
1607endfunc
1608
1609fun! Test_normal30_changecase()
1610  " This test uses multi byte characters
1611  if !has("multi_byte")
1612    return
1613  endif
1614  new
1615  call append(0, 'This is a simple test: äüöß')
1616  norm! 1ggVu
1617  call assert_equal('this is a simple test: äüöß', getline('.'))
1618  norm! VU
1619  call assert_equal('THIS IS A SIMPLE TEST: ÄÜÖSS', getline('.'))
1620  norm! guu
1621  call assert_equal('this is a simple test: äüöss', getline('.'))
1622  norm! gUgU
1623  call assert_equal('THIS IS A SIMPLE TEST: ÄÜÖSS', getline('.'))
1624  norm! gugu
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! 010~
1629  call assert_equal('this is a SIMPLE TEST: ÄÜÖSS', getline('.'))
1630  norm! V~
1631  call assert_equal('THIS IS A simple test: äüöss', getline('.'))
1632
1633  " Turkish ASCII turns to multi-byte.  On Mac the Turkish locale is available
1634  " but toupper()/tolower() don't do the right thing.
1635  if !has('mac') && !has('osx')
1636    try
1637      lang tr_TR.UTF-8
1638      set casemap=
1639      call setline(1, 'iI')
1640      1normal gUU
1641      call assert_equal("\u0130I", getline(1))
1642      call assert_equal("\u0130I", toupper("iI"))
1643
1644      call setline(1, 'iI')
1645      1normal guu
1646      call assert_equal("i\u0131", getline(1))
1647      call assert_equal("i\u0131", tolower("iI"))
1648
1649      set casemap&
1650      call setline(1, 'iI')
1651      1normal gUU
1652      call assert_equal("II", getline(1))
1653      call assert_equal("II", toupper("iI"))
1654
1655      call setline(1, 'iI')
1656      1normal guu
1657      call assert_equal("ii", getline(1))
1658      call assert_equal("ii", tolower("iI"))
1659
1660      lang en_US.UTF-8
1661    catch /E197:/
1662      " can't use Turkish locale
1663      throw 'Skipped: Turkish locale not available'
1664    endtry
1665  endif
1666
1667  " clean up
1668  bw!
1669endfunc
1670
1671fun! Test_normal31_r_cmd()
1672  " Test for r command
1673  new
1674  call append(0, 'This is a simple test: abcd')
1675  exe "norm! 1gg$r\<cr>"
1676  call assert_equal(['This is a simple test: abc', '', ''], getline(1,'$'))
1677  exe "norm! 1gg2wlr\<cr>"
1678  call assert_equal(['This is a', 'simple test: abc', '', ''], getline(1,'$'))
1679  exe "norm! 2gg0W5r\<cr>"
1680  call assert_equal(['This is a', 'simple ', ' abc', '', ''], getline('1', '$'))
1681  set autoindent
1682  call setline(2, ['simple test: abc', ''])
1683  exe "norm! 2gg0W5r\<cr>"
1684  call assert_equal(['This is a', 'simple ', 'abc', '', '', ''], getline('1', '$'))
1685  exe "norm! 1ggVr\<cr>"
1686  call assert_equal('^M^M^M^M^M^M^M^M^M', strtrans(getline(1)))
1687  call setline(1, 'This is a')
1688  exe "norm! 1gg05rf"
1689  call assert_equal('fffffis a', getline(1))
1690
1691  " clean up
1692  set noautoindent
1693  bw!
1694endfunc
1695
1696func! Test_normal32_g_cmd1()
1697  " Test for g*, g#
1698  new
1699  call append(0, ['abc.x_foo', 'x_foobar.abc'])
1700  1
1701  norm! $g*
1702  call assert_equal('x_foo', @/)
1703  call assert_equal('x_foobar.abc', getline('.'))
1704  norm! $g#
1705  call assert_equal('abc', @/)
1706  call assert_equal('abc.x_foo', getline('.'))
1707
1708  " clean up
1709  bw!
1710endfunc
1711
1712fun! Test_normal33_g_cmd2()
1713  if !has("jumplist")
1714    return
1715  endif
1716  " Tests for g cmds
1717  call Setup_NewWindow()
1718  " Test for g`
1719  clearjumps
1720  norm! ma10j
1721  let a=execute(':jumps')
1722  " empty jumplist
1723  call assert_equal('>', a[-1:])
1724  norm! g`a
1725  call assert_equal('>', a[-1:])
1726  call assert_equal(1, line('.'))
1727  call assert_equal('1', getline('.'))
1728
1729  " Test for g; and g,
1730  norm! g;
1731  " there is only one change in the changelist
1732  " currently, when we setup the window
1733  call assert_equal(2, line('.'))
1734  call assert_fails(':norm! g;', 'E662')
1735  call assert_fails(':norm! g,', 'E663')
1736  let &ul=&ul
1737  call append('$', ['a', 'b', 'c', 'd'])
1738  let &ul=&ul
1739  call append('$', ['Z', 'Y', 'X', 'W'])
1740  let a = execute(':changes')
1741  call assert_match('2\s\+0\s\+2', a)
1742  call assert_match('101\s\+0\s\+a', a)
1743  call assert_match('105\s\+0\s\+Z', a)
1744  norm! 3g;
1745  call assert_equal(2, line('.'))
1746  norm! 2g,
1747  call assert_equal(105, line('.'))
1748
1749  " Test for g& - global substitute
1750  %d
1751  call setline(1, range(1,10))
1752  call append('$', ['a', 'b', 'c', 'd'])
1753  $s/\w/&&/g
1754  exe "norm! /[1-8]\<cr>"
1755  norm! g&
1756  call assert_equal(['11', '22', '33', '44', '55', '66', '77', '88', '9', '110', 'a', 'b', 'c', 'dd'], getline(1, '$'))
1757
1758  " Test for gv
1759  %d
1760  call append('$', repeat(['abcdefgh'], 8))
1761  exe "norm! 2gg02l\<c-v>2j2ly"
1762  call assert_equal(['cde', 'cde', 'cde'], getreg(0, 1, 1))
1763  " in visual mode, gv swaps current and last selected region
1764  exe "norm! G0\<c-v>4k4lgvd"
1765  call assert_equal(['', 'abfgh', 'abfgh', 'abfgh', 'abcdefgh', 'abcdefgh', 'abcdefgh', 'abcdefgh', 'abcdefgh'], getline(1,'$'))
1766  exe "norm! G0\<c-v>4k4ly"
1767  exe "norm! gvood"
1768  call assert_equal(['', 'abfgh', 'abfgh', 'abfgh', 'fgh', 'fgh', 'fgh', 'fgh', 'fgh'], getline(1,'$'))
1769
1770  " Test for gk/gj
1771  %d
1772  15vsp
1773  set wrap listchars= sbr=
1774  let lineA='abcdefghijklmnopqrstuvwxyz'
1775  let lineB='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'
1776  $put =lineA
1777  $put =lineB
1778
1779  norm! 3gg0dgk
1780  call assert_equal(['', 'abcdefghijklmno', '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'], getline(1, '$'))
1781  set nu
1782  norm! 3gg0gjdgj
1783  call assert_equal(['', 'abcdefghijklmno', '0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1784
1785  " Test for gJ
1786  norm! 2gggJ
1787  call assert_equal(['', 'abcdefghijklmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1788  call assert_equal(16, col('.'))
1789  " shouldn't do anything
1790  norm! 10gJ
1791  call assert_equal(1, col('.'))
1792
1793  " Test for g0 g^ gm g$
1794  exe "norm! 2gg0gji   "
1795  call assert_equal(['', 'abcdefghijk   lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1796  norm! g0yl
1797  call assert_equal(12, col('.'))
1798  call assert_equal(' ', getreg(0))
1799  norm! g$yl
1800  call assert_equal(22, col('.'))
1801  call assert_equal('3', getreg(0))
1802  norm! gmyl
1803  call assert_equal(17, col('.'))
1804  call assert_equal('n', getreg(0))
1805  norm! g^yl
1806  call assert_equal(15, col('.'))
1807  call assert_equal('l', getreg(0))
1808
1809  " Test for gI
1810  norm! gIfoo
1811  call assert_equal(['', 'fooabcdefghijk   lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$'))
1812
1813  " Test for gi
1814  wincmd c
1815  %d
1816  set tw=0
1817  call setline(1, ['foobar', 'new line'])
1818  norm! A next word
1819  $put ='third line'
1820  norm! gi another word
1821  call assert_equal(['foobar next word another word', 'new line', 'third line'], getline(1,'$'))
1822
1823  " clean up
1824  bw!
1825endfunc
1826
1827func! Test_g_ctrl_g()
1828  new
1829
1830  let a = execute(":norm! g\<c-g>")
1831  call assert_equal("\n--No lines in buffer--", a)
1832
1833  call setline(1, ['first line', 'second line'])
1834
1835  " Test g CTRL-g with dos, mac and unix file type.
1836  norm! gojll
1837  set ff=dos
1838  let a = execute(":norm! g\<c-g>")
1839  call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 15 of 25", a)
1840
1841  set ff=mac
1842  let a = execute(":norm! g\<c-g>")
1843  call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 14 of 23", a)
1844
1845  set ff=unix
1846  let a = execute(":norm! g\<c-g>")
1847  call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 14 of 23", a)
1848
1849  " Test g CTRL-g in visual mode (v)
1850  let a = execute(":norm! gojllvlg\<c-g>")
1851  call assert_equal("\nSelected 1 of 2 Lines; 1 of 4 Words; 2 of 23 Bytes", a)
1852
1853  " Test g CTRL-g in visual mode (CTRL-V) with end col > start col
1854  let a = execute(":norm! \<Esc>gojll\<C-V>kllg\<c-g>")
1855  call assert_equal("\nSelected 3 Cols; 2 of 2 Lines; 2 of 4 Words; 6 of 23 Bytes", a)
1856
1857  " Test g_CTRL-g in visual mode (CTRL-V) with end col < start col
1858  let a = execute(":norm! \<Esc>goll\<C-V>jhhg\<c-g>")
1859  call assert_equal("\nSelected 3 Cols; 2 of 2 Lines; 2 of 4 Words; 6 of 23 Bytes", a)
1860
1861  " Test g CTRL-g in visual mode (CTRL-V) with end_vcol being MAXCOL
1862  let a = execute(":norm! \<Esc>gojll\<C-V>k$g\<c-g>")
1863  call assert_equal("\nSelected 2 of 2 Lines; 4 of 4 Words; 17 of 23 Bytes", a)
1864
1865  " There should be one byte less with noeol
1866  set bin noeol
1867  let a = execute(":norm! \<Esc>gog\<c-g>")
1868  call assert_equal("\nCol 1 of 10; Line 1 of 2; Word 1 of 4; Char 1 of 23; Byte 1 of 22", a)
1869  set bin & eol&
1870
1871  if has('multi_byte')
1872    call setline(1, ['Français', '日本語'])
1873
1874    let a = execute(":norm! \<Esc>gojlg\<c-g>")
1875    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)
1876
1877    let a = execute(":norm! \<Esc>gojvlg\<c-g>")
1878    call assert_equal("\nSelected 1 of 2 Lines; 1 of 2 Words; 2 of 13 Chars; 6 of 20 Bytes", a)
1879
1880    let a = execute(":norm! \<Esc>goll\<c-v>jlg\<c-g>")
1881    call assert_equal("\nSelected 4 Cols; 2 of 2 Lines; 2 of 2 Words; 6 of 13 Chars; 11 of 20 Bytes", a)
1882
1883    set fenc=utf8 bomb
1884    let a = execute(":norm! \<Esc>gojlg\<c-g>")
1885    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)
1886
1887    set fenc=utf16 bomb
1888    let a = execute(":norm! g\<c-g>")
1889    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)
1890
1891    set fenc=utf32 bomb
1892    let a = execute(":norm! g\<c-g>")
1893    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)
1894
1895    set fenc& bomb&
1896  endif
1897
1898  set ff&
1899  bwipe!
1900endfunc
1901
1902fun! Test_normal34_g_cmd3()
1903  if !has("multi_byte")
1904    return
1905  endif
1906
1907  " Test for g8
1908  new
1909  let a=execute(':norm! 1G0g8')
1910  call assert_equal("\nNUL", a)
1911
1912  call setline(1, 'abcdefghijklmnopqrstuvwxyzäüö')
1913  let a=execute(':norm! 1G$g8')
1914  call assert_equal("\nc3 b6 ", a)
1915
1916  call setline(1, "a\u0302")
1917  let a=execute(':norm! 1G0g8')
1918  call assert_equal("\n61 + cc 82 ", a)
1919
1920  " clean up
1921  bw!
1922endfunc
1923
1924func Test_normal_8g8()
1925  if !has("multi_byte")
1926    return
1927  endif
1928  new
1929
1930  " Test 8g8 which finds invalid utf8 at or after the cursor.
1931
1932  " With invalid byte.
1933  call setline(1, "___\xff___")
1934  norm! 1G08g8g
1935  call assert_equal([0, 1, 4, 0, 1], getcurpos())
1936
1937  " With invalid byte before the cursor.
1938  call setline(1, "___\xff___")
1939  norm! 1G$h8g8g
1940  call assert_equal([0, 1, 6, 0, 9], getcurpos())
1941
1942  " With truncated sequence.
1943  call setline(1, "___\xE2\x82___")
1944  norm! 1G08g8g
1945  call assert_equal([0, 1, 4, 0, 1], getcurpos())
1946
1947  " With overlong sequence.
1948  call setline(1, "___\xF0\x82\x82\xAC___")
1949  norm! 1G08g8g
1950  call assert_equal([0, 1, 4, 0, 1], getcurpos())
1951
1952  " With valid utf8.
1953  call setline(1, "café")
1954  norm! 1G08g8
1955  call assert_equal([0, 1, 1, 0, 1], getcurpos())
1956
1957  bw!
1958endfunc
1959
1960fun! Test_normal35_g_cmd4()
1961  " Test for g<
1962  " Cannot capture its output,
1963  " probably a bug, therefore, test disabled:
1964  throw "Skipped: output of g< can't be tested currently"
1965  echo "a\nb\nc\nd"
1966  let b=execute(':norm! g<')
1967  call assert_true(!empty(b), 'failed `execute(g<)`')
1968endfunc
1969
1970fun! Test_normal36_g_cmd5()
1971  new
1972  call append(0, 'abcdefghijklmnopqrstuvwxyz')
1973  set ff=unix
1974  " Test for gp gP
1975  call append(1, range(1,10))
1976  1
1977  norm! 1yy
1978  3
1979  norm! gp
1980  call assert_equal([0, 5, 1, 0, 1], getcurpos())
1981  $
1982  norm! gP
1983  call assert_equal([0, 14, 1, 0, 1], getcurpos())
1984
1985  " Test for go
1986  norm! 26go
1987  call assert_equal([0, 1, 26, 0, 26], getcurpos())
1988  norm! 27go
1989  call assert_equal([0, 1, 26, 0, 26], getcurpos())
1990  norm! 28go
1991  call assert_equal([0, 2, 1, 0, 1], getcurpos())
1992  set ff=dos
1993  norm! 29go
1994  call assert_equal([0, 2, 1, 0, 1], getcurpos())
1995  set ff=unix
1996  norm! gg0
1997  norm! 101go
1998  call assert_equal([0, 13, 26, 0, 26], getcurpos())
1999  norm! 103go
2000  call assert_equal([0, 14, 1, 0, 1], getcurpos())
2001  " count > buffer content
2002  norm! 120go
2003  call assert_equal([0, 14, 1, 0, 2147483647], getcurpos())
2004  " clean up
2005  bw!
2006endfunc
2007
2008fun! Test_normal37_g_cmd6()
2009  " basic test for gt and gT
2010  tabnew 1.txt
2011  tabnew 2.txt
2012  tabnew 3.txt
2013  norm! 1gt
2014  call assert_equal(1, tabpagenr())
2015  norm! 3gt
2016  call assert_equal(3, tabpagenr())
2017  norm! 1gT
2018  " count gT goes not to the absolute tabpagenumber
2019  " but, but goes to the count previous tabpagenumber
2020  call assert_equal(2, tabpagenr())
2021  " wrap around
2022  norm! 3gT
2023  call assert_equal(3, tabpagenr())
2024  " gt does not wrap around
2025  norm! 5gt
2026  call assert_equal(3, tabpagenr())
2027
2028  for i in range(3)
2029    tabclose
2030  endfor
2031  " clean up
2032  call assert_fails(':tabclose', 'E784')
2033endfunc
2034
2035fun! Test_normal38_nvhome()
2036  " Test for <Home> and <C-Home> key
2037  new
2038  call setline(1, range(10))
2039  $
2040  setl et sw=2
2041  norm! V10>$
2042  " count is ignored
2043  exe "norm! 10\<home>"
2044  call assert_equal(1, col('.'))
2045  exe "norm! \<home>"
2046  call assert_equal([0, 10, 1, 0, 1], getcurpos())
2047  exe "norm! 5\<c-home>"
2048  call assert_equal([0, 5, 1, 0, 1], getcurpos())
2049  exe "norm! \<c-home>"
2050  call assert_equal([0, 1, 1, 0, 1], getcurpos())
2051
2052  " clean up
2053  bw!
2054endfunc
2055
2056fun! Test_normal39_cw()
2057  " Test for cw and cW on whitespace
2058  " and cpo+=w setting
2059  new
2060  set tw=0
2061  call append(0, 'here      are   some words')
2062  norm! 1gg0elcwZZZ
2063  call assert_equal('hereZZZare   some words', getline('.'))
2064  norm! 1gg0elcWYYY
2065  call assert_equal('hereZZZareYYYsome words', getline('.'))
2066  set cpo+=w
2067  call setline(1, 'here      are   some words')
2068  norm! 1gg0elcwZZZ
2069  call assert_equal('hereZZZ     are   some words', getline('.'))
2070  norm! 1gg2elcWYYY
2071  call assert_equal('hereZZZ     areYYY  some words', getline('.'))
2072  set cpo-=w
2073  norm! 2gg0cwfoo
2074  call assert_equal('foo', getline('.'))
2075
2076  " clean up
2077  bw!
2078endfunc
2079
2080fun! Test_normal40_ctrl_bsl()
2081  " Basic test for CTRL-\ commands
2082  new
2083  call append(0, 'here      are   some words')
2084  exe "norm! 1gg0a\<C-\>\<C-N>"
2085  call assert_equal('n', mode())
2086  call assert_equal(1, col('.'))
2087  call assert_equal('', visualmode())
2088  exe "norm! 1gg0viw\<C-\>\<C-N>"
2089  call assert_equal('n', mode())
2090  call assert_equal(4, col('.'))
2091  exe "norm! 1gg0a\<C-\>\<C-G>"
2092  call assert_equal('n', mode())
2093  call assert_equal(1, col('.'))
2094  "imap <buffer> , <c-\><c-n>
2095  set im
2096  exe ":norm! \<c-\>\<c-n>dw"
2097  set noim
2098  call assert_equal('are   some words', getline(1))
2099  call assert_false(&insertmode)
2100
2101  " clean up
2102  bw!
2103endfunc
2104
2105fun! Test_normal41_insert_reg()
2106  " Test for <c-r>=, <c-r><c-r>= and <c-r><c-o>=
2107  " in insert mode
2108  new
2109  set sts=2 sw=2 ts=8 tw=0
2110  call append(0, ["aaa\tbbb\tccc", '', '', ''])
2111  let a=getline(1)
2112  norm! 2gg0
2113  exe "norm! a\<c-r>=a\<cr>"
2114  norm! 3gg0
2115  exe "norm! a\<c-r>\<c-r>=a\<cr>"
2116  norm! 4gg0
2117  exe "norm! a\<c-r>\<c-o>=a\<cr>"
2118  call assert_equal(['aaa	bbb	ccc', 'aaa bbb	ccc', 'aaa bbb	ccc', 'aaa	bbb	ccc', ''], getline(1, '$'))
2119
2120  " clean up
2121  set sts=0 sw=8 ts=8
2122  bw!
2123endfunc
2124
2125func! Test_normal42_halfpage()
2126  " basic test for Ctrl-D and Ctrl-U
2127  call Setup_NewWindow()
2128  call assert_equal(5, &scroll)
2129  exe "norm! \<c-d>"
2130  call assert_equal('6', getline('.'))
2131  exe "norm! 2\<c-d>"
2132  call assert_equal('8', getline('.'))
2133  call assert_equal(2, &scroll)
2134  set scroll=5
2135  exe "norm! \<c-u>"
2136  call assert_equal('3', getline('.'))
2137  1
2138  set scrolloff=5
2139  exe "norm! \<c-d>"
2140  call assert_equal('10', getline('.'))
2141  exe "norm! \<c-u>"
2142  call assert_equal('5', getline('.'))
2143  1
2144  set scrolloff=99
2145  exe "norm! \<c-d>"
2146  call assert_equal('10', getline('.'))
2147  set scrolloff=0
2148  100
2149  exe "norm! $\<c-u>"
2150  call assert_equal('95', getline('.'))
2151  call assert_equal([0, 95, 1, 0, 1], getcurpos())
2152  100
2153  set nostartofline
2154  exe "norm! $\<c-u>"
2155  call assert_equal('95', getline('.'))
2156  call assert_equal([0, 95, 2, 0, 2147483647], getcurpos())
2157  " cleanup
2158  set startofline
2159  bw!
2160endfunc
2161
2162fun! Test_normal43_textobject1()
2163  " basic tests for text object aw
2164  new
2165  call append(0, ['foobar,eins,foobar', 'foo,zwei,foo    '])
2166  " diw
2167  norm! 1gg0diw
2168  call assert_equal([',eins,foobar', 'foo,zwei,foo    ', ''], getline(1,'$'))
2169  " daw
2170  norm! 2ggEdaw
2171  call assert_equal([',eins,foobar', 'foo,zwei,', ''], getline(1, '$'))
2172  %d
2173  call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo   "])
2174  " diW
2175  norm! 2ggwd2iW
2176  call assert_equal(['foo	eins	foobar', 'foo	foo   ', ''], getline(1,'$'))
2177  " daW
2178  norm! 1ggd2aW
2179  call assert_equal(['foobar', 'foo	foo   ', ''], getline(1,'$'))
2180
2181  %d
2182  call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo   "])
2183  " aw in visual line mode switches to characterwise mode
2184  norm! 2gg$Vawd
2185  call assert_equal(['foo	eins	foobar', 'foo	zwei	foo'], getline(1,'$'))
2186  norm! 1gg$Viwd
2187  call assert_equal(['foo	eins	', 'foo	zwei	foo'], getline(1,'$'))
2188
2189  " clean up
2190  bw!
2191endfunc
2192
2193func! Test_normal44_textobjects2()
2194  " basic testing for is and as text objects
2195  new
2196  call append(0, ['This is a test. With some sentences!', '', 'Even with a question? And one more. And no sentence here'])
2197  " Test for dis - does not remove trailing whitespace
2198  norm! 1gg0dis
2199  call assert_equal([' With some sentences!', '', 'Even with a question? And one more. And no sentence here', ''], getline(1,'$'))
2200  " Test for das - removes leading whitespace
2201  norm! 3ggf?ldas
2202  call assert_equal([' With some sentences!', '', 'Even with a question? And no sentence here', ''], getline(1,'$'))
2203  " when used in visual mode, is made characterwise
2204  norm! 3gg$Visy
2205  call assert_equal('v', visualmode())
2206  " reset visualmode()
2207  norm! 3ggVy
2208  norm! 3gg$Vasy
2209  call assert_equal('v', visualmode())
2210  " basic testing for textobjects a< and at
2211  %d
2212  call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>','    </div>', ' '])
2213  " a<
2214  norm! 1gg0da<
2215  call assert_equal([' ', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2216  norm! 1pj
2217  call assert_equal([' <div>', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2218  " at
2219  norm! d2at
2220  call assert_equal([' '], getline(1,'$'))
2221  %d
2222  call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>','    </div>', ' '])
2223  " i<
2224  norm! 1gg0di<
2225  call assert_equal(['<> ', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2226  norm! 1Pj
2227  call assert_equal(['<div> ', '<a href="foobar" class="foo">xyz</a>', '    </div>', ' '], getline(1,'$'))
2228  norm! d2it
2229  call assert_equal(['<div></div>',' '], getline(1,'$'))
2230  " basic testing for a[ and i[ text object
2231  %d
2232  call setline(1, [' ', '[', 'one [two]', 'thre', ']'])
2233  norm! 3gg0di[
2234  call assert_equal([' ', '[', ']'], getline(1,'$'))
2235  call setline(1, [' ', '[', 'one [two]', 'thre', ']'])
2236  norm! 3gg0ftd2a[
2237  call assert_equal([' '], getline(1,'$'))
2238  %d
2239  " Test for i" when cursor is in front of a quoted object
2240  call append(0, 'foo "bar"')
2241  norm! 1gg0di"
2242  call assert_equal(['foo ""', ''], getline(1,'$'))
2243
2244  " clean up
2245  bw!
2246endfunc
2247
2248func! Test_normal45_drop()
2249  if !has('dnd')
2250    " The ~ register does not exist
2251    call assert_beeps('norm! "~')
2252    return
2253  endif
2254
2255  " basic test for drag-n-drop
2256  " unfortunately, without a gui, we can't really test much here,
2257  " so simply test that ~p fails (which uses the drop register)
2258  new
2259  call assert_fails(':norm! "~p', 'E353')
2260  call assert_equal([],  getreg('~', 1, 1))
2261  " the ~ register is read only
2262  call assert_fails(':let @~="1"', 'E354')
2263  bw!
2264endfunc
2265
2266func! Test_normal46_ignore()
2267  " This test uses multi byte characters
2268  if !has("multi_byte")
2269    return
2270  endif
2271
2272  new
2273  " How to test this?
2274  " let's just for now test, that the buffer
2275  " does not change
2276  call feedkeys("\<c-s>", 't')
2277  call assert_equal([''], getline(1,'$'))
2278
2279  " no valid commands
2280  exe "norm! \<char-0x100>"
2281  call assert_equal([''], getline(1,'$'))
2282
2283  exe "norm! ä"
2284  call assert_equal([''], getline(1,'$'))
2285
2286  " clean up
2287  bw!
2288endfunc
2289
2290func! Test_normal47_visual_buf_wipe()
2291  " This was causing a crash or ml_get error.
2292  enew!
2293  call setline(1,'xxx')
2294  normal $
2295  new
2296  call setline(1, range(1,2))
2297  2
2298  exe "norm \<C-V>$"
2299  bw!
2300  norm yp
2301  set nomodified
2302endfunc
2303
2304func! Test_normal47_autocmd()
2305  " disabled, does not seem to be possible currently
2306  throw "Skipped: not possible to test cursorhold autocmd while waiting for input in normal_cmd"
2307  new
2308  call append(0, repeat('-',20))
2309  au CursorHold * call feedkeys('2l', '')
2310  1
2311  set updatetime=20
2312  " should delete 12 chars (d12l)
2313  call feedkeys('d1', '!')
2314  call assert_equal('--------', getline(1))
2315
2316  " clean up
2317  au! CursorHold
2318  set updatetime=4000
2319  bw!
2320endfunc
2321
2322func! Test_normal48_wincmd()
2323  new
2324  exe "norm! \<c-w>c"
2325  call assert_equal(1, winnr('$'))
2326  call assert_fails(":norm! \<c-w>c", "E444")
2327endfunc
2328
2329func! Test_normal49_counts()
2330  new
2331  call setline(1, 'one two three four five six seven eight nine ten')
2332  1
2333  norm! 3d2w
2334  call assert_equal('seven eight nine ten', getline(1))
2335  bw!
2336endfunc
2337
2338func! Test_normal50_commandline()
2339  if !has("timers") || !has("cmdline_hist")
2340    return
2341  endif
2342  func! DoTimerWork(id)
2343    call assert_equal('[Command Line]', bufname(''))
2344    " should fail, with E11, but does fail with E23?
2345    "call feedkeys("\<c-^>", 'tm')
2346
2347    " should also fail with E11
2348    call assert_fails(":wincmd p", 'E11')
2349    " return from commandline window
2350    call feedkeys("\<cr>")
2351  endfunc
2352
2353  let oldlang=v:lang
2354  lang C
2355  set updatetime=20
2356  call timer_start(100, 'DoTimerWork')
2357  try
2358    " throws E23, for whatever reason...
2359    call feedkeys('q:', 'x!')
2360  catch /E23/
2361    " no-op
2362  endtry
2363  " clean up
2364  set updatetime=4000
2365  exe "lang" oldlang
2366  bw!
2367endfunc
2368
2369func! Test_normal51_FileChangedRO()
2370  if !has("autocmd")
2371    return
2372  endif
2373  " Don't sleep after the warning message.
2374  call test_settime(1)
2375  call writefile(['foo'], 'Xreadonly.log')
2376  new Xreadonly.log
2377  setl ro
2378  au FileChangedRO <buffer> :call feedkeys("\<c-^>", 'tix')
2379  call assert_fails(":norm! Af", 'E788')
2380  call assert_equal(['foo'], getline(1,'$'))
2381  call assert_equal('Xreadonly.log', bufname(''))
2382
2383  " cleanup
2384  call test_settime(0)
2385  bw!
2386  call delete("Xreadonly.log")
2387endfunc
2388
2389func! Test_normal52_rl()
2390  if !has("rightleft")
2391    return
2392  endif
2393  new
2394  call setline(1, 'abcde fghij klmnopq')
2395  norm! 1gg$
2396  set rl
2397  call assert_equal(19, col('.'))
2398  call feedkeys('l', 'tx')
2399  call assert_equal(18, col('.'))
2400  call feedkeys('h', 'tx')
2401  call assert_equal(19, col('.'))
2402  call feedkeys("\<right>", 'tx')
2403  call assert_equal(18, col('.'))
2404  call feedkeys("\<s-right>", 'tx')
2405  call assert_equal(13, col('.'))
2406  call feedkeys("\<c-right>", 'tx')
2407  call assert_equal(7, col('.'))
2408  call feedkeys("\<c-left>", 'tx')
2409  call assert_equal(13, col('.'))
2410  call feedkeys("\<s-left>", 'tx')
2411  call assert_equal(19, col('.'))
2412  call feedkeys("<<", 'tx')
2413  call assert_equal('	abcde fghij klmnopq',getline(1))
2414  call feedkeys(">>", 'tx')
2415  call assert_equal('abcde fghij klmnopq',getline(1))
2416
2417  " cleanup
2418  set norl
2419  bw!
2420endfunc
2421
2422func! Test_normal53_digraph()
2423  if !has('digraphs')
2424    return
2425  endif
2426  new
2427  call setline(1, 'abcdefgh|')
2428  exe "norm! 1gg0f\<c-k>!!"
2429  call assert_equal(9, col('.'))
2430  set cpo+=D
2431  exe "norm! 1gg0f\<c-k>!!"
2432  call assert_equal(1, col('.'))
2433
2434  set cpo-=D
2435  bw!
2436endfunc
2437
2438func Test_normal54_Ctrl_bsl()
2439  new
2440  call setline(1, 'abcdefghijklmn')
2441  exe "norm! df\<c-\>\<c-n>"
2442  call assert_equal(['abcdefghijklmn'], getline(1,'$'))
2443  exe "norm! df\<c-\>\<c-g>"
2444  call assert_equal(['abcdefghijklmn'], getline(1,'$'))
2445  exe "norm! df\<c-\>m"
2446  call assert_equal(['abcdefghijklmn'], getline(1,'$'))
2447  if !has("multi_byte")
2448    return
2449  endif
2450  call setline(2, 'abcdefghijklmnāf')
2451  norm! 2gg0
2452  exe "norm! df\<Char-0x101>"
2453  call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$'))
2454  norm! 1gg0
2455  exe "norm! df\<esc>"
2456  call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$'))
2457
2458  " clean up
2459  bw!
2460endfunc
2461
2462func Test_normal_large_count()
2463  " This may fail with 32bit long, how do we detect that?
2464  new
2465  normal o
2466  normal 6666666666dL
2467  bwipe!
2468endfunc
2469
2470func Test_delete_until_paragraph()
2471  if !has('multi_byte')
2472    return
2473  endif
2474  new
2475  normal grádv}
2476  call assert_equal('á', getline(1))
2477  normal grád}
2478  call assert_equal('', getline(1))
2479  bwipe!
2480endfunc
2481
2482" Test for the gr (virtual replace) command
2483" Test for the bug fixed by 7.4.387
2484func Test_gr_command()
2485  enew!
2486  let save_cpo = &cpo
2487  call append(0, ['First line', 'Second line', 'Third line'])
2488  exe "normal i\<C-G>u"
2489  call cursor(2, 1)
2490  set cpo-=X
2491  normal 4gro
2492  call assert_equal('oooond line', getline(2))
2493  undo
2494  set cpo+=X
2495  normal 4gro
2496  call assert_equal('ooooecond line', getline(2))
2497  let &cpo = save_cpo
2498  enew!
2499endfunc
2500
2501" When splitting a window the changelist position is wrong.
2502" Test the changelist position after splitting a window.
2503" Test for the bug fixed by 7.4.386
2504func Test_changelist()
2505  let save_ul = &ul
2506  enew!
2507  call append('$', ['1', '2'])
2508  exe "normal i\<C-G>u"
2509  exe "normal Gkylpa\<C-G>u"
2510  set ul=100
2511  exe "normal Gylpa\<C-G>u"
2512  set ul=100
2513  normal gg
2514  vsplit
2515  normal g;
2516  call assert_equal([3, 2], [line('.'), col('.')])
2517  normal g;
2518  call assert_equal([2, 2], [line('.'), col('.')])
2519  call assert_fails('normal g;', 'E662:')
2520  %bwipe!
2521  let &ul = save_ul
2522endfunc
2523