0
0
mirror of https://github.com/vim/vim.git synced 2025-09-24 03:44:06 -04:00

patch 8.0.0474: the client-server feature is not tested

Problem:    The client-server feature is not tested.
Solution:   Add a test.
This commit is contained in:
Bram Moolenaar
2017-03-18 16:18:37 +01:00
parent 8c34aa09a4
commit 15bf76d40b
6 changed files with 72 additions and 16 deletions

View File

@@ -2097,11 +2097,12 @@ test_arglist \
test_breakindent \ test_breakindent \
test_bufwintabinfo \ test_bufwintabinfo \
test_cdo \ test_cdo \
test_changedtick \
test_channel \ test_channel \
test_charsearch \ test_charsearch \
test_charsearch_utf8 \ test_charsearch_utf8 \
test_changedtick \
test_cindent \ test_cindent \
test_clientserver \
test_cmdline \ test_cmdline \
test_command_count \ test_command_count \
test_crypt \ test_crypt \

View File

@@ -2105,11 +2105,15 @@ Messaging_WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
str = serverConvert(client_enc, (char_u *)data->lpData, &tofree); str = serverConvert(client_enc, (char_u *)data->lpData, &tofree);
res = eval_client_expr_to_string(str); res = eval_client_expr_to_string(str);
vim_free(tofree);
if (res == NULL) if (res == NULL)
{ {
res = vim_strsave((char_u *)_(e_invexprmsg)); char *err = _(e_invexprmsg);
size_t len = STRLEN(str) + STRLEN(err) + 5;
res = alloc(len);
if (res != NULL)
vim_snprintf((char *)res, len, "%s: \"%s\"", err, str);
reply.dwData = COPYDATA_ERROR_RESULT; reply.dwData = COPYDATA_ERROR_RESULT;
} }
else else
@@ -2120,6 +2124,7 @@ Messaging_WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
serverSendEnc(sender); serverSendEnc(sender);
retval = (int)SendMessage(sender, WM_COPYDATA, retval = (int)SendMessage(sender, WM_COPYDATA,
(WPARAM)message_window, (LPARAM)(&reply)); (WPARAM)message_window, (LPARAM)(&reply));
vim_free(tofree);
vim_free(res); vim_free(res);
return retval; return retval;

View File

@@ -144,6 +144,7 @@ NEW_TESTS = test_arabic.res \
test_channel.res \ test_channel.res \
test_charsearch.res \ test_charsearch.res \
test_cindent.res \ test_cindent.res \
test_clientserver.res \
test_cmdline.res \ test_cmdline.res \
test_command_count.res \ test_command_count.res \
test_crypt.res \ test_crypt.res \

View File

@@ -164,6 +164,22 @@ func s:feedkeys(timer)
call feedkeys('x', 'nt') call feedkeys('x', 'nt')
endfunc endfunc
" Get the command to run Vim, with -u NONE and --not-a-term arguments.
" Returns an empty string on error.
func GetVimCommand()
if !filereadable('vimcmd')
return ''
endif
let cmd = readfile('vimcmd')[0]
let cmd = substitute(cmd, '-u \f\+', '-u NONE', '')
if cmd !~ '-u NONE'
let cmd = cmd . ' -u NONE'
endif
let cmd .= ' --not-a-term'
let cmd = substitute(cmd, 'VIMRUNTIME=.*VIMRUNTIME;', '', '')
return cmd
endfunc
" Run Vim, using the "vimcmd" file and "-u NORC". " Run Vim, using the "vimcmd" file and "-u NORC".
" "before" is a list of Vim commands to be executed before loading plugins. " "before" is a list of Vim commands to be executed before loading plugins.
" "after" is a list of Vim commands to be executed after loading plugins. " "after" is a list of Vim commands to be executed after loading plugins.
@@ -174,7 +190,8 @@ func RunVim(before, after, arguments)
endfunc endfunc
func RunVimPiped(before, after, arguments, pipecmd) func RunVimPiped(before, after, arguments, pipecmd)
if !filereadable('vimcmd') let cmd = GetVimCommand()
if cmd == ''
return 0 return 0
endif endif
let args = '' let args = ''
@@ -187,18 +204,6 @@ func RunVimPiped(before, after, arguments, pipecmd)
let args .= ' -S Xafter.vim' let args .= ' -S Xafter.vim'
endif endif
let cmd = readfile('vimcmd')[0]
let cmd = substitute(cmd, '-u \f\+', '-u NONE', '')
if cmd !~ '-u NONE'
let cmd = cmd . ' -u NONE'
endif
let cmd .= ' --not-a-term'
" With pipecmd we can't set VIMRUNTIME.
if a:pipecmd != ''
let cmd = substitute(cmd, 'VIMRUNTIME=.*VIMRUNTIME;', '', '')
endif
exe "silent !" . a:pipecmd . cmd . args . ' ' . a:arguments exe "silent !" . a:pipecmd . cmd . args . ' ' . a:arguments
if len(a:before) > 0 if len(a:before) > 0

View File

@@ -0,0 +1,42 @@
" Tests for the +clientserver feature.
if !has('job') || !has('clientserver')
finish
endif
source shared.vim
func Test_client_server()
let cmd = GetVimCommand()
if cmd == ''
return
endif
let name = 'XVIMTEXT'
let cmd .= ' --servername ' . name
let g:job = job_start(cmd, {'stoponexit': 'kill', 'out_io': 'null'})
call WaitFor('job_status(g:job) == "run"')
if job_status(g:job) != 'run'
call assert_true(0, 'Cannot run the Vim server')
return
endif
" Takes a short while for the server to be active.
call WaitFor('serverlist() =~ "' . name . '"')
call assert_match(name, serverlist())
call remote_foreground(name)
call remote_send(name, ":let testvar = 'yes'\<CR>")
call WaitFor('remote_expr("' . name . '", "testvar") == "yes"')
call assert_equal('yes', remote_expr(name, "testvar"))
call remote_send(name, ":qa!\<CR>")
call WaitFor('job_status(g:job) == "dead"')
if job_status(g:job) != 'dead'
call assert_true(0, 'Server did not exit')
call job_stop(g:job, 'kill')
endif
endfunc
" Uncomment this line to get a debugging log
" call ch_logfile('channellog', 'w')

View File

@@ -764,6 +764,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
474,
/**/ /**/
473, 473,
/**/ /**/