Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 1 | " Tests for the +clientserver feature. |
| 2 | |
| 3 | if !has('job') || !has('clientserver') |
| 4 | finish |
| 5 | endif |
| 6 | |
| 7 | source shared.vim |
| 8 | |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 9 | let s:where = 0 |
| 10 | func Abort(id) |
| 11 | call assert_report('Test timed out at ' . s:where) |
| 12 | call FinishTesting() |
| 13 | endfunc |
| 14 | |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 15 | func Test_client_server() |
| 16 | let cmd = GetVimCommand() |
| 17 | if cmd == '' |
| 18 | return |
| 19 | endif |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 20 | |
| 21 | " Some of these commands may hang when failing. |
| 22 | call timer_start(10000, 'Abort') |
| 23 | |
| 24 | let s:where = 1 |
| 25 | let name = 'XVIMTEST' |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 26 | let cmd .= ' --servername ' . name |
| 27 | let g:job = job_start(cmd, {'stoponexit': 'kill', 'out_io': 'null'}) |
| 28 | call WaitFor('job_status(g:job) == "run"') |
| 29 | if job_status(g:job) != 'run' |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 30 | call assert_report('Cannot run the Vim server') |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 31 | return |
| 32 | endif |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 33 | let s:where = 2 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 34 | |
| 35 | " Takes a short while for the server to be active. |
| 36 | call WaitFor('serverlist() =~ "' . name . '"') |
| 37 | call assert_match(name, serverlist()) |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 38 | let s:where = 3 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 39 | |
| 40 | call remote_foreground(name) |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 41 | let s:where = 4 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 42 | |
| 43 | call remote_send(name, ":let testvar = 'yes'\<CR>") |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 44 | let s:where = 5 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 45 | call WaitFor('remote_expr("' . name . '", "testvar") == "yes"') |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 46 | let s:where = 6 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 47 | call assert_equal('yes', remote_expr(name, "testvar")) |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 48 | let s:where = 7 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 49 | |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 50 | if has('unix') && has('gui') && !has('gui_running') |
| 51 | " Running in a terminal and the GUI is avaiable: Tell the server to open |
| 52 | " the GUI and check that the remote command still works. |
| 53 | " Need to wait for the GUI to start up, otherwise the send hangs in trying |
| 54 | " to send to the terminal window. |
| 55 | call remote_send(name, ":gui -f\<CR>") |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 56 | let s:where = 8 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 57 | sleep 500m |
| 58 | call remote_send(name, ":let testvar = 'maybe'\<CR>") |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 59 | let s:where = 9 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 60 | call WaitFor('remote_expr("' . name . '", "testvar") == "maybe"') |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 61 | let s:where = 10 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 62 | call assert_equal('maybe', remote_expr(name, "testvar")) |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 63 | let s:where = 11 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 64 | endif |
| 65 | |
| 66 | call assert_fails('call remote_send("XXX", ":let testvar = ''yes''\<CR>")', 'E241') |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 67 | let s:where = 12 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 68 | |
| 69 | " Expression evaluated locally. |
| 70 | if v:servername == '' |
| 71 | call remote_startserver('MYSELF') |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 72 | let s:where = 13 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 73 | call assert_equal('MYSELF', v:servername) |
| 74 | endif |
| 75 | let g:testvar = 'myself' |
| 76 | call assert_equal('myself', remote_expr(v:servername, 'testvar')) |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 77 | let s:where = 14 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 78 | |
| 79 | call remote_send(name, ":call server2client(expand('<client>'), 'got it')\<CR>", 'g:myserverid') |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 80 | let s:where = 15 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 81 | call assert_equal('got it', remote_read(g:myserverid)) |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 82 | let s:where = 16 |
Bram Moolenaar | 7416f3e | 2017-03-18 18:10:13 +0100 | [diff] [blame] | 83 | |
Bram Moolenaar | 6caf606 | 2017-03-18 20:45:05 +0100 | [diff] [blame] | 84 | call remote_send(name, ":call server2client(expand('<client>'), 'another')\<CR>", 'g:myserverid') |
| 85 | let s:where = 151 |
| 86 | let peek_result = 'nothing' |
| 87 | let r = remote_peek(g:myserverid, 'peek_result') |
| 88 | let s:where = 161 |
| 89 | " unpredictable whether the result is already avaialble. |
| 90 | if r > 0 |
| 91 | call assert_equal('another', peek_result) |
| 92 | elseif r == 0 |
| 93 | call assert_equal('nothing', peek_result) |
| 94 | else |
| 95 | call assert_report('remote_peek() failed') |
| 96 | endif |
| 97 | let g:peek_result = 'empty' |
| 98 | call WaitFor('remote_peek(g:myserverid, "g:peek_result") > 0') |
| 99 | let s:where = 171 |
| 100 | call assert_equal('another', g:peek_result) |
| 101 | let s:where = 181 |
| 102 | call assert_equal('another', remote_read(g:myserverid)) |
| 103 | let s:where = 191 |
| 104 | |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 105 | call remote_send(name, ":qa!\<CR>") |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 106 | let s:where = 17 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 107 | call WaitFor('job_status(g:job) == "dead"') |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 108 | let s:where = 18 |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 109 | if job_status(g:job) != 'dead' |
Bram Moolenaar | 4220555 | 2017-03-18 19:42:22 +0100 | [diff] [blame] | 110 | call assert_report('Server did not exit') |
Bram Moolenaar | 15bf76d | 2017-03-18 16:18:37 +0100 | [diff] [blame] | 111 | call job_stop(g:job, 'kill') |
| 112 | endif |
| 113 | endfunc |
| 114 | |
| 115 | " Uncomment this line to get a debugging log |
| 116 | " call ch_logfile('channellog', 'w') |