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\.0\*', 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 g Ctrl-G 1810 set ff=unix 1811 let a=execute(":norm! g\<c-g>") 1812 call assert_match('Col 15 of 43; Line 2 of 2; Word 2 of 2; Byte 16 of 45', a) 1813 1814 " Test for gI 1815 norm! gIfoo 1816 call assert_equal(['', 'fooabcdefghijk lmno0123456789AMNOPQRSTUVWXYZ'], getline(1,'$')) 1817 1818 " Test for gi 1819 wincmd c 1820 %d 1821 set tw=0 1822 call setline(1, ['foobar', 'new line']) 1823 norm! A next word 1824 $put ='third line' 1825 norm! gi another word 1826 call assert_equal(['foobar next word another word', 'new line', 'third line'], getline(1,'$')) 1827 1828 " clean up 1829 bw! 1830endfunc 1831 1832fun! Test_normal34_g_cmd3() 1833 if !has("multi_byte") 1834 return 1835 endif 1836 1837 " Test for g8 1838 new 1839 let a=execute(':norm! 1G0g8') 1840 call assert_equal("\nNUL", a) 1841 1842 call setline(1, 'abcdefghijklmnopqrstuvwxyzäüö') 1843 let a=execute(':norm! 1G$g8') 1844 call assert_equal("\nc3 b6 ", a) 1845 1846 call setline(1, "a\u0302") 1847 let a=execute(':norm! 1G0g8') 1848 call assert_equal("\n61 + cc 82 ", a) 1849 1850 " clean up 1851 bw! 1852endfunc 1853 1854func Test_normal_8g8() 1855 if !has("multi_byte") 1856 return 1857 endif 1858 new 1859 1860 " Test 8g8 which finds invalid utf8 at or after the cursor. 1861 1862 " With invalid byte. 1863 call setline(1, "___\xff___") 1864 norm! 1G08g8g 1865 call assert_equal([0, 1, 4, 0, 1], getcurpos()) 1866 1867 " With invalid byte before the cursor. 1868 call setline(1, "___\xff___") 1869 norm! 1G$h8g8g 1870 call assert_equal([0, 1, 6, 0, 9], getcurpos()) 1871 1872 " With truncated sequence. 1873 call setline(1, "___\xE2\x82___") 1874 norm! 1G08g8g 1875 call assert_equal([0, 1, 4, 0, 1], getcurpos()) 1876 1877 " With overlong sequence. 1878 call setline(1, "___\xF0\x82\x82\xAC___") 1879 norm! 1G08g8g 1880 call assert_equal([0, 1, 4, 0, 1], getcurpos()) 1881 1882 " With valid utf8. 1883 call setline(1, "café") 1884 norm! 1G08g8 1885 call assert_equal([0, 1, 1, 0, 1], getcurpos()) 1886 1887 bw! 1888endfunc 1889 1890fun! Test_normal35_g_cmd4() 1891 " Test for g< 1892 " Cannot capture its output, 1893 " probably a bug, therefore, test disabled: 1894 throw "Skipped: output of g< can't be tested currently" 1895 echo "a\nb\nc\nd" 1896 let b=execute(':norm! g<') 1897 call assert_true(!empty(b), 'failed `execute(g<)`') 1898endfunc 1899 1900fun! Test_normal36_g_cmd5() 1901 new 1902 call append(0, 'abcdefghijklmnopqrstuvwxyz') 1903 set ff=unix 1904 " Test for gp gP 1905 call append(1, range(1,10)) 1906 1 1907 norm! 1yy 1908 3 1909 norm! gp 1910 call assert_equal([0, 5, 1, 0, 1], getcurpos()) 1911 $ 1912 norm! gP 1913 call assert_equal([0, 14, 1, 0, 1], getcurpos()) 1914 1915 " Test for go 1916 norm! 26go 1917 call assert_equal([0, 1, 26, 0, 26], getcurpos()) 1918 norm! 27go 1919 call assert_equal([0, 1, 26, 0, 26], getcurpos()) 1920 norm! 28go 1921 call assert_equal([0, 2, 1, 0, 1], getcurpos()) 1922 set ff=dos 1923 norm! 29go 1924 call assert_equal([0, 2, 1, 0, 1], getcurpos()) 1925 set ff=unix 1926 norm! gg0 1927 norm! 101go 1928 call assert_equal([0, 13, 26, 0, 26], getcurpos()) 1929 norm! 103go 1930 call assert_equal([0, 14, 1, 0, 1], getcurpos()) 1931 " count > buffer content 1932 norm! 120go 1933 call assert_equal([0, 14, 1, 0, 2147483647], getcurpos()) 1934 " clean up 1935 bw! 1936endfunc 1937 1938fun! Test_normal37_g_cmd6() 1939 " basic test for gt and gT 1940 tabnew 1.txt 1941 tabnew 2.txt 1942 tabnew 3.txt 1943 norm! 1gt 1944 call assert_equal(1, tabpagenr()) 1945 norm! 3gt 1946 call assert_equal(3, tabpagenr()) 1947 norm! 1gT 1948 " count gT goes not to the absolute tabpagenumber 1949 " but, but goes to the count previous tabpagenumber 1950 call assert_equal(2, tabpagenr()) 1951 " wrap around 1952 norm! 3gT 1953 call assert_equal(3, tabpagenr()) 1954 " gt does not wrap around 1955 norm! 5gt 1956 call assert_equal(3, tabpagenr()) 1957 1958 for i in range(3) 1959 tabclose 1960 endfor 1961 " clean up 1962 call assert_fails(':tabclose', 'E784') 1963endfunc 1964 1965fun! Test_normal38_nvhome() 1966 " Test for <Home> and <C-Home> key 1967 new 1968 call setline(1, range(10)) 1969 $ 1970 setl et sw=2 1971 norm! V10>$ 1972 " count is ignored 1973 exe "norm! 10\<home>" 1974 call assert_equal(1, col('.')) 1975 exe "norm! \<home>" 1976 call assert_equal([0, 10, 1, 0, 1], getcurpos()) 1977 exe "norm! 5\<c-home>" 1978 call assert_equal([0, 5, 1, 0, 1], getcurpos()) 1979 exe "norm! \<c-home>" 1980 call assert_equal([0, 1, 1, 0, 1], getcurpos()) 1981 1982 " clean up 1983 bw! 1984endfunc 1985 1986fun! Test_normal39_cw() 1987 " Test for cw and cW on whitespace 1988 " and cpo+=w setting 1989 new 1990 set tw=0 1991 call append(0, 'here are some words') 1992 norm! 1gg0elcwZZZ 1993 call assert_equal('hereZZZare some words', getline('.')) 1994 norm! 1gg0elcWYYY 1995 call assert_equal('hereZZZareYYYsome words', getline('.')) 1996 set cpo+=w 1997 call setline(1, 'here are some words') 1998 norm! 1gg0elcwZZZ 1999 call assert_equal('hereZZZ are some words', getline('.')) 2000 norm! 1gg2elcWYYY 2001 call assert_equal('hereZZZ areYYY some words', getline('.')) 2002 set cpo-=w 2003 norm! 2gg0cwfoo 2004 call assert_equal('foo', getline('.')) 2005 2006 " clean up 2007 bw! 2008endfunc 2009 2010fun! Test_normal40_ctrl_bsl() 2011 " Basic test for CTRL-\ commands 2012 new 2013 call append(0, 'here are some words') 2014 exe "norm! 1gg0a\<C-\>\<C-N>" 2015 call assert_equal('n', mode()) 2016 call assert_equal(1, col('.')) 2017 call assert_equal('', visualmode()) 2018 exe "norm! 1gg0viw\<C-\>\<C-N>" 2019 call assert_equal('n', mode()) 2020 call assert_equal(4, col('.')) 2021 exe "norm! 1gg0a\<C-\>\<C-G>" 2022 call assert_equal('n', mode()) 2023 call assert_equal(1, col('.')) 2024 "imap <buffer> , <c-\><c-n> 2025 set im 2026 exe ":norm! \<c-\>\<c-n>dw" 2027 set noim 2028 call assert_equal('are some words', getline(1)) 2029 call assert_false(&insertmode) 2030 2031 " clean up 2032 bw! 2033endfunc 2034 2035fun! Test_normal41_insert_reg() 2036 " Test for <c-r>=, <c-r><c-r>= and <c-r><c-o>= 2037 " in insert mode 2038 new 2039 set sts=2 sw=2 ts=8 tw=0 2040 call append(0, ["aaa\tbbb\tccc", '', '', '']) 2041 let a=getline(1) 2042 norm! 2gg0 2043 exe "norm! a\<c-r>=a\<cr>" 2044 norm! 3gg0 2045 exe "norm! a\<c-r>\<c-r>=a\<cr>" 2046 norm! 4gg0 2047 exe "norm! a\<c-r>\<c-o>=a\<cr>" 2048 call assert_equal(['aaa bbb ccc', 'aaa bbb ccc', 'aaa bbb ccc', 'aaa bbb ccc', ''], getline(1, '$')) 2049 2050 " clean up 2051 set sts=0 sw=8 ts=8 2052 bw! 2053endfunc 2054 2055func! Test_normal42_halfpage() 2056 " basic test for Ctrl-D and Ctrl-U 2057 call Setup_NewWindow() 2058 call assert_equal(5, &scroll) 2059 exe "norm! \<c-d>" 2060 call assert_equal('6', getline('.')) 2061 exe "norm! 2\<c-d>" 2062 call assert_equal('8', getline('.')) 2063 call assert_equal(2, &scroll) 2064 set scroll=5 2065 exe "norm! \<c-u>" 2066 call assert_equal('3', getline('.')) 2067 1 2068 set scrolloff=5 2069 exe "norm! \<c-d>" 2070 call assert_equal('10', getline('.')) 2071 exe "norm! \<c-u>" 2072 call assert_equal('5', getline('.')) 2073 1 2074 set scrolloff=99 2075 exe "norm! \<c-d>" 2076 call assert_equal('10', getline('.')) 2077 set scrolloff=0 2078 100 2079 exe "norm! $\<c-u>" 2080 call assert_equal('95', getline('.')) 2081 call assert_equal([0, 95, 1, 0, 1], getcurpos()) 2082 100 2083 set nostartofline 2084 exe "norm! $\<c-u>" 2085 call assert_equal('95', getline('.')) 2086 call assert_equal([0, 95, 2, 0, 2147483647], getcurpos()) 2087 " cleanup 2088 set startofline 2089 bw! 2090endfunc 2091 2092fun! Test_normal43_textobject1() 2093 " basic tests for text object aw 2094 new 2095 call append(0, ['foobar,eins,foobar', 'foo,zwei,foo ']) 2096 " diw 2097 norm! 1gg0diw 2098 call assert_equal([',eins,foobar', 'foo,zwei,foo ', ''], getline(1,'$')) 2099 " daw 2100 norm! 2ggEdaw 2101 call assert_equal([',eins,foobar', 'foo,zwei,', ''], getline(1, '$')) 2102 %d 2103 call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo "]) 2104 " diW 2105 norm! 2ggwd2iW 2106 call assert_equal(['foo eins foobar', 'foo foo ', ''], getline(1,'$')) 2107 " daW 2108 norm! 1ggd2aW 2109 call assert_equal(['foobar', 'foo foo ', ''], getline(1,'$')) 2110 2111 %d 2112 call append(0, ["foo\teins\tfoobar", "foo\tzwei\tfoo "]) 2113 " aw in visual line mode switches to characterwise mode 2114 norm! 2gg$Vawd 2115 call assert_equal(['foo eins foobar', 'foo zwei foo'], getline(1,'$')) 2116 norm! 1gg$Viwd 2117 call assert_equal(['foo eins ', 'foo zwei foo'], getline(1,'$')) 2118 2119 " clean up 2120 bw! 2121endfunc 2122 2123func! Test_normal44_textobjects2() 2124 " basic testing for is and as text objects 2125 new 2126 call append(0, ['This is a test. With some sentences!', '', 'Even with a question? And one more. And no sentence here']) 2127 " Test for dis - does not remove trailing whitespace 2128 norm! 1gg0dis 2129 call assert_equal([' With some sentences!', '', 'Even with a question? And one more. And no sentence here', ''], getline(1,'$')) 2130 " Test for das - removes leading whitespace 2131 norm! 3ggf?ldas 2132 call assert_equal([' With some sentences!', '', 'Even with a question? And no sentence here', ''], getline(1,'$')) 2133 " when used in visual mode, is made characterwise 2134 norm! 3gg$Visy 2135 call assert_equal('v', visualmode()) 2136 " reset visualmode() 2137 norm! 3ggVy 2138 norm! 3gg$Vasy 2139 call assert_equal('v', visualmode()) 2140 " basic testing for textobjects a< and at 2141 %d 2142 call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>',' </div>', ' ']) 2143 " a< 2144 norm! 1gg0da< 2145 call assert_equal([' ', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2146 norm! 1pj 2147 call assert_equal([' <div>', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2148 " at 2149 norm! d2at 2150 call assert_equal([' '], getline(1,'$')) 2151 %d 2152 call setline(1, ['<div> ','<a href="foobar" class="foo">xyz</a>',' </div>', ' ']) 2153 " i< 2154 norm! 1gg0di< 2155 call assert_equal(['<> ', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2156 norm! 1Pj 2157 call assert_equal(['<div> ', '<a href="foobar" class="foo">xyz</a>', ' </div>', ' '], getline(1,'$')) 2158 norm! d2it 2159 call assert_equal(['<div></div>',' '], getline(1,'$')) 2160 " basic testing for a[ and i[ text object 2161 %d 2162 call setline(1, [' ', '[', 'one [two]', 'thre', ']']) 2163 norm! 3gg0di[ 2164 call assert_equal([' ', '[', ']'], getline(1,'$')) 2165 call setline(1, [' ', '[', 'one [two]', 'thre', ']']) 2166 norm! 3gg0ftd2a[ 2167 call assert_equal([' '], getline(1,'$')) 2168 %d 2169 " Test for i" when cursor is in front of a quoted object 2170 call append(0, 'foo "bar"') 2171 norm! 1gg0di" 2172 call assert_equal(['foo ""', ''], getline(1,'$')) 2173 2174 " clean up 2175 bw! 2176endfunc 2177 2178func! Test_normal45_drop() 2179 if !has('dnd') 2180 " The ~ register does not exist 2181 call assert_beeps('norm! "~') 2182 return 2183 endif 2184 2185 " basic test for drag-n-drop 2186 " unfortunately, without a gui, we can't really test much here, 2187 " so simply test that ~p fails (which uses the drop register) 2188 new 2189 call assert_fails(':norm! "~p', 'E353') 2190 call assert_equal([], getreg('~', 1, 1)) 2191 " the ~ register is read only 2192 call assert_fails(':let @~="1"', 'E354') 2193 bw! 2194endfunc 2195 2196func! Test_normal46_ignore() 2197 " This test uses multi byte characters 2198 if !has("multi_byte") 2199 return 2200 endif 2201 2202 new 2203 " How to test this? 2204 " let's just for now test, that the buffer 2205 " does not change 2206 call feedkeys("\<c-s>", 't') 2207 call assert_equal([''], getline(1,'$')) 2208 2209 " no valid commands 2210 exe "norm! \<char-0x100>" 2211 call assert_equal([''], getline(1,'$')) 2212 2213 exe "norm! ä" 2214 call assert_equal([''], getline(1,'$')) 2215 2216 " clean up 2217 bw! 2218endfunc 2219 2220func! Test_normal47_visual_buf_wipe() 2221 " This was causing a crash or ml_get error. 2222 enew! 2223 call setline(1,'xxx') 2224 normal $ 2225 new 2226 call setline(1, range(1,2)) 2227 2 2228 exe "norm \<C-V>$" 2229 bw! 2230 norm yp 2231 set nomodified 2232endfunc 2233 2234func! Test_normal47_autocmd() 2235 " disabled, does not seem to be possible currently 2236 throw "Skipped: not possible to test cursorhold autocmd while waiting for input in normal_cmd" 2237 new 2238 call append(0, repeat('-',20)) 2239 au CursorHold * call feedkeys('2l', '') 2240 1 2241 set updatetime=20 2242 " should delete 12 chars (d12l) 2243 call feedkeys('d1', '!') 2244 call assert_equal('--------', getline(1)) 2245 2246 " clean up 2247 au! CursorHold 2248 set updatetime=4000 2249 bw! 2250endfunc 2251 2252func! Test_normal48_wincmd() 2253 new 2254 exe "norm! \<c-w>c" 2255 call assert_equal(1, winnr('$')) 2256 call assert_fails(":norm! \<c-w>c", "E444") 2257endfunc 2258 2259func! Test_normal49_counts() 2260 new 2261 call setline(1, 'one two three four five six seven eight nine ten') 2262 1 2263 norm! 3d2w 2264 call assert_equal('seven eight nine ten', getline(1)) 2265 bw! 2266endfunc 2267 2268func! Test_normal50_commandline() 2269 if !has("timers") || !has("cmdline_hist") 2270 return 2271 endif 2272 func! DoTimerWork(id) 2273 call assert_equal('[Command Line]', bufname('')) 2274 " should fail, with E11, but does fail with E23? 2275 "call feedkeys("\<c-^>", 'tm') 2276 2277 " should also fail with E11 2278 call assert_fails(":wincmd p", 'E11') 2279 " return from commandline window 2280 call feedkeys("\<cr>") 2281 endfunc 2282 2283 let oldlang=v:lang 2284 lang C 2285 set updatetime=20 2286 call timer_start(100, 'DoTimerWork') 2287 try 2288 " throws E23, for whatever reason... 2289 call feedkeys('q:', 'x!') 2290 catch /E23/ 2291 " no-op 2292 endtry 2293 " clean up 2294 set updatetime=4000 2295 exe "lang" oldlang 2296 bw! 2297endfunc 2298 2299func! Test_normal51_FileChangedRO() 2300 if !has("autocmd") 2301 return 2302 endif 2303 " Don't sleep after the warning message. 2304 call test_settime(1) 2305 call writefile(['foo'], 'Xreadonly.log') 2306 new Xreadonly.log 2307 setl ro 2308 au FileChangedRO <buffer> :call feedkeys("\<c-^>", 'tix') 2309 call assert_fails(":norm! Af", 'E788') 2310 call assert_equal(['foo'], getline(1,'$')) 2311 call assert_equal('Xreadonly.log', bufname('')) 2312 2313 " cleanup 2314 call test_settime(0) 2315 bw! 2316 call delete("Xreadonly.log") 2317endfunc 2318 2319func! Test_normal52_rl() 2320 if !has("rightleft") 2321 return 2322 endif 2323 new 2324 call setline(1, 'abcde fghij klmnopq') 2325 norm! 1gg$ 2326 set rl 2327 call assert_equal(19, col('.')) 2328 call feedkeys('l', 'tx') 2329 call assert_equal(18, col('.')) 2330 call feedkeys('h', 'tx') 2331 call assert_equal(19, col('.')) 2332 call feedkeys("\<right>", 'tx') 2333 call assert_equal(18, col('.')) 2334 call feedkeys("\<s-right>", 'tx') 2335 call assert_equal(13, col('.')) 2336 call feedkeys("\<c-right>", 'tx') 2337 call assert_equal(7, col('.')) 2338 call feedkeys("\<c-left>", 'tx') 2339 call assert_equal(13, col('.')) 2340 call feedkeys("\<s-left>", 'tx') 2341 call assert_equal(19, col('.')) 2342 call feedkeys("<<", 'tx') 2343 call assert_equal(' abcde fghij klmnopq',getline(1)) 2344 call feedkeys(">>", 'tx') 2345 call assert_equal('abcde fghij klmnopq',getline(1)) 2346 2347 " cleanup 2348 set norl 2349 bw! 2350endfunc 2351 2352func! Test_normal53_digraph() 2353 if !has('digraphs') 2354 return 2355 endif 2356 new 2357 call setline(1, 'abcdefgh|') 2358 exe "norm! 1gg0f\<c-k>!!" 2359 call assert_equal(9, col('.')) 2360 set cpo+=D 2361 exe "norm! 1gg0f\<c-k>!!" 2362 call assert_equal(1, col('.')) 2363 2364 set cpo-=D 2365 bw! 2366endfunc 2367 2368func Test_normal54_Ctrl_bsl() 2369 new 2370 call setline(1, 'abcdefghijklmn') 2371 exe "norm! df\<c-\>\<c-n>" 2372 call assert_equal(['abcdefghijklmn'], getline(1,'$')) 2373 exe "norm! df\<c-\>\<c-g>" 2374 call assert_equal(['abcdefghijklmn'], getline(1,'$')) 2375 exe "norm! df\<c-\>m" 2376 call assert_equal(['abcdefghijklmn'], getline(1,'$')) 2377 if !has("multi_byte") 2378 return 2379 endif 2380 call setline(2, 'abcdefghijklmnāf') 2381 norm! 2gg0 2382 exe "norm! df\<Char-0x101>" 2383 call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$')) 2384 norm! 1gg0 2385 exe "norm! df\<esc>" 2386 call assert_equal(['abcdefghijklmn', 'f'], getline(1,'$')) 2387 2388 " clean up 2389 bw! 2390endfunc 2391 2392func Test_normal_large_count() 2393 " This may fail with 32bit long, how do we detect that? 2394 new 2395 normal o 2396 normal 6666666666dL 2397 bwipe! 2398endfunc 2399 2400func Test_delete_until_paragraph() 2401 if !has('multi_byte') 2402 return 2403 endif 2404 new 2405 normal grádv} 2406 call assert_equal('á', getline(1)) 2407 normal grád} 2408 call assert_equal('', getline(1)) 2409 bwipe! 2410endfunc 2411 2412" Test for the gr (virtual replace) command 2413" Test for the bug fixed by 7.4.387 2414func Test_gr_command() 2415 enew! 2416 let save_cpo = &cpo 2417 call append(0, ['First line', 'Second line', 'Third line']) 2418 exe "normal i\<C-G>u" 2419 call cursor(2, 1) 2420 set cpo-=X 2421 normal 4gro 2422 call assert_equal('oooond line', getline(2)) 2423 undo 2424 set cpo+=X 2425 normal 4gro 2426 call assert_equal('ooooecond line', getline(2)) 2427 let &cpo = save_cpo 2428 enew! 2429endfunc 2430 2431" When splitting a window the changelist position is wrong. 2432" Test the changelist position after splitting a window. 2433" Test for the bug fixed by 7.4.386 2434func Test_changelist() 2435 let save_ul = &ul 2436 enew! 2437 call append('$', ['1', '2']) 2438 exe "normal i\<C-G>u" 2439 exe "normal Gkylpa\<C-G>u" 2440 set ul=100 2441 exe "normal Gylpa\<C-G>u" 2442 set ul=100 2443 normal gg 2444 vsplit 2445 normal g; 2446 call assert_equal([3, 2], [line('.'), col('.')]) 2447 normal g; 2448 call assert_equal([2, 2], [line('.'), col('.')]) 2449 call assert_fails('normal g;', 'E662:') 2450 %bwipe! 2451 let &ul = save_ul 2452endfunc 2453