All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
2 let g:ale_lsp_next_message_id = 1
5 if exists('b:conn') && has_key(b:conn, 'id')
6 call ale#lsp#RemoveConnectionWithID(b:conn.id)
12 Execute(GetNextMessageID() should increment appropriately):
13 " We should get the initial ID, and increment a bit.
14 AssertEqual 1, ale#lsp#GetNextMessageID()
15 AssertEqual 2, ale#lsp#GetNextMessageID()
16 AssertEqual 3, ale#lsp#GetNextMessageID()
19 let g:ale_lsp_next_message_id = 9223372036854775807
21 " When we hit the maximum ID, the next ID afterwards should be 1.
22 AssertEqual 9223372036854775807, ale#lsp#GetNextMessageID()
23 AssertEqual 1, ale#lsp#GetNextMessageID()
25 Execute(ale#lsp#CreateMessageData() should create an appropriate message):
26 " NeoVim outputs JSON with spaces, so the output is a little different.
28 " 79 is the size in bytes for UTF-8, not the number of characters.
32 \ "Content-Length: 79\r\n\r\n"
33 \ . '{"method": "someMethod", "jsonrpc": "2.0", "id": 1, "params": {"foo": "barÜ"}}',
35 \ ale#lsp#CreateMessageData([0, 'someMethod', {'foo': 'barÜ'}])
36 " Check again to ensure that we use the next ID.
40 \ "Content-Length: 79\r\n\r\n"
41 \ . '{"method": "someMethod", "jsonrpc": "2.0", "id": 2, "params": {"foo": "barÜ"}}',
43 \ ale#lsp#CreateMessageData([0, 'someMethod', {'foo': 'barÜ'}])
48 \ "Content-Length: 71\r\n\r\n"
49 \ . '{"method":"someMethod","jsonrpc":"2.0","id":1,"params":{"foo":"barÜ"}}',
51 \ ale#lsp#CreateMessageData([0, 'someMethod', {'foo': 'barÜ'}])
55 \ "Content-Length: 71\r\n\r\n"
56 \ . '{"method":"someMethod","jsonrpc":"2.0","id":2,"params":{"foo":"barÜ"}}',
58 \ ale#lsp#CreateMessageData([0, 'someMethod', {'foo': 'barÜ'}])
61 Execute(ale#lsp#CreateMessageData() should create messages without params):
66 \ "Content-Length: 56\r\n\r\n"
67 \ . '{"method": "someOtherMethod", "jsonrpc": "2.0", "id": 1}',
69 \ ale#lsp#CreateMessageData([0, 'someOtherMethod'])
74 \ "Content-Length: 51\r\n\r\n"
75 \ . '{"method":"someOtherMethod","jsonrpc":"2.0","id":1}',
77 \ ale#lsp#CreateMessageData([0, 'someOtherMethod'])
80 Execute(ale#lsp#CreateMessageData() should create notifications):
85 \ "Content-Length: 48\r\n\r\n"
86 \ . '{"method": "someNotification", "jsonrpc": "2.0"}',
88 \ ale#lsp#CreateMessageData([1, 'someNotification'])
92 \ "Content-Length: 74\r\n\r\n"
93 \ . '{"method": "someNotification", "jsonrpc": "2.0", "params": {"foo": "bar"}}',
95 \ ale#lsp#CreateMessageData([1, 'someNotification', {'foo': 'bar'}])
100 \ "Content-Length: 45\r\n\r\n"
101 \ . '{"method":"someNotification","jsonrpc":"2.0"}',
103 \ ale#lsp#CreateMessageData([1, 'someNotification'])
107 \ "Content-Length: 68\r\n\r\n"
108 \ . '{"method":"someNotification","jsonrpc":"2.0","params":{"foo":"bar"}}',
110 \ ale#lsp#CreateMessageData([1, 'someNotification', {'foo': 'bar'}])
113 Execute(ale#lsp#CreateMessageData() should create tsserver notification messages):
118 \ '{"seq": null, "type": "request", "command": "someNotification"}'
121 \ ale#lsp#CreateMessageData([1, 'ts@someNotification'])
125 \ '{"seq": null, "arguments": {"foo": "bar"}, "type": "request", "command": "someNotification"}'
128 \ ale#lsp#CreateMessageData([1, 'ts@someNotification', {'foo': 'bar'}])
133 \ '{"seq":null,"type":"request","command":"someNotification"}'
136 \ ale#lsp#CreateMessageData([1, 'ts@someNotification'])
140 \ '{"seq":null,"arguments":{"foo":"bar"},"type":"request","command":"someNotification"}'
143 \ ale#lsp#CreateMessageData([1, 'ts@someNotification', {'foo': 'bar'}])
146 Execute(ale#lsp#CreateMessageData() should create tsserver messages expecting responses):
151 \ '{"seq": 1, "type": "request", "command": "someMessage"}'
154 \ ale#lsp#CreateMessageData([0, 'ts@someMessage'])
158 \ '{"seq": 2, "arguments": {"foo": "bar"}, "type": "request", "command": "someMessage"}'
161 \ ale#lsp#CreateMessageData([0, 'ts@someMessage', {'foo': 'bar'}])
166 \ '{"seq":1,"type":"request","command":"someMessage"}'
169 \ ale#lsp#CreateMessageData([0, 'ts@someMessage'])
173 \ '{"seq":2,"arguments":{"foo":"bar"},"type":"request","command":"someMessage"}'
176 \ ale#lsp#CreateMessageData([0, 'ts@someMessage', {'foo': 'bar'}])
179 Execute(ale#lsp#ReadMessageData() should read single whole messages):
181 \ ['', [{'id': 2, 'jsonrpc': '2.0', 'result': {'foo': 'barÜ'}}]],
182 \ ale#lsp#ReadMessageData(
183 \ "Content-Length: 49\r\n\r\n"
184 \ . '{"id":2,"jsonrpc":"2.0","result":{"foo":"barÜ"}}'
187 Execute(ale#lsp#ReadMessageData() should ignore other headers):
189 \ ['', [{'id': 2, 'jsonrpc': '2.0', 'result': {'foo': 'barÜ'}}]],
190 \ ale#lsp#ReadMessageData(
191 \ "First-Header: 49\r\n"
192 \ . "Content-Length: 49\r\n"
193 \ . "Other-Header: 49\r\n"
195 \ . '{"id":2,"jsonrpc":"2.0","result":{"foo":"barÜ"}}'
198 Execute(ale#lsp#ReadMessageData() should handle partial messages):
199 let b:data = "Content-Length: 49\r\n\r\n" . '{"id":2,"jsonrpc":"2.0","result":'
201 AssertEqual [b:data, []], ale#lsp#ReadMessageData(b:data)
203 Execute(ale#lsp#ReadMessageData() should handle multiple messages):
206 \ {'id': 2, 'jsonrpc': '2.0', 'result': {'foo': 'barÜ'}},
207 \ {'id': 2, 'jsonrpc': '2.0', 'result': {'foo123': 'barÜ'}},
209 \ ale#lsp#ReadMessageData(
210 \ "Content-Length: 49\r\n\r\n"
211 \ . '{"id":2,"jsonrpc":"2.0","result":{"foo":"barÜ"}}'
212 \ . "Content-Length: 52\r\n\r\n"
213 \ . '{"id":2,"jsonrpc":"2.0","result":{"foo123":"barÜ"}}'
216 Execute(ale#lsp#ReadMessageData() should handle a message with part of a second message):
217 let b:data = "Content-Length: 52\r\n\r\n" . '{"id":2,"jsonrpc":"2.'
221 \ {'id': 2, 'jsonrpc': '2.0', 'result': {'foo': 'barÜ'}},
223 \ ale#lsp#ReadMessageData(
224 \ "Content-Length: 49\r\n\r\n"
225 \ . '{"id":2,"jsonrpc":"2.0","result":{"foo":"barÜ"}}'