mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
Merge pull request #19886 from zeertzjq/vim-8.2.2030
vim-patch:8.2.{2030,2031}: some tests fail
This commit is contained in:
commit
d5cc161dea
@ -114,6 +114,13 @@ if has('win32')
|
||||
let $PROMPT = '$P$G'
|
||||
endif
|
||||
|
||||
if has('mac')
|
||||
" In MacOS, when starting a shell in a terminal, a bash deprecation warning
|
||||
" message is displayed. This breaks the terminal test. Disable the warning
|
||||
" message.
|
||||
let $BASH_SILENCE_DEPRECATION_WARNING = 1
|
||||
endif
|
||||
|
||||
" Prepare for calling test_garbagecollect_now().
|
||||
let v:testing = 1
|
||||
|
||||
|
@ -66,8 +66,9 @@ func Test_client_server()
|
||||
call remote_send(name, ":gui -f\<CR>")
|
||||
endif
|
||||
" Wait for the server to be up and answering requests.
|
||||
sleep 100m
|
||||
call WaitForAssert({-> assert_true(name->remote_expr("v:version", "", 1) != "")})
|
||||
" When using valgrind this can be very, very slow.
|
||||
sleep 1
|
||||
call WaitForAssert({-> assert_match('\d', name->remote_expr("v:version", "", 1))}, 10000)
|
||||
|
||||
call remote_send(name, ":let testvar = 'maybe'\<CR>")
|
||||
call WaitForAssert({-> assert_equal('maybe', remote_expr(name, "testvar", "", 2))})
|
||||
|
@ -1809,6 +1809,36 @@ func Test_read_shellcmd()
|
||||
endif
|
||||
endfunc
|
||||
|
||||
" Test for going up and down the directory tree using 'wildmenu'
|
||||
func Test_wildmenu_dirstack()
|
||||
CheckUnix
|
||||
%bw!
|
||||
call mkdir('Xdir1/dir2/dir3', 'p')
|
||||
call writefile([], 'Xdir1/file1_1.txt')
|
||||
call writefile([], 'Xdir1/file1_2.txt')
|
||||
call writefile([], 'Xdir1/dir2/file2_1.txt')
|
||||
call writefile([], 'Xdir1/dir2/file2_2.txt')
|
||||
call writefile([], 'Xdir1/dir2/dir3/file3_1.txt')
|
||||
call writefile([], 'Xdir1/dir2/dir3/file3_2.txt')
|
||||
cd Xdir1/dir2/dir3
|
||||
set wildmenu
|
||||
|
||||
call feedkeys(":e \<Tab>\<C-B>\"\<CR>", 'xt')
|
||||
call assert_equal('"e file3_1.txt', @:)
|
||||
call feedkeys(":e \<Tab>\<Up>\<C-B>\"\<CR>", 'xt')
|
||||
call assert_equal('"e ../dir3/', @:)
|
||||
call feedkeys(":e \<Tab>\<Up>\<Up>\<C-B>\"\<CR>", 'xt')
|
||||
call assert_equal('"e ../../dir2/', @:)
|
||||
call feedkeys(":e \<Tab>\<Up>\<Up>\<Down>\<C-B>\"\<CR>", 'xt')
|
||||
call assert_equal('"e ../../dir2/dir3/', @:)
|
||||
call feedkeys(":e \<Tab>\<Up>\<Up>\<Down>\<Down>\<C-B>\"\<CR>", 'xt')
|
||||
call assert_equal('"e ../../dir2/dir3/file3_1.txt', @:)
|
||||
|
||||
cd -
|
||||
call delete('Xdir1', 'rf')
|
||||
set wildmenu&
|
||||
endfunc
|
||||
|
||||
" Test for recalling newer or older cmdline from history with <Up>, <Down>,
|
||||
" <S-Up>, <S-Down>, <PageUp>, <PageDown>, <C-p>, or <C-n>.
|
||||
func Test_recalling_cmdline()
|
||||
|
@ -15,14 +15,18 @@ func CheckCWD()
|
||||
endfunc
|
||||
command! -nargs=0 -bar CheckCWD call CheckCWD()
|
||||
|
||||
" "options" argument can contain:
|
||||
" 'msec' - time to wait for a match
|
||||
" 'match' - "pattern" to use "lines" as pattern instead of text
|
||||
func CheckDbgOutput(buf, lines, options = {})
|
||||
" Verify the expected output
|
||||
let lnum = 20 - len(a:lines)
|
||||
let msec = get(a:options, 'msec', 1000)
|
||||
for l in a:lines
|
||||
if get(a:options, 'match', 'equal') ==# 'pattern'
|
||||
call WaitForAssert({-> assert_match(l, term_getline(a:buf, lnum))}, 200)
|
||||
call WaitForAssert({-> assert_match(l, term_getline(a:buf, lnum))}, msec)
|
||||
else
|
||||
call WaitForAssert({-> assert_equal(l, term_getline(a:buf, lnum))}, 200)
|
||||
call WaitForAssert({-> assert_equal(l, term_getline(a:buf, lnum))}, msec)
|
||||
endif
|
||||
let lnum += 1
|
||||
endfor
|
||||
@ -198,7 +202,7 @@ func Test_Debugger()
|
||||
|
||||
" Start a debug session, so that reading the last line from the terminal
|
||||
" works properly.
|
||||
call RunDbgCmd(buf, ':debug echo Foo()')
|
||||
call RunDbgCmd(buf, ':debug echo Foo()', ['cmd: echo Foo()'])
|
||||
|
||||
" No breakpoints
|
||||
call RunDbgCmd(buf, 'breakl', ['No breakpoints defined'])
|
||||
@ -814,9 +818,10 @@ func Test_Backtrace_CmdLine()
|
||||
\ '-S Xtest1.vim -c "debug call GlobalFunction()"',
|
||||
\ {'wait_for_ruler': 0})
|
||||
|
||||
" Need to wait for the vim-in-terminal to be ready
|
||||
" Need to wait for the vim-in-terminal to be ready.
|
||||
" With valgrind this can take quite long.
|
||||
call CheckDbgOutput(buf, ['command line',
|
||||
\ 'cmd: call GlobalFunction()'])
|
||||
\ 'cmd: call GlobalFunction()'], #{msec: 5000})
|
||||
|
||||
" At this point the ontly thing in the stack is the cmdline
|
||||
call RunDbgCmd(buf, 'backtrace', [
|
||||
@ -967,14 +972,14 @@ func Test_debug_backtrace_level()
|
||||
" set a breakpoint and source file1.vim
|
||||
let buf = RunVimInTerminal(
|
||||
\ '-c "breakadd file 1 Xtest1.vim" -S Xtest1.vim',
|
||||
\ #{ wait_for_ruler: 0 } )
|
||||
\ #{wait_for_ruler: 0})
|
||||
|
||||
call CheckDbgOutput(buf, [
|
||||
\ 'Breakpoint in "' .. file1 .. '" line 1',
|
||||
\ 'Entering Debug mode. Type "cont" to continue.',
|
||||
\ 'command line..script ' .. file1,
|
||||
\ 'line 1: let s:file1_var = ''file1'''
|
||||
\ ])
|
||||
\ ], #{msec: 5000})
|
||||
|
||||
" step through the initial declarations
|
||||
call RunDbgCmd(buf, 'step', [ 'line 2: let g:global_var = ''global''' ] )
|
||||
|
@ -774,7 +774,13 @@ func Test_shell()
|
||||
CheckUnix
|
||||
let save_shell = &shell
|
||||
set shell=
|
||||
call assert_fails('shell', 'E91:')
|
||||
let caught_e91 = 0
|
||||
try
|
||||
shell
|
||||
catch /E91:/
|
||||
let caught_e91 = 1
|
||||
endtry
|
||||
call assert_equal(1, caught_e91)
|
||||
let &shell = save_shell
|
||||
endfunc
|
||||
|
||||
|
@ -98,8 +98,6 @@ func Do_test_quotestar_for_x11()
|
||||
|
||||
" Running in a terminal and the GUI is available: Tell the server to open
|
||||
" the GUI and check that the remote command still works.
|
||||
" Need to wait for the GUI to start up, otherwise the send hangs in trying
|
||||
" to send to the terminal window.
|
||||
if has('gui_athena') || has('gui_motif')
|
||||
" For those GUIs, ignore the 'failed to create input context' error.
|
||||
call remote_send(name, ":call test_ignore_error('E285') | gui -f\<CR>")
|
||||
@ -107,7 +105,10 @@ func Do_test_quotestar_for_x11()
|
||||
call remote_send(name, ":gui -f\<CR>")
|
||||
endif
|
||||
" Wait for the server in the GUI to be up and answering requests.
|
||||
" First need to wait for the GUI to start up, otherwise the send hangs in
|
||||
" trying to send to the terminal window.
|
||||
" On some systems and with valgrind this can be very slow.
|
||||
sleep 1
|
||||
call WaitForAssert({-> assert_match("1", remote_expr(name, "has('gui_running')", "", 1))}, 10000)
|
||||
|
||||
call remote_send(name, ":let @* = 'maybe'\<CR>")
|
||||
|
Loading…
Reference in New Issue
Block a user