1" Tests for editing the command line. 2 3source check.vim 4source screendump.vim 5 6func Test_complete_tab() 7 call writefile(['testfile'], 'Xtestfile') 8 call feedkeys(":e Xtest\t\r", "tx") 9 call assert_equal('testfile', getline(1)) 10 call delete('Xtestfile') 11endfunc 12 13func Test_complete_list() 14 " We can't see the output, but at least we check the code runs properly. 15 call feedkeys(":e test\<C-D>\r", "tx") 16 call assert_equal('test', expand('%:t')) 17endfunc 18 19func Test_complete_wildmenu() 20 call mkdir('Xdir1/Xdir2', 'p') 21 call writefile(['testfile1'], 'Xdir1/Xtestfile1') 22 call writefile(['testfile2'], 'Xdir1/Xtestfile2') 23 call writefile(['testfile3'], 'Xdir1/Xdir2/Xtestfile3') 24 call writefile(['testfile3'], 'Xdir1/Xdir2/Xtestfile4') 25 set wildmenu 26 27 " Pressing <Tab> completes, and moves to next files when pressing again. 28 call feedkeys(":e Xdir1/\<Tab>\<Tab>\<CR>", 'tx') 29 call assert_equal('testfile1', getline(1)) 30 call feedkeys(":e Xdir1/\<Tab>\<Tab>\<Tab>\<CR>", 'tx') 31 call assert_equal('testfile2', getline(1)) 32 33 " <S-Tab> is like <Tab> but begin with the last match and then go to 34 " previous. 35 call feedkeys(":e Xdir1/Xtest\<S-Tab>\<CR>", 'tx') 36 call assert_equal('testfile2', getline(1)) 37 call feedkeys(":e Xdir1/Xtest\<S-Tab>\<S-Tab>\<CR>", 'tx') 38 call assert_equal('testfile1', getline(1)) 39 40 " <Left>/<Right> to move to previous/next file. 41 call feedkeys(":e Xdir1/\<Tab>\<Right>\<CR>", 'tx') 42 call assert_equal('testfile1', getline(1)) 43 call feedkeys(":e Xdir1/\<Tab>\<Right>\<Right>\<CR>", 'tx') 44 call assert_equal('testfile2', getline(1)) 45 call feedkeys(":e Xdir1/\<Tab>\<Right>\<Right>\<Left>\<CR>", 'tx') 46 call assert_equal('testfile1', getline(1)) 47 48 " <Up>/<Down> to go up/down directories. 49 call feedkeys(":e Xdir1/\<Tab>\<Down>\<CR>", 'tx') 50 call assert_equal('testfile3', getline(1)) 51 call feedkeys(":e Xdir1/\<Tab>\<Down>\<Up>\<Right>\<CR>", 'tx') 52 call assert_equal('testfile1', getline(1)) 53 54 " cleanup 55 %bwipe 56 call delete('Xdir1/Xdir2/Xtestfile4') 57 call delete('Xdir1/Xdir2/Xtestfile3') 58 call delete('Xdir1/Xtestfile2') 59 call delete('Xdir1/Xtestfile1') 60 call delete('Xdir1/Xdir2', 'd') 61 call delete('Xdir1', 'd') 62 set nowildmenu 63endfunc 64 65func Test_map_completion() 66 if !has('cmdline_compl') 67 return 68 endif 69 call feedkeys(":map <unique> <si\<Tab>\<Home>\"\<CR>", 'xt') 70 call assert_equal('"map <unique> <silent>', getreg(':')) 71 call feedkeys(":map <script> <un\<Tab>\<Home>\"\<CR>", 'xt') 72 call assert_equal('"map <script> <unique>', getreg(':')) 73 call feedkeys(":map <expr> <sc\<Tab>\<Home>\"\<CR>", 'xt') 74 call assert_equal('"map <expr> <script>', getreg(':')) 75 call feedkeys(":map <buffer> <e\<Tab>\<Home>\"\<CR>", 'xt') 76 call assert_equal('"map <buffer> <expr>', getreg(':')) 77 call feedkeys(":map <nowait> <b\<Tab>\<Home>\"\<CR>", 'xt') 78 call assert_equal('"map <nowait> <buffer>', getreg(':')) 79 call feedkeys(":map <special> <no\<Tab>\<Home>\"\<CR>", 'xt') 80 call assert_equal('"map <special> <nowait>', getreg(':')) 81 call feedkeys(":map <silent> <sp\<Tab>\<Home>\"\<CR>", 'xt') 82 call assert_equal('"map <silent> <special>', getreg(':')) 83 84 map <Middle>x middle 85 86 map ,f commaf 87 map ,g commaf 88 map <Left> left 89 map <A-Left>x shiftleft 90 call feedkeys(":map ,\<Tab>\<Home>\"\<CR>", 'xt') 91 call assert_equal('"map ,f', getreg(':')) 92 call feedkeys(":map ,\<Tab>\<Tab>\<Home>\"\<CR>", 'xt') 93 call assert_equal('"map ,g', getreg(':')) 94 call feedkeys(":map <L\<Tab>\<Home>\"\<CR>", 'xt') 95 call assert_equal('"map <Left>', getreg(':')) 96 call feedkeys(":map <A-Left>\<Tab>\<Home>\"\<CR>", 'xt') 97 call assert_equal("\"map <A-Left>\<Tab>", getreg(':')) 98 unmap ,f 99 unmap ,g 100 unmap <Left> 101 unmap <A-Left>x 102 103 set cpo-=< cpo-=B cpo-=k 104 map <Left> left 105 call feedkeys(":map <L\<Tab>\<Home>\"\<CR>", 'xt') 106 call assert_equal('"map <Left>', getreg(':')) 107 call feedkeys(":map <M\<Tab>\<Home>\"\<CR>", 'xt') 108 call assert_equal("\"map <M\<Tab>", getreg(':')) 109 unmap <Left> 110 111 set cpo+=< 112 map <Left> left 113 exe "set t_k6=\<Esc>[17~" 114 call feedkeys(":map \<Esc>[17~x f6x\<CR>", 'xt') 115 call feedkeys(":map <L\<Tab>\<Home>\"\<CR>", 'xt') 116 call assert_equal('"map <Left>', getreg(':')) 117 if !has('gui_running') 118 call feedkeys(":map \<Esc>[17~\<Tab>\<Home>\"\<CR>", 'xt') 119 call assert_equal("\"map <F6>x", getreg(':')) 120 endif 121 unmap <Left> 122 call feedkeys(":unmap \<Esc>[17~x\<CR>", 'xt') 123 set cpo-=< 124 125 set cpo+=B 126 map <Left> left 127 call feedkeys(":map <L\<Tab>\<Home>\"\<CR>", 'xt') 128 call assert_equal('"map <Left>', getreg(':')) 129 unmap <Left> 130 set cpo-=B 131 132 set cpo+=k 133 map <Left> left 134 call feedkeys(":map <L\<Tab>\<Home>\"\<CR>", 'xt') 135 call assert_equal('"map <Left>', getreg(':')) 136 unmap <Left> 137 set cpo-=k 138 139 unmap <Middle>x 140 set cpo&vim 141endfunc 142 143func Test_match_completion() 144 if !has('cmdline_compl') 145 return 146 endif 147 hi Aardig ctermfg=green 148 call feedkeys(":match \<Tab>\<Home>\"\<CR>", 'xt') 149 call assert_equal('"match Aardig', getreg(':')) 150 call feedkeys(":match \<S-Tab>\<Home>\"\<CR>", 'xt') 151 call assert_equal('"match none', getreg(':')) 152endfunc 153 154func Test_highlight_completion() 155 if !has('cmdline_compl') 156 return 157 endif 158 hi Aardig ctermfg=green 159 call feedkeys(":hi \<Tab>\<Home>\"\<CR>", 'xt') 160 call assert_equal('"hi Aardig', getreg(':')) 161 call feedkeys(":hi default \<Tab>\<Home>\"\<CR>", 'xt') 162 call assert_equal('"hi default Aardig', getreg(':')) 163 call feedkeys(":hi clear Aa\<Tab>\<Home>\"\<CR>", 'xt') 164 call assert_equal('"hi clear Aardig', getreg(':')) 165 call feedkeys(":hi li\<S-Tab>\<Home>\"\<CR>", 'xt') 166 call assert_equal('"hi link', getreg(':')) 167 call feedkeys(":hi d\<S-Tab>\<Home>\"\<CR>", 'xt') 168 call assert_equal('"hi default', getreg(':')) 169 call feedkeys(":hi c\<S-Tab>\<Home>\"\<CR>", 'xt') 170 call assert_equal('"hi clear', getreg(':')) 171 172 " A cleared group does not show up in completions. 173 hi Anders ctermfg=green 174 call assert_equal(['Aardig', 'Anders'], getcompletion('A', 'highlight')) 175 hi clear Aardig 176 call assert_equal(['Anders'], getcompletion('A', 'highlight')) 177 hi clear Anders 178 call assert_equal([], getcompletion('A', 'highlight')) 179endfunc 180 181func Test_expr_completion() 182 if !has('cmdline_compl') 183 return 184 endif 185 for cmd in [ 186 \ 'let a = ', 187 \ 'const a = ', 188 \ 'if', 189 \ 'elseif', 190 \ 'while', 191 \ 'for', 192 \ 'echo', 193 \ 'echon', 194 \ 'execute', 195 \ 'echomsg', 196 \ 'echoerr', 197 \ 'call', 198 \ 'return', 199 \ 'cexpr', 200 \ 'caddexpr', 201 \ 'cgetexpr', 202 \ 'lexpr', 203 \ 'laddexpr', 204 \ 'lgetexpr'] 205 call feedkeys(":" . cmd . " getl\<Tab>\<Home>\"\<CR>", 'xt') 206 call assert_equal('"' . cmd . ' getline(', getreg(':')) 207 endfor 208endfunc 209 210func Test_getcompletion() 211 if !has('cmdline_compl') 212 return 213 endif 214 let groupcount = len(getcompletion('', 'event')) 215 call assert_true(groupcount > 0) 216 let matchcount = len('File'->getcompletion('event')) 217 call assert_true(matchcount > 0) 218 call assert_true(groupcount > matchcount) 219 220 if has('menu') 221 source $VIMRUNTIME/menu.vim 222 let matchcount = len(getcompletion('', 'menu')) 223 call assert_true(matchcount > 0) 224 call assert_equal(['File.'], getcompletion('File', 'menu')) 225 call assert_true(matchcount > 0) 226 let matchcount = len(getcompletion('File.', 'menu')) 227 call assert_true(matchcount > 0) 228 endif 229 230 let l = getcompletion('v:n', 'var') 231 call assert_true(index(l, 'v:null') >= 0) 232 let l = getcompletion('v:notexists', 'var') 233 call assert_equal([], l) 234 235 args a.c b.c 236 let l = getcompletion('', 'arglist') 237 call assert_equal(['a.c', 'b.c'], l) 238 %argdelete 239 240 let l = getcompletion('', 'augroup') 241 call assert_true(index(l, 'END') >= 0) 242 let l = getcompletion('blahblah', 'augroup') 243 call assert_equal([], l) 244 245 let l = getcompletion('', 'behave') 246 call assert_true(index(l, 'mswin') >= 0) 247 let l = getcompletion('not', 'behave') 248 call assert_equal([], l) 249 250 let l = getcompletion('', 'color') 251 call assert_true(index(l, 'default') >= 0) 252 let l = getcompletion('dirty', 'color') 253 call assert_equal([], l) 254 255 let l = getcompletion('', 'command') 256 call assert_true(index(l, 'sleep') >= 0) 257 let l = getcompletion('awake', 'command') 258 call assert_equal([], l) 259 260 let l = getcompletion('', 'dir') 261 call assert_true(index(l, 'samples/') >= 0) 262 let l = getcompletion('NoMatch', 'dir') 263 call assert_equal([], l) 264 265 let l = getcompletion('exe', 'expression') 266 call assert_true(index(l, 'executable(') >= 0) 267 let l = getcompletion('kill', 'expression') 268 call assert_equal([], l) 269 270 let l = getcompletion('tag', 'function') 271 call assert_true(index(l, 'taglist(') >= 0) 272 let l = getcompletion('paint', 'function') 273 call assert_equal([], l) 274 275 let Flambda = {-> 'hello'} 276 let l = getcompletion('', 'function') 277 let l = filter(l, {i, v -> v =~ 'lambda'}) 278 call assert_equal([], l) 279 280 let l = getcompletion('run', 'file') 281 call assert_true(index(l, 'runtest.vim') >= 0) 282 let l = getcompletion('walk', 'file') 283 call assert_equal([], l) 284 set wildignore=*.vim 285 let l = getcompletion('run', 'file', 1) 286 call assert_true(index(l, 'runtest.vim') < 0) 287 set wildignore& 288 289 let l = getcompletion('ha', 'filetype') 290 call assert_true(index(l, 'hamster') >= 0) 291 let l = getcompletion('horse', 'filetype') 292 call assert_equal([], l) 293 294 let l = getcompletion('z', 'syntax') 295 call assert_true(index(l, 'zimbu') >= 0) 296 let l = getcompletion('emacs', 'syntax') 297 call assert_equal([], l) 298 299 let l = getcompletion('jikes', 'compiler') 300 call assert_true(index(l, 'jikes') >= 0) 301 let l = getcompletion('break', 'compiler') 302 call assert_equal([], l) 303 304 let l = getcompletion('last', 'help') 305 call assert_true(index(l, ':tablast') >= 0) 306 let l = getcompletion('giveup', 'help') 307 call assert_equal([], l) 308 309 let l = getcompletion('time', 'option') 310 call assert_true(index(l, 'timeoutlen') >= 0) 311 let l = getcompletion('space', 'option') 312 call assert_equal([], l) 313 314 let l = getcompletion('er', 'highlight') 315 call assert_true(index(l, 'ErrorMsg') >= 0) 316 let l = getcompletion('dark', 'highlight') 317 call assert_equal([], l) 318 319 let l = getcompletion('', 'messages') 320 call assert_true(index(l, 'clear') >= 0) 321 let l = getcompletion('not', 'messages') 322 call assert_equal([], l) 323 324 let l = getcompletion('', 'mapclear') 325 call assert_true(index(l, '<buffer>') >= 0) 326 let l = getcompletion('not', 'mapclear') 327 call assert_equal([], l) 328 329 let l = getcompletion('.', 'shellcmd') 330 call assert_equal(['./', '../'], filter(l, 'v:val =~ "\\./"')) 331 call assert_equal(-1, match(l[2:], '^\.\.\?/$')) 332 let root = has('win32') ? 'C:\\' : '/' 333 let l = getcompletion(root, 'shellcmd') 334 let expected = map(filter(glob(root . '*', 0, 1), 335 \ 'isdirectory(v:val) || executable(v:val)'), 'isdirectory(v:val) ? v:val . ''/'' : v:val') 336 call assert_equal(expected, l) 337 338 if has('cscope') 339 let l = getcompletion('', 'cscope') 340 let cmds = ['add', 'find', 'help', 'kill', 'reset', 'show'] 341 call assert_equal(cmds, l) 342 " using cmdline completion must not change the result 343 call feedkeys(":cscope find \<c-d>\<c-c>", 'xt') 344 let l = getcompletion('', 'cscope') 345 call assert_equal(cmds, l) 346 let keys = ['a', 'c', 'd', 'e', 'f', 'g', 'i', 's', 't'] 347 let l = getcompletion('find ', 'cscope') 348 call assert_equal(keys, l) 349 endif 350 351 if has('signs') 352 sign define Testing linehl=Comment 353 let l = getcompletion('', 'sign') 354 let cmds = ['define', 'jump', 'list', 'place', 'undefine', 'unplace'] 355 call assert_equal(cmds, l) 356 " using cmdline completion must not change the result 357 call feedkeys(":sign list \<c-d>\<c-c>", 'xt') 358 let l = getcompletion('', 'sign') 359 call assert_equal(cmds, l) 360 let l = getcompletion('list ', 'sign') 361 call assert_equal(['Testing'], l) 362 endif 363 364 " For others test if the name is recognized. 365 let names = ['buffer', 'environment', 'file_in_path', 'mapping', 'tag', 'tag_listfiles', 'user'] 366 if has('cmdline_hist') 367 call add(names, 'history') 368 endif 369 if has('gettext') 370 call add(names, 'locale') 371 endif 372 if has('profile') 373 call add(names, 'syntime') 374 endif 375 376 set tags=Xtags 377 call writefile(["!_TAG_FILE_ENCODING\tutf-8\t//", "word\tfile\tcmd"], 'Xtags') 378 379 for name in names 380 let matchcount = len(getcompletion('', name)) 381 call assert_true(matchcount >= 0, 'No matches for ' . name) 382 endfor 383 384 call delete('Xtags') 385 set tags& 386 387 call assert_fails('call getcompletion("", "burp")', 'E475:') 388endfunc 389 390func Test_shellcmd_completion() 391 let save_path = $PATH 392 393 call mkdir('Xpathdir/Xpathsubdir', 'p') 394 call writefile([''], 'Xpathdir/Xfile.exe') 395 call setfperm('Xpathdir/Xfile.exe', 'rwx------') 396 397 " Set PATH to example directory without trailing slash. 398 let $PATH = getcwd() . '/Xpathdir' 399 400 " Test for the ":!<TAB>" case. Previously, this would include subdirs of 401 " dirs in the PATH, even though they won't be executed. We check that only 402 " subdirs of the PWD and executables from the PATH are included in the 403 " suggestions. 404 let actual = getcompletion('X', 'shellcmd') 405 let expected = map(filter(glob('*', 0, 1), 'isdirectory(v:val) && v:val[0] == "X"'), 'v:val . "/"') 406 call insert(expected, 'Xfile.exe') 407 call assert_equal(expected, actual) 408 409 call delete('Xpathdir', 'rf') 410 let $PATH = save_path 411endfunc 412 413func Test_expand_star_star() 414 call mkdir('a/b', 'p') 415 call writefile(['asdfasdf'], 'a/b/fileXname') 416 call feedkeys(":find **/fileXname\<Tab>\<CR>", 'xt') 417 call assert_equal('find a/b/fileXname', getreg(':')) 418 bwipe! 419 call delete('a', 'rf') 420endfunc 421 422func Test_cmdline_paste() 423 let @a = "def" 424 call feedkeys(":abc \<C-R>a ghi\<C-B>\"\<CR>", 'tx') 425 call assert_equal('"abc def ghi', @:) 426 427 new 428 call setline(1, 'asdf.x /tmp/some verylongword a;b-c*d ') 429 430 call feedkeys(":aaa \<C-R>\<C-W> bbb\<C-B>\"\<CR>", 'tx') 431 call assert_equal('"aaa asdf bbb', @:) 432 433 call feedkeys("ft:aaa \<C-R>\<C-F> bbb\<C-B>\"\<CR>", 'tx') 434 call assert_equal('"aaa /tmp/some bbb', @:) 435 436 call feedkeys(":aaa \<C-R>\<C-L> bbb\<C-B>\"\<CR>", 'tx') 437 call assert_equal('"aaa '.getline(1).' bbb', @:) 438 439 set incsearch 440 call feedkeys("fy:aaa veryl\<C-R>\<C-W> bbb\<C-B>\"\<CR>", 'tx') 441 call assert_equal('"aaa verylongword bbb', @:) 442 443 call feedkeys("f;:aaa \<C-R>\<C-A> bbb\<C-B>\"\<CR>", 'tx') 444 call assert_equal('"aaa a;b-c*d bbb', @:) 445 446 call feedkeys(":\<C-\>etoupper(getline(1))\<CR>\<C-B>\"\<CR>", 'tx') 447 call assert_equal('"ASDF.X /TMP/SOME VERYLONGWORD A;B-C*D ', @:) 448 bwipe! 449 450 " Error while typing a command used to cause that it was not executed 451 " in the end. 452 new 453 try 454 call feedkeys(":file \<C-R>%Xtestfile\<CR>", 'tx') 455 catch /^Vim\%((\a\+)\)\=:E32/ 456 " ignore error E32 457 endtry 458 call assert_equal("Xtestfile", bufname("%")) 459 bwipe! 460endfunc 461 462func Test_cmdline_remove_char() 463 let encoding_save = &encoding 464 465 for e in ['utf8', 'latin1'] 466 exe 'set encoding=' . e 467 468 call feedkeys(":abc def\<S-Left>\<Del>\<C-B>\"\<CR>", 'tx') 469 call assert_equal('"abc ef', @:, e) 470 471 call feedkeys(":abc def\<S-Left>\<BS>\<C-B>\"\<CR>", 'tx') 472 call assert_equal('"abcdef', @:) 473 474 call feedkeys(":abc def ghi\<S-Left>\<C-W>\<C-B>\"\<CR>", 'tx') 475 call assert_equal('"abc ghi', @:, e) 476 477 call feedkeys(":abc def\<S-Left>\<C-U>\<C-B>\"\<CR>", 'tx') 478 call assert_equal('"def', @:, e) 479 endfor 480 481 let &encoding = encoding_save 482endfunc 483 484func Test_cmdline_keymap_ctrl_hat() 485 if !has('keymap') 486 return 487 endif 488 489 set keymap=esperanto 490 call feedkeys(":\"Jxauxdo \<C-^>Jxauxdo \<C-^>Jxauxdo\<CR>", 'tx') 491 call assert_equal('"Jxauxdo Ĵaŭdo Jxauxdo', @:) 492 set keymap= 493endfunc 494 495func Test_illegal_address1() 496 new 497 2;'( 498 2;') 499 quit 500endfunc 501 502func Test_illegal_address2() 503 call writefile(['c', 'x', ' x', '.', '1;y'], 'Xtest.vim') 504 new 505 source Xtest.vim 506 " Trigger calling validate_cursor() 507 diffsp Xtest.vim 508 quit! 509 bwipe! 510 call delete('Xtest.vim') 511endfunc 512 513func Test_cmdline_complete_wildoptions() 514 help 515 call feedkeys(":tag /\<c-a>\<c-b>\"\<cr>", 'tx') 516 let a = join(sort(split(@:)),' ') 517 set wildoptions=tagfile 518 call feedkeys(":tag /\<c-a>\<c-b>\"\<cr>", 'tx') 519 let b = join(sort(split(@:)),' ') 520 call assert_equal(a, b) 521 bw! 522endfunc 523 524func Test_cmdline_complete_user_cmd() 525 command! -complete=color -nargs=1 Foo : 526 call feedkeys(":Foo \<Tab>\<Home>\"\<cr>", 'tx') 527 call assert_equal('"Foo blue', @:) 528 call feedkeys(":Foo b\<Tab>\<Home>\"\<cr>", 'tx') 529 call assert_equal('"Foo blue', @:) 530 delcommand Foo 531endfunc 532 533func Test_cmdline_complete_user_names() 534 if has('unix') && executable('whoami') 535 let whoami = systemlist('whoami')[0] 536 let first_letter = whoami[0] 537 if len(first_letter) > 0 538 " Trying completion of :e ~x where x is the first letter of 539 " the user name should complete to at least the user name. 540 call feedkeys(':e ~' . first_letter . "\<c-a>\<c-B>\"\<cr>", 'tx') 541 call assert_match('^"e \~.*\<' . whoami . '\>', @:) 542 endif 543 endif 544 if has('win32') 545 " Just in case: check that the system has an Administrator account. 546 let names = system('net user') 547 if names =~ 'Administrator' 548 " Trying completion of :e ~A should complete to Administrator. 549 " There could be other names starting with "A" before Administrator. 550 call feedkeys(':e ~A' . "\<c-a>\<c-B>\"\<cr>", 'tx') 551 call assert_match('^"e \~.*Administrator', @:) 552 endif 553 endif 554endfunc 555 556func Test_cmdline_complete_bang() 557 if executable('whoami') 558 call feedkeys(":!whoam\<C-A>\<C-B>\"\<CR>", 'tx') 559 call assert_match('^".*\<whoami\>', @:) 560 endif 561endfunc 562 563funct Test_cmdline_complete_languages() 564 let lang = substitute(execute('language messages'), '.*"\(.*\)"$', '\1', '') 565 566 call feedkeys(":language \<c-a>\<c-b>\"\<cr>", 'tx') 567 call assert_match('^"language .*\<ctype\>.*\<messages\>.*\<time\>', @:) 568 569 if has('unix') 570 " TODO: these tests don't work on Windows. lang appears to be 'C' 571 " but C does not appear in the completion. Why? 572 call assert_match('^"language .*\<' . lang . '\>', @:) 573 574 call feedkeys(":language messages \<c-a>\<c-b>\"\<cr>", 'tx') 575 call assert_match('^"language .*\<' . lang . '\>', @:) 576 577 call feedkeys(":language ctype \<c-a>\<c-b>\"\<cr>", 'tx') 578 call assert_match('^"language .*\<' . lang . '\>', @:) 579 580 call feedkeys(":language time \<c-a>\<c-b>\"\<cr>", 'tx') 581 call assert_match('^"language .*\<' . lang . '\>', @:) 582 endif 583endfunc 584 585func Test_cmdline_complete_env_variable() 586 let $X_VIM_TEST_COMPLETE_ENV = 'foo' 587 588 call feedkeys(":edit $X_VIM_TEST_COMPLETE_E\<C-A>\<C-B>\"\<CR>", 'tx') 589 call assert_match('"edit $X_VIM_TEST_COMPLETE_ENV', @:) 590 591 unlet $X_VIM_TEST_COMPLETE_ENV 592endfunc 593 594func Test_cmdline_write_alternatefile() 595 new 596 call setline('.', ['one', 'two']) 597 f foo.txt 598 new 599 f #-A 600 call assert_equal('foo.txt-A', expand('%')) 601 f #<-B.txt 602 call assert_equal('foo-B.txt', expand('%')) 603 f %< 604 call assert_equal('foo-B', expand('%')) 605 new 606 call assert_fails('f #<', 'E95') 607 bw! 608 f foo-B.txt 609 f %<-A 610 call assert_equal('foo-B-A', expand('%')) 611 bw! 612 bw! 613endfunc 614 615" using a leading backslash here 616set cpo+=C 617 618func Test_cmdline_search_range() 619 new 620 call setline(1, ['a', 'b', 'c', 'd']) 621 /d 622 1,\/s/b/B/ 623 call assert_equal('B', getline(2)) 624 625 /a 626 $ 627 \?,4s/c/C/ 628 call assert_equal('C', getline(3)) 629 630 call setline(1, ['a', 'b', 'c', 'd']) 631 %s/c/c/ 632 1,\&s/b/B/ 633 call assert_equal('B', getline(2)) 634 635 bwipe! 636endfunc 637 638" Tests for getcmdline(), getcmdpos() and getcmdtype() 639func Check_cmdline(cmdtype) 640 call assert_equal('MyCmd a', getcmdline()) 641 call assert_equal(8, getcmdpos()) 642 call assert_equal(a:cmdtype, getcmdtype()) 643 return '' 644endfunc 645 646set cpo& 647 648func Test_getcmdtype() 649 call feedkeys(":MyCmd a\<C-R>=Check_cmdline(':')\<CR>\<Esc>", "xt") 650 651 let cmdtype = '' 652 debuggreedy 653 call feedkeys(":debug echo 'test'\<CR>", "t") 654 call feedkeys("let cmdtype = \<C-R>=string(getcmdtype())\<CR>\<CR>", "t") 655 call feedkeys("cont\<CR>", "xt") 656 0debuggreedy 657 call assert_equal('>', cmdtype) 658 659 call feedkeys("/MyCmd a\<C-R>=Check_cmdline('/')\<CR>\<Esc>", "xt") 660 call feedkeys("?MyCmd a\<C-R>=Check_cmdline('?')\<CR>\<Esc>", "xt") 661 662 call feedkeys(":call input('Answer?')\<CR>", "t") 663 call feedkeys("MyCmd a\<C-R>=Check_cmdline('@')\<CR>\<C-C>", "xt") 664 665 call feedkeys(":insert\<CR>MyCmd a\<C-R>=Check_cmdline('-')\<CR>\<Esc>", "xt") 666 667 cnoremap <expr> <F6> Check_cmdline('=') 668 call feedkeys("a\<C-R>=MyCmd a\<F6>\<Esc>\<Esc>", "xt") 669 cunmap <F6> 670endfunc 671 672func Test_getcmdwintype() 673 call feedkeys("q/:let a = getcmdwintype()\<CR>:q\<CR>", 'x!') 674 call assert_equal('/', a) 675 676 call feedkeys("q?:let a = getcmdwintype()\<CR>:q\<CR>", 'x!') 677 call assert_equal('?', a) 678 679 call feedkeys("q::let a = getcmdwintype()\<CR>:q\<CR>", 'x!') 680 call assert_equal(':', a) 681 682 call feedkeys(":\<C-F>:let a = getcmdwintype()\<CR>:q\<CR>", 'x!') 683 call assert_equal(':', a) 684 685 call assert_equal('', getcmdwintype()) 686endfunc 687 688func Test_getcmdwin_autocmd() 689 let s:seq = [] 690 augroup CmdWin 691 au WinEnter * call add(s:seq, 'WinEnter ' .. win_getid()) 692 au WinLeave * call add(s:seq, 'WinLeave ' .. win_getid()) 693 au BufEnter * call add(s:seq, 'BufEnter ' .. bufnr()) 694 au BufLeave * call add(s:seq, 'BufLeave ' .. bufnr()) 695 au CmdWinEnter * call add(s:seq, 'CmdWinEnter ' .. win_getid()) 696 au CmdWinLeave * call add(s:seq, 'CmdWinLeave ' .. win_getid()) 697 698 let org_winid = win_getid() 699 let org_bufnr = bufnr() 700 call feedkeys("q::let a = getcmdwintype()\<CR>:let s:cmd_winid = win_getid()\<CR>:let s:cmd_bufnr = bufnr()\<CR>:q\<CR>", 'x!') 701 call assert_equal(':', a) 702 call assert_equal([ 703 \ 'WinLeave ' .. org_winid, 704 \ 'WinEnter ' .. s:cmd_winid, 705 \ 'BufLeave ' .. org_bufnr, 706 \ 'BufEnter ' .. s:cmd_bufnr, 707 \ 'CmdWinEnter ' .. s:cmd_winid, 708 \ 'CmdWinLeave ' .. s:cmd_winid, 709 \ 'BufLeave ' .. s:cmd_bufnr, 710 \ 'WinLeave ' .. s:cmd_winid, 711 \ 'WinEnter ' .. org_winid, 712 \ 'BufEnter ' .. org_bufnr, 713 \ ], s:seq) 714 715 au! 716 augroup END 717endfunc 718 719func Test_verbosefile() 720 set verbosefile=Xlog 721 echomsg 'foo' 722 echomsg 'bar' 723 set verbosefile= 724 let log = readfile('Xlog') 725 call assert_match("foo\nbar", join(log, "\n")) 726 call delete('Xlog') 727endfunc 728 729func Test_verbose_option() 730 CheckScreendump 731 732 let lines =<< trim [SCRIPT] 733 command DoSomething echo 'hello' |set ts=4 |let v = '123' |echo v 734 call feedkeys("\r", 't') " for the hit-enter prompt 735 set verbose=20 736 [SCRIPT] 737 call writefile(lines, 'XTest_verbose') 738 739 let buf = RunVimInTerminal('-S XTest_verbose', {'rows': 12}) 740 call term_wait(buf, 100) 741 call term_sendkeys(buf, ":DoSomething\<CR>") 742 call VerifyScreenDump(buf, 'Test_verbose_option_1', {}) 743 744 " clean up 745 call StopVimInTerminal(buf) 746 call delete('XTest_verbose') 747endfunc 748 749func Test_setcmdpos() 750 func InsertTextAtPos(text, pos) 751 call assert_equal(0, setcmdpos(a:pos)) 752 return a:text 753 endfunc 754 755 " setcmdpos() with position in the middle of the command line. 756 call feedkeys(":\"12\<C-R>=InsertTextAtPos('a', 3)\<CR>b\<CR>", 'xt') 757 call assert_equal('"1ab2', @:) 758 759 call feedkeys(":\"12\<C-R>\<C-R>=InsertTextAtPos('a', 3)\<CR>b\<CR>", 'xt') 760 call assert_equal('"1b2a', @:) 761 762 " setcmdpos() with position beyond the end of the command line. 763 call feedkeys(":\"12\<C-B>\<C-R>=InsertTextAtPos('a', 10)\<CR>b\<CR>", 'xt') 764 call assert_equal('"12ab', @:) 765 766 " setcmdpos() returns 1 when not editing the command line. 767 call assert_equal(1, 3->setcmdpos()) 768endfunc 769 770func Test_cmdline_overstrike() 771 let encodings = ['latin1', 'utf8'] 772 let encoding_save = &encoding 773 774 for e in encodings 775 exe 'set encoding=' . e 776 777 " Test overstrike in the middle of the command line. 778 call feedkeys(":\"01234\<home>\<right>\<right>ab\<right>\<insert>cd\<enter>", 'xt') 779 call assert_equal('"0ab1cd4', @:, e) 780 781 " Test overstrike going beyond end of command line. 782 call feedkeys(":\"01234\<home>\<right>\<right>ab\<right>\<insert>cdefgh\<enter>", 'xt') 783 call assert_equal('"0ab1cdefgh', @:, e) 784 785 " Test toggling insert/overstrike a few times. 786 call feedkeys(":\"01234\<home>\<right>ab\<right>\<insert>cd\<right>\<insert>ef\<enter>", 'xt') 787 call assert_equal('"ab0cd3ef4', @:, e) 788 endfor 789 790 " Test overstrike with multi-byte characters. 791 call feedkeys(":\"テキストエディタ\<home>\<right>\<right>ab\<right>\<insert>cd\<enter>", 'xt') 792 call assert_equal('"テabキcdエディタ', @:, e) 793 794 let &encoding = encoding_save 795endfunc 796 797func Test_cmdwin_bug() 798 let winid = win_getid() 799 sp 800 try 801 call feedkeys("q::call win_gotoid(" .. winid .. ")\<CR>:q\<CR>", 'x!') 802 catch /^Vim\%((\a\+)\)\=:E11/ 803 endtry 804 bw! 805endfunc 806 807func Test_cmdwin_restore() 808 CheckScreendump 809 810 let lines =<< trim [SCRIPT] 811 call setline(1, range(30)) 812 2split 813 [SCRIPT] 814 call writefile(lines, 'XTest_restore') 815 816 let buf = RunVimInTerminal('-S XTest_restore', {'rows': 12}) 817 call term_wait(buf, 100) 818 call term_sendkeys(buf, "q:") 819 call VerifyScreenDump(buf, 'Test_cmdwin_restore_1', {}) 820 821 " normal restore 822 call term_sendkeys(buf, ":q\<CR>") 823 call VerifyScreenDump(buf, 'Test_cmdwin_restore_2', {}) 824 825 " restore after setting 'lines' with one window 826 call term_sendkeys(buf, ":close\<CR>") 827 call term_sendkeys(buf, "q:") 828 call term_sendkeys(buf, ":set lines=18\<CR>") 829 call term_sendkeys(buf, ":q\<CR>") 830 call VerifyScreenDump(buf, 'Test_cmdwin_restore_3', {}) 831 832 " clean up 833 call StopVimInTerminal(buf) 834 call delete('XTest_restore') 835endfunc 836 837func Test_buffers_lastused() 838 " check that buffers are sorted by time when wildmode has lastused 839 call test_settime(1550020000) " middle 840 edit bufa 841 enew 842 call test_settime(1550030000) " newest 843 edit bufb 844 enew 845 call test_settime(1550010000) " oldest 846 edit bufc 847 enew 848 call test_settime(0) 849 enew 850 851 call assert_equal(['bufa', 'bufb', 'bufc'], 852 \ getcompletion('', 'buffer')) 853 854 let save_wildmode = &wildmode 855 set wildmode=full:lastused 856 857 let cap = "\<c-r>=execute('let X=getcmdline()')\<cr>" 858 call feedkeys(":b \<tab>" .. cap .. "\<esc>", 'xt') 859 call assert_equal('b bufb', X) 860 call feedkeys(":b \<tab>\<tab>" .. cap .. "\<esc>", 'xt') 861 call assert_equal('b bufa', X) 862 call feedkeys(":b \<tab>\<tab>\<tab>" .. cap .. "\<esc>", 'xt') 863 call assert_equal('b bufc', X) 864 enew 865 866 edit other 867 call feedkeys(":b \<tab>" .. cap .. "\<esc>", 'xt') 868 call assert_equal('b bufb', X) 869 call feedkeys(":b \<tab>\<tab>" .. cap .. "\<esc>", 'xt') 870 call assert_equal('b bufa', X) 871 call feedkeys(":b \<tab>\<tab>\<tab>" .. cap .. "\<esc>", 'xt') 872 call assert_equal('b bufc', X) 873 enew 874 875 let &wildmode = save_wildmode 876 877 bwipeout bufa 878 bwipeout bufb 879 bwipeout bufc 880endfunc 881 882func Test_cmdwin_feedkeys() 883 " This should not generate E488 884 call feedkeys("q:\<CR>", 'x') 885endfunc 886 887" Tests for the issues fixed in 7.4.441. 888" When 'cedit' is set to Ctrl-C, opening the command window hangs Vim 889func Test_cmdwin_cedit() 890 exe "set cedit=\<C-c>" 891 normal! : 892 call assert_equal(1, winnr('$')) 893 894 let g:cmd_wintype = '' 895 func CmdWinType() 896 let g:cmd_wintype = getcmdwintype() 897 return '' 898 endfunc 899 900 call feedkeys("\<C-c>a\<C-R>=CmdWinType()\<CR>\<CR>") 901 echo input('') 902 call assert_equal('@', g:cmd_wintype) 903 904 set cedit&vim 905 delfunc CmdWinType 906endfunc 907 908" vim: shiftwidth=2 sts=2 expandtab 909