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 some systems Turkish locale 1634 " is available but toupper()/tolower() don't do the right thing. 1635 try 1636 lang tr_TR.UTF-8 1637 set casemap= 1638 let iupper = toupper('i') 1639 if iupper == "\u0130" 1640 call setline(1, 'iI') 1641 1normal gUU 1642 call assert_equal("\u0130I", getline(1)) 1643 call assert_equal("\u0130I", toupper("iI")) 1644 1645 call setline(1, 'iI') 1646 1normal guu 1647 call assert_equal("i\u0131", getline(1)) 1648 call assert_equal("i\u0131", tolower("iI")) 1649 elseif iupper == "I" 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 else 1660 call assert_true(false, "expected toupper('i') to be either 'I' or '\u0130'") 1661 endif 1662 set casemap& 1663 call setline(1, 'iI') 1664 1normal gUU 1665 call assert_equal("II", getline(1)) 1666 call assert_equal("II", toupper("iI")) 1667 1668 call setline(1, 'iI') 1669 1normal guu 1670 call assert_equal("ii", getline(1)) 1671 call assert_equal("ii", tolower("iI")) 1672 1673 lang en_US.UTF-8 1674 catch /E197:/ 1675 " can't use Turkish locale 1676 throw 'Skipped: Turkish locale not available' 1677 endtry 1678 1679 " clean up 1680 bw! 1681endfunc 1682 1683fun! Test_normal31_r_cmd() 1684 " Test for r command 1685 new 1686 call append(0, 'This is a simple test: abcd') 1687 exe "norm! 1gg$r\<cr>" 1688 call assert_equal(['This is a simple test: abc', '', ''], getline(1,'$')) 1689 exe "norm! 1gg2wlr\<cr>" 1690 call assert_equal(['This is a', 'simple test: abc', '', ''], getline(1,'$')) 1691 exe "norm! 2gg0W5r\<cr>" 1692 call assert_equal(['This is a', 'simple ', ' abc', '', ''], getline('1', '$')) 1693 set autoindent 1694 call setline(2, ['simple test: abc', '']) 1695 exe "norm! 2gg0W5r\<cr>" 1696 call assert_equal(['This is a', 'simple ', 'abc', '', '', ''], getline('1', '$')) 1697 exe "norm! 1ggVr\<cr>" 1698 call assert_equal('^M^M^M^M^M^M^M^M^M', strtrans(getline(1))) 1699 call setline(1, 'This is a') 1700 exe "norm! 1gg05rf" 1701 call assert_equal('fffffis a', getline(1)) 1702 1703 " clean up 1704 set noautoindent 1705 bw! 1706endfunc 1707 1708func! Test_normal32_g_cmd1() 1709 " Test for g*, g# 1710 new 1711 call append(0, ['abc.x_foo', 'x_foobar.abc']) 1712 1 1713 norm! $g* 1714 call assert_equal('x_foo', @/) 1715 call assert_equal('x_foobar.abc', getline('.')) 1716 norm! $g# 1717 call assert_equal('abc', @/) 1718 call assert_equal('abc.x_foo', getline('.')) 1719 1720 " clean up 1721 bw! 1722endfunc 1723 1724fun! Test_normal33_g_cmd2() 1725 if !has("jumplist") 1726 return 1727 endif 1728 " Tests for g cmds 1729 call Setup_NewWindow() 1730 " Test for g` 1731 clearjumps 1732 norm! ma10j 1733 let a=execute(':jumps') 1734 " empty jumplist 1735 call assert_equal('>', a[-1:]) 1736 norm! g`a 1737 call assert_equal('>', a[-1:]) 1738 call assert_equal(1, line('.')) 1739 call assert_equal('1', getline('.')) 1740 1741 " Test for g; and g, 1742 norm! g; 1743 " there is only one change in the changelist 1744 " currently, when we setup the window 1745 call assert_equal(2, line('.')) 1746 call assert_fails(':norm! g;', 'E662') 1747 call assert_fails(':norm! g,', 'E663') 1748 let &ul=&ul 1749 call append('$', ['a', 'b', 'c', 'd']) 1750 let &ul=&ul 1751 call append('$', ['Z', 'Y', 'X', 'W']) 1752 let a = execute(':changes') 1753 call assert_match('2\s\+0\s\+2', a) 1754 call assert_match('101\s\+0\s\+a', a) 1755 call assert_match('105\s\+0\s\+Z', a) 1756 norm! 3g; 1757 call assert_equal(2, line('.')) 1758 norm! 2g, 1759 call assert_equal(105, line('.')) 1760 1761 " Test for g& - global substitute 1762 %d 1763 call setline(1, range(1,10)) 1764 call append('$', ['a', 'b', 'c', 'd']) 1765 $s/\w/&&/g 1766 exe "norm! /[1-8]\<cr>" 1767 norm! g& 1768 call assert_equal(['11', '22', '33', '44', '55', '66', '77', '88', '9', '110', 'a', 'b', 'c', 'dd'], getline(1, '$')) 1769 1770 " Test for gv 1771 %d 1772 call append('$', repeat(['abcdefgh'], 8)) 1773 exe "norm! 2gg02l\<c-v>2j2ly" 1774 call assert_equal(['cde', 'cde', 'cde'], getreg(0, 1, 1)) 1775 " in visual mode, gv swaps current and last selected region 1776 exe "norm! G0\<c-v>4k4lgvd" 1777 call assert_equal(['', 'abfgh', 'abfgh', 'abfgh', 'abcdefgh', 'abcdefgh', 'abcdefgh', 'abcdefgh', 'abcdefgh'], getline(1,'$')) 1778 exe "norm! G0\<c-v>4k4ly" 1779 exe "norm! gvood" 1780 call assert_equal(['', 'abfgh', 'abfgh', 'abfgh', 'fgh', 'fgh', 'fgh', 'fgh', 'fgh'], getline(1,'$')) 1781 1782 " Test for gk/gj 1783 %d 1784 15vsp 1785 set wrap listchars= sbr= 1786 let lineA='abcdefghijklmnopqrstuvwxyz' 1787 let lineB='0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ' 1788 $put =lineA 1789 $put =lineB 1790 1791 norm! 3gg0dgk 1792 call assert_equal(['', 'abcdefghijklmno', '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ'], getline(1, '$')) 1793 set nu 1794 norm! 3gg0gjdgj 1795 call assert_equal(['', 'abcdefghijklmno', '0123456789AMNOPQRSTUVWXYZ'], getline(1,'$')) 1796 1797 " Test for gJ 1798 norm! 2gggJ 1799 call assert_equal(['', 'abcdefghijklmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$')) 1800 call assert_equal(16, col('.')) 1801 " shouldn't do anything 1802 norm! 10gJ 1803 call assert_equal(1, col('.')) 1804 1805 " Test for g0 g^ gm g$ 1806 exe "norm! 2gg0gji " 1807 call assert_equal(['', 'abcdefghijk lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$')) 1808 norm! g0yl 1809 call assert_equal(12, col('.')) 1810 call assert_equal(' ', getreg(0)) 1811 norm! g$yl 1812 call assert_equal(22, col('.')) 1813 call assert_equal('3', getreg(0)) 1814 norm! gmyl 1815 call assert_equal(17, col('.')) 1816 call assert_equal('n', getreg(0)) 1817 norm! g^yl 1818 call assert_equal(15, col('.')) 1819 call assert_equal('l', getreg(0)) 1820 1821 " Test for gI 1822 norm! gIfoo 1823 call assert_equal(['', 'fooabcdefghijk lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$')) 1824 1825 " Test for gi 1826 wincmd c 1827 %d 1828 set tw=0 1829 call setline(1, ['foobar', 'new line']) 1830 norm! A next word 1831 $put ='third line' 1832 norm! gi another word 1833 call assert_equal(['foobar next word another word', 'new line', 'third line'], getline(1,'$')) 1834 1835 " clean up 1836 bw! 1837endfunc 1838 1839func! Test_g_ctrl_g() 1840 new 1841 1842 let a = execute(":norm! g\<c-g>") 1843 call assert_equal("\n--No lines in buffer--", a) 1844 1845 call setline(1, ['first line', 'second line']) 1846 1847 " Test g CTRL-g with dos, mac and unix file type. 1848 norm! gojll 1849 set ff=dos 1850 let a = execute(":norm! g\<c-g>") 1851 call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 15 of 25", a) 1852 1853 set ff=mac 1854 let a = execute(":norm! g\<c-g>") 1855 call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 14 of 23", a) 1856 1857 set ff=unix 1858 let a = execute(":norm! g\<c-g>") 1859 call assert_equal("\nCol 3 of 11; Line 2 of 2; Word 3 of 4; Byte 14 of 23", a) 1860 1861 " Test g CTRL-g in visual mode (v) 1862 let a = execute(":norm! gojllvlg\<c-g>") 1863 call assert_equal("\nSelected 1 of 2 Lines; 1 of 4 Words; 2 of 23 Bytes", a) 1864 1865 " Test g CTRL-g in visual mode (CTRL-V) with end col > start col 1866 let a = execute(":norm! \<Esc>gojll\<C-V>kllg\<c-g>") 1867 call assert_equal("\nSelected 3 Cols; 2 of 2 Lines; 2 of 4 Words; 6 of 23 Bytes", a) 1868 1869 " Test g_CTRL-g in visual mode (CTRL-V) with end col < start col 1870 let a = execute(":norm! \<Esc>goll\<C-V>jhhg\<c-g>") 1871 call assert_equal("\nSelected 3 Cols; 2 of 2 Lines; 2 of 4 Words; 6 of 23 Bytes", a) 1872 1873 " Test g CTRL-g in visual mode (CTRL-V) with end_vcol being MAXCOL 1874 let a = execute(":norm! \<Esc>gojll\<C-V>k$g\<c-g>") 1875 call assert_equal("\nSelected 2 of 2 Lines; 4 of 4 Words; 17 of 23 Bytes", a) 1876 1877 " There should be one byte less with noeol 1878 set bin noeol 1879 let a = execute(":norm! \<Esc>gog\<c-g>") 1880 call assert_equal("\nCol 1 of 10; Line 1 of 2; Word 1 of 4; Char 1 of 23; Byte 1 of 22", a) 1881 set bin & eol& 1882 1883 if has('multi_byte') 1884 call setline(1, ['Français', '日本語']) 1885 1886 let a = execute(":norm! \<Esc>gojlg\<c-g>") 1887 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) 1888 1889 let a = execute(":norm! \<Esc>gojvlg\<c-g>") 1890 call assert_equal("\nSelected 1 of 2 Lines; 1 of 2 Words; 2 of 13 Chars; 6 of 20 Bytes", a) 1891 1892 let a = execute(":norm! \<Esc>goll\<c-v>jlg\<c-g>") 1893 call assert_equal("\nSelected 4 Cols; 2 of 2 Lines; 2 of 2 Words; 6 of 13 Chars; 11 of 20 Bytes", a) 1894 1895 set fenc=utf8 bomb 1896 let a = execute(":norm! \<Esc>gojlg\<c-g>") 1897 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) 1898 1899 set fenc=utf16 bomb 1900 let a = execute(":norm! g\<c-g>") 1901 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) 1902 1903 set fenc=utf32 bomb 1904 let a = execute(":norm! g\<c-g>") 1905 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) 1906 1907 set fenc& bomb& 1908 endif 1909 1910 set ff& 1911 bwipe! 1912endfunc 1913 1914fun! Test_normal34_g_cmd3() 1915 if !has("multi_byte") 1916 return 1917 endif 1918 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 if !has("multi_byte") 1938 return 1939 endif 1940 new 1941 1942 " Test 8g8 which finds invalid utf8 at or after the cursor. 1943 1944 " With invalid byte. 1945 call setline(1, "___\xff___") 1946 norm! 1G08g8g 1947 call assert_equal([0, 1, 4, 0, 1], getcurpos()) 1948 1949 " With invalid byte before the cursor. 1950 call setline(1, "___\xff___") 1951 norm! 1G$h8g8g 1952 call assert_equal([0, 1, 6, 0, 9], getcurpos()) 1953 1954 " With truncated sequence. 1955 call setline(1, "___\xE2\x82___") 1956 norm! 1G08g8g 1957 call assert_equal([0, 1, 4, 0, 1], getcurpos()) 1958 1959 " With overlong sequence. 1960 call setline(1, "___\xF0\x82\x82\xAC___") 1961 norm! 1G08g8g 1962 call assert_equal([0, 1, 4, 0, 1], getcurpos()) 1963 1964 " With valid utf8. 1965 call setline(1, "café") 1966 norm! 1G08g8 1967 call assert_equal([0, 1, 1, 0, 1], getcurpos()) 1968 1969 bw! 1970endfunc 1971 1972fun! Test_normal35_g_cmd4() 1973 " Test for g< 1974 " Cannot capture its output, 1975 " probably a bug, therefore, test disabled: 1976 throw "Skipped: output of g< can't be tested currently" 1977 echo "a\nb\nc\nd" 1978 let b=execute(':norm! g<') 1979 call assert_true(!empty(b), 'failed `execute(g<)`') 1980endfunc 1981 1982fun! Test_normal36_g_cmd5() 1983 new 1984 call append(0, 'abcdefghijklmnopqrstuvwxyz') 1985 set ff=unix 1986 " Test for gp gP 1987 call append(1, range(1,10)) 1988 1 1989 norm! 1yy 1990 3 1991 norm! gp 1992 call assert_equal([0, 5, 1, 0, 1], getcurpos()) 1993 $ 1994 norm! gP 1995 call assert_equal([0, 14, 1, 0, 1], getcurpos()) 1996 1997 " Test for go 1998 norm! 26go 1999 call assert_equal([0, 1, 26, 0, 26], getcurpos()) 2000 norm! 27go 2001 call assert_equal([0, 1, 26, 0, 26], getcurpos()) 2002 norm! 28go 2003 call assert_equal([0, 2, 1, 0, 1], getcurpos()) 2004 set ff=dos 2005 norm! 29go 2006 call assert_equal([0, 2, 1, 0, 1], getcurpos()) 2007 set ff=unix 2008 norm! gg0 2009 norm! 101go 2010 call assert_equal([0, 13, 26, 0, 26], getcurpos()) 2011 norm! 103go 2012 call assert_equal([0, 14, 1, 0, 1], getcurpos()) 2013 " count > buffer content 2014 norm! 120go 2015 call assert_equal([0, 14, 1, 0, 2147483647], getcurpos()) 2016 " clean up 2017 bw! 2018endfunc 2019 2020fun! Test_normal37_g_cmd6() 2021 " basic test for gt and gT 2022 tabnew 1.txt 2023 tabnew 2.txt 2024 tabnew 3.txt 2025 norm! 1gt 2026 call assert_equal(1, tabpagenr()) 2027 norm! 3gt 2028 call assert_equal(3, tabpagenr()) 2029 norm! 1gT 2030 " count gT goes not to the absolute tabpagenumber 2031 " but, but goes to the count previous tabpagenumber 2032 call assert_equal(2, tabpagenr()) 2033 " wrap around 2034 norm! 3gT 2035 call assert_equal(3, tabpagenr()) 2036 " gt does not wrap around 2037 norm! 5gt 2038 call assert_equal(3, tabpagenr()) 2039 2040 for i in range(3) 2041 tabclose 2042 endfor 2043 " clean up 2044 call assert_fails(':tabclose', 'E784') 2045endfunc 2046 2047fun! Test_normal38_nvhome() 2048 " Test for <Home> and <C-Home> key 2049 new 2050 call setline(1, range(10)) 2051 $ 2052 setl et sw=2 2053 norm! V10>$ 2054 " count is ignored 2055 exe "norm! 10\<home>" 2056 call assert_equal(1, col('.')) 2057 exe "norm! \<home>" 2058 call assert_equal([0, 10, 1, 0, 1], getcurpos()) 2059 exe "norm! 5\<c-home>" 2060 call assert_equal([0, 5, 1, 0, 1], getcurpos()) 2061 exe "norm! \<c-home>" 2062 call assert_equal([0, 1, 1, 0, 1], getcurpos()) 2063 2064 " clean up 2065 bw! 2066endfunc 2067 2068fun! Test_normal39_cw() 2069 " Test for cw and cW on whitespace 2070 " and cpo+=w setting 2071 new 2072 set tw=0 2073 call append(0, 'here are some words') 2074 norm! 1gg0elcwZZZ 2075 call assert_equal('hereZZZare some words', getline('.')) 2076 norm! 1gg0elcWYYY 2077 call assert_equal('hereZZZareYYYsome words', getline('.')) 2078 set cpo+=w 2079 call setline(1, 'here are some words') 2080 norm! 1gg0elcwZZZ 2081 call assert_equal('hereZZZ are some words', getline('.')) 2082 norm! 1gg2elcWYYY 2083 call assert_equal('hereZZZ areYYY some words', getline('.')) 2084 set cpo-=w 2085 norm! 2gg0cwfoo 2086 call assert_equal('foo', getline('.')) 2087 2088 " clean up 2089 bw! 2090endfunc 2091 2092fun! Test_normal40_ctrl_bsl() 2093 " Basic test for CTRL-\ commands 2094 new 2095 call append(0, 'here are some words') 2096 exe "norm! 1gg0a\<C-\>\<C-N>" 2097 call assert_equal('n', mode()) 2098 call assert_equal(1, col('.')) 2099 call assert_equal('', visualmode()) 2100 exe "norm! 1gg0viw\<C-\>\<C-N>" 2101 call assert_equal('n', mode()) 2102 call assert_equal(4, col('.')) 2103 exe "norm! 1gg0a\<C-\>\<C-G>" 2104 call assert_equal('n', mode()) 2105 call assert_equal(1, col('.')) 2106 "imap <buffer> , <c-\><c-n> 2107 set im 2108 exe ":norm! \<c-\>\<c-n>dw" 2109 set noim 2110 call assert_equal('are some words', getline(1)) 2111 call assert_false(&insertmode) 2112 2113 " clean up 2114 bw! 2115endfunc 2116 2117fun! Test_normal41_insert_reg() 2118 " Test for <c-r>=, <c-r><c-r>= and <c-r><c-o>= 2119 " in insert mode 2120 new 2121 set sts=2 sw=2 ts=8 tw=0 2122 call append(0, ["aaa\tbbb\tccc", '', '', '']) 2123 let a=getline(1) 2124 norm! 2gg0 2125 exe "norm! a\<c-r>=a\<cr>" 2126 norm! 3gg0 2127 exe "norm! a\<c-r>\<c-r>=a\<cr>" 2128 norm! 4gg0 2129 exe "norm! a\<c-r>\<c-o>=a\<cr>" 2130 call assert_equal(['aaa bbb ccc', 'aaa bbb ccc', 'aaa bbb ccc', 'aaa bbb ccc', ''], getline(1, '$')) 2131 2132 " clean up 2133 set sts=0 sw=8 ts=8 2134 bw! 2135endfunc 2136 2137func! Test_normal42_halfpage() 2138 " basic test for Ctrl-D and Ctrl-U 2139 call Setup_NewWindow() 2140 call assert_equal(5, &scroll) 2141 exe "norm! \<c-d>" 2142 call assert_equal('6', getline('.')) 2143 exe "norm! 2\<c-d>" 2144 call assert_equal('8', getline('.')) 2145 call assert_equal(2, &scroll) 2146 set scroll=5 2147 exe "norm! \<c-u>" 2148 call assert_equal('3', getline('.')) 2149 1 2150 set scrolloff=5 2151 exe "norm! \<c-d>" 2152 call assert_equal('10', getline('.')) 2153 exe "norm! \<c-u>" 2154 call assert_equal('5', getline('.')) 2155 1 2156 set scrolloff=99 2157 exe "norm! \<c-d>" 2158 call assert_equal('10', getline('.')) 2159 set scrolloff=0 2160 100 2161 exe "norm! $\<c-u>" 2162 call assert_equal('95', getline('.')) 2163 call assert_equal([0, 95, 1, 0, 1], getcurpos()) 2164 100 2165 set nostartofline 2166 exe "norm! $\<c-u>" 2167 call assert_equal('95', getline('.')) 2168 call assert_equal([0, 95, 2, 0, 2147483647], getcurpos()) 2169 " cleanup 2170 set startofline 2171 bw! 2172endfunc 2173 2174fun! Test_normal43_textobject1() 2175 " basic tests for text object aw 2176 new 2177 call append(0, ['foobar,eins,foobar', 'foo,zwei,foo ']) 2178 " diw 2179 norm! 1gg0diw 2180 call assert_equal([',eins,foobar', 'foo,zwei,foo ', ''], getline(1,'$')) 2181 " daw 2182 norm! 2ggEdaw 2183 call assert_equal([',eins,foobar', 'foo,zwei,', ''], getline(1, '$')) 2184 %d 2185 call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo "]) 2186 " diW 2187 norm! 2ggwd2iW 2188 call assert_equal(['foo eins foobar', 'foo foo ', ''], getline(1,'$')) 2189 " daW 2190 norm! 1ggd2aW 2191 call assert_equal(['foobar', 'foo foo ', ''], getline(1,'$')) 2192 2193 %d 2194 call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo "]) 2195 " aw in visual line mode switches to characterwise mode 2196 norm! 2gg$Vawd 2197 call assert_equal(['foo eins foobar', 'foo zwei foo'], getline(1,'$')) 2198 norm! 1gg$Viwd 2199 call assert_equal(['foo eins ', 'foo zwei foo'], getline(1,'$')) 2200 2201 " clean up 2202 bw! 2203endfunc 2204 2205func! Test_normal44_textobjects2() 2206 " basic testing for is and as text objects 2207 new 2208 call append(0, ['This is a test. With some sentences!', '', 'Even with a question? And one more. And no sentence here']) 2209 " Test for dis - does not remove trailing whitespace 2210 norm! 1gg0dis 2211 call assert_equal([' With some sentences!', '', 'Even with a question? And one more. And no sentence here', ''], getline(1,'$')) 2212 " Test for das - removes leading whitespace 2213 norm! 3ggf?ldas 2214 call assert_equal([' With some sentences!', '', 'Even with a question? And no sentence here', ''], getline(1,'$')) 2215 " when used in visual mode, is made characterwise 2216 norm! 3gg$Visy 2217 call assert_equal('v', visualmode()) 2218 " reset visualmode() 2219 norm! 3ggVy 2220 norm! 3gg$Vasy 2221 call assert_equal('v', visualmode()) 2222 " basic testing for textobjects a< and at 2223 %d 2224 call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>',' </div>', ' ']) 2225 " a< 2226 norm! 1gg0da< 2227 call assert_equal([' ', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2228 norm! 1pj 2229 call assert_equal([' <div>', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2230 " at 2231 norm! d2at 2232 call assert_equal([' '], getline(1,'$')) 2233 %d 2234 call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>',' </div>', ' ']) 2235 " i< 2236 norm! 1gg0di< 2237 call assert_equal(['<> ', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2238 norm! 1Pj 2239 call assert_equal(['<div> ', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2240 norm! d2it 2241 call assert_equal(['<div></div>',' '], getline(1,'$')) 2242 " basic testing for a[ and i[ text object 2243 %d 2244 call setline(1, [' ', '[', 'one [two]', 'thre', ']']) 2245 norm! 3gg0di[ 2246 call assert_equal([' ', '[', ']'], getline(1,'$')) 2247 call setline(1, [' ', '[', 'one [two]', 'thre', ']']) 2248 norm! 3gg0ftd2a[ 2249 call assert_equal([' '], getline(1,'$')) 2250 %d 2251 " Test for i" when cursor is in front of a quoted object 2252 call append(0, 'foo "bar"') 2253 norm! 1gg0di" 2254 call assert_equal(['foo ""', ''], getline(1,'$')) 2255 2256 " clean up 2257 bw! 2258endfunc 2259 2260func! Test_normal45_drop() 2261 if !has('dnd') 2262 " The ~ register does not exist 2263 call assert_beeps('norm! "~') 2264 return 2265 endif 2266 2267 " basic test for drag-n-drop 2268 " unfortunately, without a gui, we can't really test much here, 2269 " so simply test that ~p fails (which uses the drop register) 2270 new 2271 call assert_fails(':norm! "~p', 'E353') 2272 call assert_equal([], getreg('~', 1, 1)) 2273 " the ~ register is read only 2274 call assert_fails(':let @~="1"', 'E354') 2275 bw! 2276endfunc 2277 2278func! Test_normal46_ignore() 2279 " This test uses multi byte characters 2280 if !has("multi_byte") 2281 return 2282 endif 2283 2284 new 2285 " How to test this? 2286 " let's just for now test, that the buffer 2287 " does not change 2288 call feedkeys("\<c-s>", 't') 2289 call assert_equal([''], getline(1,'$')) 2290 2291 " no valid commands 2292 exe "norm! \<char-0x100>" 2293 call assert_equal([''], getline(1,'$')) 2294 2295 exe "norm! ä" 2296 call assert_equal([''], getline(1,'$')) 2297 2298 " clean up 2299 bw! 2300endfunc 2301 2302func! Test_normal47_visual_buf_wipe() 2303 " This was causing a crash or ml_get error. 2304 enew! 2305 call setline(1,'xxx') 2306 normal $ 2307 new 2308 call setline(1, range(1,2)) 2309 2 2310 exe "norm \<C-V>$" 2311 bw! 2312 norm yp 2313 set nomodified 2314endfunc 2315 2316func! Test_normal47_autocmd() 2317 " disabled, does not seem to be possible currently 2318 throw "Skipped: not possible to test cursorhold autocmd while waiting for input in normal_cmd" 2319 new 2320 call append(0, repeat('-',20)) 2321 au CursorHold * call feedkeys('2l', '') 2322 1 2323 set updatetime=20 2324 " should delete 12 chars (d12l) 2325 call feedkeys('d1', '!') 2326 call assert_equal('--------', getline(1)) 2327 2328 " clean up 2329 au! CursorHold 2330 set updatetime=4000 2331 bw! 2332endfunc 2333 2334func! Test_normal48_wincmd() 2335 new 2336 exe "norm! \<c-w>c" 2337 call assert_equal(1, winnr('$')) 2338 call assert_fails(":norm! \<c-w>c", "E444") 2339endfunc 2340 2341func! Test_normal49_counts() 2342 new 2343 call setline(1, 'one two three four five six seven eight nine ten') 2344 1 2345 norm! 3d2w 2346 call assert_equal('seven eight nine ten', getline(1)) 2347 bw! 2348endfunc 2349 2350func! Test_normal50_commandline() 2351 if !has("timers") || !has("cmdline_hist") 2352 return 2353 endif 2354 func! DoTimerWork(id) 2355 call assert_equal('[Command Line]', bufname('')) 2356 " should fail, with E11, but does fail with E23? 2357 "call feedkeys("\<c-^>", 'tm') 2358 2359 " should also fail with E11 2360 call assert_fails(":wincmd p", 'E11') 2361 " return from commandline window 2362 call feedkeys("\<cr>") 2363 endfunc 2364 2365 let oldlang=v:lang 2366 lang C 2367 set updatetime=20 2368 call timer_start(100, 'DoTimerWork') 2369 try 2370 " throws E23, for whatever reason... 2371 call feedkeys('q:', 'x!') 2372 catch /E23/ 2373 " no-op 2374 endtry 2375 " clean up 2376 set updatetime=4000 2377 exe "lang" oldlang 2378 bw! 2379endfunc 2380 2381func! Test_normal51_FileChangedRO() 2382 if !has("autocmd") 2383 return 2384 endif 2385 " Don't sleep after the warning message. 2386 call test_settime(1) 2387 call writefile(['foo'], 'Xreadonly.log') 2388 new Xreadonly.log 2389 setl ro 2390 au FileChangedRO <buffer> :call feedkeys("\<c-^>", 'tix') 2391 call assert_fails(":norm! Af", 'E788') 2392 call assert_equal(['foo'], getline(1,'$')) 2393 call assert_equal('Xreadonly.log', bufname('')) 2394 2395 " cleanup 2396 call test_settime(0) 2397 bw! 2398 call delete("Xreadonly.log") 2399endfunc 2400 2401func! Test_normal52_rl() 2402 if !has("rightleft") 2403 return 2404 endif 2405 new 2406 call setline(1, 'abcde fghij klmnopq') 2407 norm! 1gg$ 2408 set rl 2409 call assert_equal(19, col('.')) 2410 call feedkeys('l', 'tx') 2411 call assert_equal(18, col('.')) 2412 call feedkeys('h', 'tx') 2413 call assert_equal(19, col('.')) 2414 call feedkeys("\<right>", 'tx') 2415 call assert_equal(18, col('.')) 2416 call feedkeys("\<s-right>", 'tx') 2417 call assert_equal(13, col('.')) 2418 call feedkeys("\<c-right>", 'tx') 2419 call assert_equal(7, col('.')) 2420 call feedkeys("\<c-left>", 'tx') 2421 call assert_equal(13, col('.')) 2422 call feedkeys("\<s-left>", 'tx') 2423 call assert_equal(19, col('.')) 2424 call feedkeys("<<", 'tx') 2425 call assert_equal(' abcde fghij klmnopq',getline(1)) 2426 call feedkeys(">>", 'tx') 2427 call assert_equal('abcde fghij klmnopq',getline(1)) 2428 2429 " cleanup 2430 set norl 2431 bw! 2432endfunc 2433 2434func! Test_normal53_digraph() 2435 if !has('digraphs') 2436 return 2437 endif 2438 new 2439 call setline(1, 'abcdefgh|') 2440 exe "norm! 1gg0f\<c-k>!!" 2441 call assert_equal(9, col('.')) 2442 set cpo+=D 2443 exe "norm! 1gg0f\<c-k>!!" 2444 call assert_equal(1, col('.')) 2445 2446 set cpo-=D 2447 bw! 2448endfunc 2449 2450func Test_normal54_Ctrl_bsl() 2451 new 2452 call setline(1, 'abcdefghijklmn') 2453 exe "norm! df\<c-\>\<c-n>" 2454 call assert_equal(['abcdefghijklmn'], getline(1,'$')) 2455 exe "norm! df\<c-\>\<c-g>" 2456 call assert_equal(['abcdefghijklmn'], getline(1,'$')) 2457 exe "norm! df\<c-\>m" 2458 call assert_equal(['abcdefghijklmn'], getline(1,'$')) 2459 if !has("multi_byte") 2460 return 2461 endif 2462 call setline(2, 'abcdefghijklmnāf') 2463 norm! 2gg0 2464 exe "norm! df\<Char-0x101>" 2465 call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$')) 2466 norm! 1gg0 2467 exe "norm! df\<esc>" 2468 call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$')) 2469 2470 " clean up 2471 bw! 2472endfunc 2473 2474func Test_normal_large_count() 2475 " This may fail with 32bit long, how do we detect that? 2476 new 2477 normal o 2478 normal 6666666666dL 2479 bwipe! 2480endfunc 2481 2482func Test_delete_until_paragraph() 2483 if !has('multi_byte') 2484 return 2485 endif 2486 new 2487 normal grádv} 2488 call assert_equal('á', getline(1)) 2489 normal grád} 2490 call assert_equal('', getline(1)) 2491 bwipe! 2492endfunc 2493 2494" Test for the gr (virtual replace) command 2495" Test for the bug fixed by 7.4.387 2496func Test_gr_command() 2497 enew! 2498 let save_cpo = &cpo 2499 call append(0, ['First line', 'Second line', 'Third line']) 2500 exe "normal i\<C-G>u" 2501 call cursor(2, 1) 2502 set cpo-=X 2503 normal 4gro 2504 call assert_equal('oooond line', getline(2)) 2505 undo 2506 set cpo+=X 2507 normal 4gro 2508 call assert_equal('ooooecond line', getline(2)) 2509 let &cpo = save_cpo 2510 enew! 2511endfunc 2512 2513" When splitting a window the changelist position is wrong. 2514" Test the changelist position after splitting a window. 2515" Test for the bug fixed by 7.4.386 2516func Test_changelist() 2517 let save_ul = &ul 2518 enew! 2519 call append('$', ['1', '2']) 2520 exe "normal i\<C-G>u" 2521 exe "normal Gkylpa\<C-G>u" 2522 set ul=100 2523 exe "normal Gylpa\<C-G>u" 2524 set ul=100 2525 normal gg 2526 vsplit 2527 normal g; 2528 call assert_equal([3, 2], [line('.'), col('.')]) 2529 normal g; 2530 call assert_equal([2, 2], [line('.'), col('.')]) 2531 call assert_fails('normal g;', 'E662:') 2532 %bwipe! 2533 let &ul = save_ul 2534endfunc 2535