Skip to content

Commit f615728

Browse files
committed
patch 7.4.1299
Problem: When the server sends a message with ID zero the channel handler is not invoked. (Christian J. Robinson) Solution: Recognize zero value for the request ID. Add a test for invoking the channel handler.
1 parent d6a8d48 commit f615728

4 files changed

Lines changed: 48 additions & 3 deletions

File tree

src/channel.c

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -786,6 +786,7 @@ channel_get_json(int ch_idx, int id, typval_T **rettv)
786786

787787
if ((id > 0 && tv->v_type == VAR_NUMBER && tv->vval.v_number == id)
788788
|| (id <= 0 && (tv->v_type != VAR_NUMBER
789+
|| tv->vval.v_number == 0
789790
|| tv->vval.v_number != channel->ch_block_id)))
790791
{
791792
*rettv = item->value;

src/testdir/test_channel.py

Lines changed: 16 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -130,6 +130,16 @@ def handle(self):
130130
elif decoded[1] == 'eval-result':
131131
# Send back the last received eval result.
132132
response = last_eval
133+
elif decoded[1] == 'call me':
134+
cmd = '[0,"we called you"]'
135+
print("sending: {}".format(cmd))
136+
self.request.sendall(cmd.encode('utf-8'))
137+
response = "ok"
138+
elif decoded[1] == 'call me again':
139+
cmd = '[0,"we did call you"]'
140+
print("sending: {}".format(cmd))
141+
self.request.sendall(cmd.encode('utf-8'))
142+
response = ""
133143
elif decoded[1] == '!quit!':
134144
# we're done
135145
self.server.shutdown()
@@ -140,9 +150,12 @@ def handle(self):
140150
else:
141151
response = "what?"
142152

143-
encoded = json.dumps([decoded[0], response])
144-
print("sending: {}".format(encoded))
145-
self.request.sendall(encoded.encode('utf-8'))
153+
if response == "":
154+
print("no response")
155+
else:
156+
encoded = json.dumps([decoded[0], response])
157+
print("sending: {}".format(encoded))
158+
self.request.sendall(encoded.encode('utf-8'))
146159

147160
# Negative numbers are used for "eval" responses.
148161
elif decoded[0] < 0:

src/testdir/test_channel.vim

Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -204,6 +204,35 @@ func Test_server_crash()
204204
call s:run_server('s:server_crash')
205205
endfunc
206206

207+
let s:reply = ""
208+
func s:Handler(chan, msg)
209+
let s:reply = a:msg
210+
endfunc
211+
212+
func s:channel_handler(port)
213+
let chopt = copy(s:chopt)
214+
let chopt['callback'] = 's:Handler'
215+
let handle = ch_open('localhost:' . a:port, chopt)
216+
if handle < 0
217+
call assert_false(1, "Can't open channel")
218+
return
219+
endif
220+
221+
" Test that it works while waiting on a numbered message.
222+
call assert_equal('ok', ch_sendexpr(handle, 'call me'))
223+
sleep 10m
224+
call assert_equal('we called you', s:reply)
225+
226+
" Test that it works while not waiting on a numbered message.
227+
call ch_sendexpr(handle, 'call me again', 0)
228+
sleep 10m
229+
call assert_equal('we did call you', s:reply)
230+
endfunc
231+
232+
func Test_channel_handler()
233+
call s:run_server('s:channel_handler')
234+
endfunc
235+
207236
" Test that trying to connect to a non-existing port fails quickly.
208237
func Test_connect_waittime()
209238
let start = reltime()

src/version.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -747,6 +747,8 @@ static char *(features[]) =
747747

748748
static int included_patches[] =
749749
{ /* Add new patch number below this line */
750+
/**/
751+
1299,
750752
/**/
751753
1298,
752754
/**/

0 commit comments

Comments
 (0)