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