blob: e458e38961b7336903b25910d6efea113b29e8cd [file] [log] [blame]
Bram Moolenaar321efdd2016-07-15 17:09:11 +02001" Test the netbeans interface.
2
Bram Moolenaarb46fecd2019-06-15 17:58:09 +02003source check.vim
4CheckFeature netbeans_intg
Bram Moolenaar321efdd2016-07-15 17:09:11 +02005
6source shared.vim
7
8let s:python = PythonProg()
9if s:python == ''
Bram Moolenaarb46fecd2019-06-15 17:58:09 +020010 throw 'Skipped: python program missing'
Bram Moolenaar321efdd2016-07-15 17:09:11 +020011endif
12
Bram Moolenaar4b96df52020-01-26 22:00:26 +010013" Run "testfunc" after starting the server and stop the server afterwards.
Bram Moolenaar321efdd2016-07-15 17:09:11 +020014func s:run_server(testfunc, ...)
15 call RunServer('test_netbeans.py', a:testfunc, a:000)
16endfunc
17
Bram Moolenaar173d8412020-04-19 14:02:26 +020018" Wait for an exception (error) to be thrown. This is used to check whether a
19" message from the netbeans server causes an error. It takes some time for Vim
20" to process a netbeans message. So a sleep is used below to account for this.
21func WaitForError(errcode)
22 let save_exception = ''
23 for i in range(200)
24 try
25 sleep 5m
26 catch
27 let save_exception = v:exception
28 break
29 endtry
30 endfor
31 call assert_match(a:errcode, save_exception)
32endfunc
33
Bram Moolenaar95650152020-07-19 18:24:32 +020034" Read the "Xnetbeans" file and filter out geometry messages.
35func ReadXnetbeans()
36 let l = readfile("Xnetbeans")
Bram Moolenaar32e5ec02020-11-06 13:44:21 +010037 " Xnetbeans may include '0:geometry=' messages in the GUI Vim if the window
Bram Moolenaar95650152020-07-19 18:24:32 +020038 " position, size, or z order are changed. Remove these messages because
Bram Moolenaar50dc3ec2020-11-16 18:39:43 +010039 " these messages will break the assert for the output.
Bram Moolenaar95650152020-07-19 18:24:32 +020040 return filter(l, 'v:val !~ "^0:geometry="')
41endfunc
42
Bram Moolenaar321efdd2016-07-15 17:09:11 +020043func Nb_basic(port)
Bram Moolenaarb152b6a2022-09-29 21:37:33 +010044 call writefile([], "Xnetbeans", 'D')
Bram Moolenaar173d8412020-04-19 14:02:26 +020045
46 " Last line number in the Xnetbeans file. Used to verify the result of the
47 " communication with the netbeans server
48 let g:last = 0
49
50 " Establish the connection with the netbeans server
51 exe 'nbstart :localhost:' .. a:port .. ':bunny'
Bram Moolenaar321efdd2016-07-15 17:09:11 +020052 call assert_true(has("netbeans_enabled"))
Bram Moolenaar95650152020-07-19 18:24:32 +020053 call WaitFor('len(ReadXnetbeans()) > (g:last + 2)')
54 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +020055 call assert_equal(['AUTH bunny',
56 \ '0:version=0 "2.5"',
57 \ '0:startupDone=0'], l[-3:])
58 let g:last += 3
Bram Moolenaar321efdd2016-07-15 17:09:11 +020059
Bram Moolenaar173d8412020-04-19 14:02:26 +020060 " Trying to connect again to netbeans server should fail
61 call assert_fails("exe 'nbstart :localhost:' . a:port . ':bunny'", 'E511:')
Bram Moolenaar321efdd2016-07-15 17:09:11 +020062
Bram Moolenaar173d8412020-04-19 14:02:26 +020063 " Open the command buffer to communicate with the server
64 split Xcmdbuf
65 let cmdbufnr = bufnr()
Bram Moolenaar95650152020-07-19 18:24:32 +020066 call WaitFor('len(ReadXnetbeans()) > (g:last + 2)')
67 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +020068 call assert_equal('0:fileOpened=0 "Xcmdbuf" T F',
69 \ substitute(l[-3], '".*/', '"', ''))
70 call assert_equal('send: 1:putBufferNumber!15 "Xcmdbuf"',
71 \ substitute(l[-2], '".*/', '"', ''))
72 call assert_equal('1:startDocumentListen!16', l[-1])
73 let g:last += 3
Bram Moolenaar321efdd2016-07-15 17:09:11 +020074
Bram Moolenaar173d8412020-04-19 14:02:26 +020075 " Keep the command buffer loaded for communication
76 hide
77
78 sleep 1m
79
80 " getCursor test
Bram Moolenaarb152b6a2022-09-29 21:37:33 +010081 call writefile(['foo bar', 'foo bar', 'foo bar'], 'Xfile1', 'D')
Bram Moolenaar173d8412020-04-19 14:02:26 +020082 split Xfile1
83 call cursor(3, 4)
84 sleep 10m
85 call appendbufline(cmdbufnr, '$', 'getCursor_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +020086 call WaitFor('len(ReadXnetbeans()) >= (g:last + 5)')
87 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +020088 call assert_equal(['send: 0:getCursor/30', '30 -1 3 3 19'], l[-2:])
89 let g:last += 5
90
91 " Test for E627
92 call appendbufline(cmdbufnr, '$', 'E627_Test')
93 call WaitForError('E627:')
Bram Moolenaar95650152020-07-19 18:24:32 +020094 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
95 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +020096 call assert_equal('send: 0 setReadOnly!31', l[-1])
97 let g:last += 3
98
99 " Test for E628
100 call appendbufline(cmdbufnr, '$', 'E628_Test')
101 call WaitForError('E628:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200102 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
103 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200104 call assert_equal('send: 0:setReadOnly 32', l[-1])
105 let g:last += 3
106
107 " Test for E632
108 call appendbufline(cmdbufnr, '$', 'E632_Test')
109 call WaitForError('E632:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200110 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
111 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200112 call assert_equal(['send: 0:getLength/33', '33 0'], l[-2:])
113 let g:last += 4
114
115 " Test for E633
116 call appendbufline(cmdbufnr, '$', 'E633_Test')
117 call WaitForError('E633:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200118 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
119 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200120 call assert_equal(['send: 0:getText/34', '34 '], l[-2:])
121 let g:last += 4
122
123 " Test for E634
124 call appendbufline(cmdbufnr, '$', 'E634_Test')
125 call WaitForError('E634:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200126 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
127 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200128 call assert_equal(['send: 0:remove/35 1 1', '35'], l[-2:])
129 let g:last += 4
130
131 " Test for E635
132 call appendbufline(cmdbufnr, '$', 'E635_Test')
133 call WaitForError('E635:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200134 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
135 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200136 call assert_equal(['send: 0:insert/36 0 "line1\n"', '36'], l[-2:])
137 let g:last += 4
138
139 " Test for E636
140 call appendbufline(cmdbufnr, '$', 'E636_Test')
141 call WaitForError('E636:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200142 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
143 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200144 call assert_equal('send: 0:create!37', l[-1])
145 let g:last += 3
146
147 " Test for E637
148 call appendbufline(cmdbufnr, '$', 'E637_Test')
149 call WaitForError('E637:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200150 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
151 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200152 call assert_equal('send: 0:startDocumentListen!38', l[-1])
153 let g:last += 3
154
155 " Test for E638
156 call appendbufline(cmdbufnr, '$', 'E638_Test')
157 call WaitForError('E638:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200158 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
159 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200160 call assert_equal('send: 0:stopDocumentListen!39', l[-1])
161 let g:last += 3
162
163 " Test for E639
164 call appendbufline(cmdbufnr, '$', 'E639_Test')
165 call WaitForError('E639:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200166 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
167 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200168 call assert_equal('send: 0:setTitle!40 "Title"', l[-1])
169 let g:last += 3
170
171 " Test for E640
172 call appendbufline(cmdbufnr, '$', 'E640_Test')
173 call WaitForError('E640:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200174 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
175 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200176 call assert_equal('send: 0:initDone!41', l[-1])
177 let g:last += 3
178
179 " Test for E641
180 call appendbufline(cmdbufnr, '$', 'E641_Test')
181 call WaitForError('E641:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200182 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
183 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200184 call assert_equal('send: 0:putBufferNumber!42 "XSomeBuf"', l[-1])
185 let g:last += 3
186
187 " Test for E642
188 call appendbufline(cmdbufnr, '$', 'E642_Test')
189 call WaitForError('E642:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200190 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
191 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200192 call assert_equal('send: 9:putBufferNumber!43 "XInvalidBuf"', l[-1])
193 let g:last += 3
194
195 " Test for E643
196 call appendbufline(cmdbufnr, '$', 'E643_Test')
197 call WaitForError('E643:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200198 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
199 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200200 call assert_equal('send: 0:setFullName!44 "XSomeBuf"', l[-1])
201 let g:last += 3
202
203 enew!
204
205 " Test for E644
206 call appendbufline(cmdbufnr, '$', 'E644_Test')
207 call WaitForError('E644:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200208 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
209 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200210 call assert_equal('send: 0:editFile!45 "Xfile3"', l[-1])
211 let g:last += 3
212
213 " Test for E645 (shown only when verbose > 0)
214 call appendbufline(cmdbufnr, '$', 'E645_Test')
215 set verbose=1
216 call WaitForError('E645:')
217 set verbose&
Bram Moolenaar95650152020-07-19 18:24:32 +0200218 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
219 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200220 call assert_equal('send: 0:setVisible!46 T', l[-1])
221 let g:last += 3
222
223 " Test for E646 (shown only when verbose > 0)
224 call appendbufline(cmdbufnr, '$', 'E646_Test')
225 set verbose=1
226 call WaitForError('E646:')
227 set verbose&
Bram Moolenaar95650152020-07-19 18:24:32 +0200228 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
229 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200230 call assert_equal('send: 0:setModified!47 T', l[-1])
231 let g:last += 3
232
233 " Test for E647
234 call appendbufline(cmdbufnr, '$', 'E647_Test')
235 call WaitForError('E647:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200236 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
237 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200238 call assert_equal('send: 0:setDot!48 1/1', l[-1])
239 let g:last += 3
240
241 " Test for E648
242 call appendbufline(cmdbufnr, '$', 'E648_Test')
243 call WaitForError('E648:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200244 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
245 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200246 call assert_equal('send: 0:close!49', l[-1])
247 let g:last += 3
248
249 " Test for E650
250 call appendbufline(cmdbufnr, '$', 'E650_Test')
251 call WaitForError('E650:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200252 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
253 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200254 call assert_equal('send: 0:defineAnnoType!50 1 "abc" "a" "a" 1 1', l[-1])
255 let g:last += 3
256
257 " Test for E651
258 call appendbufline(cmdbufnr, '$', 'E651_Test')
259 call WaitForError('E651:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200260 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
261 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200262 call assert_equal('send: 0:addAnno!51 1 1 1 1', l[-1])
263 let g:last += 3
264
265 " Test for E652
266 call appendbufline(cmdbufnr, '$', 'E652_Test')
267 call WaitForError('E652:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200268 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
269 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200270 call assert_equal(['send: 0:getAnno/52 8', '52 0'], l[-2:])
271 let g:last += 4
272
273 " editFile test
Bram Moolenaarb152b6a2022-09-29 21:37:33 +0100274 call writefile(['foo bar1', 'foo bar2', 'foo bar3'], 'Xfile3', 'D')
Bram Moolenaar173d8412020-04-19 14:02:26 +0200275 call appendbufline(cmdbufnr, '$', 'editFile_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200276 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
277 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200278 call assert_equal('send: 2:editFile!53 "Xfile3"', l[-2])
279 call assert_match('0:fileOpened=0 ".*/Xfile3" T F', l[-1])
280 call assert_equal('Xfile3', bufname())
281 let g:last += 4
282
283 " getLength test
284 call appendbufline(cmdbufnr, '$', 'getLength_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200285 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
286 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200287 call assert_equal(['send: 2:getLength/54', '54 27'], l[-2:])
288 let g:last += 4
289
290 " getModified test
291 call appendbufline(cmdbufnr, '$', 'getModified_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200292 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
293 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200294 call assert_equal(['send: 2:getModified/55', '55 0'], l[-2:])
295 let g:last += 4
296
297 " getText test
298 call appendbufline(cmdbufnr, '$', 'getText_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200299 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
300 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200301 call assert_equal(['send: 2:getText/56',
302 \ '56 "foo bar1\nfoo bar2\nfoo bar3\n"'], l[-2:])
303 let g:last += 4
304
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100305 " setDot test with lnum/col
306 call cursor(1, 1)
Bram Moolenaar173d8412020-04-19 14:02:26 +0200307 call appendbufline(cmdbufnr, '$', 'setDot_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200308 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
309 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200310 call assert_equal('send: 2:setDot!57 3/6', l[-1])
Bram Moolenaar6fd3a4b2020-11-03 11:53:29 +0100311 sleep 10m
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100312 call assert_equal([0, 3, 7, 0], getpos('.'))
313 let g:last += 3
314
315 " setDot test with an offset
316 call cursor(1, 1)
317 call appendbufline(cmdbufnr, '$', 'setDot2_Test')
318 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
319 let l = ReadXnetbeans()
320 call assert_equal('send: 2:setDot!57 9', l[-1])
Bram Moolenaar6fd3a4b2020-11-03 11:53:29 +0100321 sleep 10m
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100322 call assert_equal([0, 2, 1, 0], getpos('.'))
Bram Moolenaar173d8412020-04-19 14:02:26 +0200323 let g:last += 3
324
325 " startDocumentListen test
326 call appendbufline(cmdbufnr, '$', 'startDocumentListen_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200327 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
328 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200329 call assert_equal('send: 2:startDocumentListen!58', l[-1])
330 let g:last += 3
331
332 " make some changes to the buffer and check whether the netbeans server
333 " received the notifications
334 call append(2, 'blue sky')
335 1d
Bram Moolenaar95650152020-07-19 18:24:32 +0200336 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
337 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200338 call assert_match('2:insert=\d\+ 18 "blue sky"', l[-3])
339 call assert_match('2:insert=\d\+ 26 "\\n"', l[-2])
340 call assert_match('2:remove=\d\+ 0 9', l[-1])
341 let g:last += 3
342
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100343 " Change case using the ~ command with 'whichwrap' containing '~'
344 set whichwrap+=~
345 normal 2G$~
346 set whichwrap&
347 call WaitFor('len(ReadXnetbeans()) >= (g:last + 2)')
348 let l = ReadXnetbeans()
349 call assert_match('2:remove=\d\+ 16 1', l[-4])
350 call assert_match('2:insert=\d\+ 16 "Y"', l[-3])
351 call assert_match('2:remove=\d\+ 18 0', l[-2])
352 call assert_match('2:insert=\d\+ 18 ""', l[-1])
353 let g:last += 4
354
355 " Test for replacing spaces with a tab character using 'softtabstop' and
356 " 'noexpandtab'
357 setlocal softtabstop=4
358 setlocal noexpandtab
359 exe "normal I\<Tab>\<Tab>"
360 setlocal expandtab&
361 setlocal softtabstop&
362 call WaitFor('len(ReadXnetbeans()) >= (g:last + 18)')
363 let l = ReadXnetbeans()
364 call assert_match('2:insert=\d\+ 18 " foo bar3"', l[-3])
365 call assert_match('2:remove=\d\+ 26 8', l[-2])
366 call assert_match('2:insert=\d\+ 26 "\t"', l[-1])
367 let g:last += 18
368
Yegappan Lakshmanan2ac71842021-05-31 19:23:01 +0200369 " Test for changing case of multiple lines using ~
370 normal ggVG~
371 call WaitFor('len(ReadXnetbeans()) >= (g:last + 6)')
372 let l = ReadXnetbeans()
373 call assert_match('2:remove=\d\+ 0 8', l[-6])
374 call assert_match('2:insert=\d\+ 0 "FOO BAR2"', l[-5])
375 call assert_match('2:remove=\d\+ 9 8', l[-4])
376 call assert_match('2:insert=\d\+ 9 "BLUE SKy"', l[-3])
377 call assert_match('2:remove=\d\+ 18 9', l[-2])
378 call assert_match('2:insert=\d\+ 18 "\tFOO BAR3"', l[-1])
379 let g:last += 6
380
381 " Test for changing case of a visual block using ~
382 exe "normal ggw\<C-V>$~"
383 call WaitFor('len(ReadXnetbeans()) >= (g:last + 2)')
384 let l = ReadXnetbeans()
385 call assert_match('2:remove=\d\+ 4 4', l[-2])
386 call assert_match('2:insert=\d\+ 4 "bar2"', l[-1])
387 let g:last += 2
388
389 " Increment a number using <C-A> in visual mode
390 exe "normal! gg$v6\<C-A>"
391 call WaitFor('len(ReadXnetbeans()) >= (g:last + 6)')
392 let l = ReadXnetbeans()
393 call assert_match('2:remove=\d\+ 0 9', l[-4])
394 call assert_match('2:insert=\d\+ 0 "FOO bar8"', l[-3])
395 call assert_match('2:remove=\d\+ 7 1', l[-2])
396 call assert_match('2:insert=\d\+ 7 "8"', l[-1])
397 let g:last += 6
398
399 " Decrement a number using <C-X> in visual mode
400 exe "normal! gg$v3\<C-X>"
401 call WaitFor('len(ReadXnetbeans()) >= (g:last + 6)')
402 let l = ReadXnetbeans()
403 call assert_match('2:remove=\d\+ 0 9', l[-4])
404 call assert_match('2:insert=\d\+ 0 "FOO bar5"', l[-3])
405 call assert_match('2:remove=\d\+ 7 1', l[-2])
406 call assert_match('2:insert=\d\+ 7 "5"', l[-1])
407 let g:last += 6
408
Bram Moolenaar173d8412020-04-19 14:02:26 +0200409 " stopDocumentListen test
410 call appendbufline(cmdbufnr, '$', 'stopDocumentListen_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200411 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
412 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200413 call assert_equal('send: 2:stopDocumentListen!59', l[-1])
414 let g:last += 3
415
416 " Wait for vim to process the previous netbeans message
417 sleep 1m
418
419 " modify the buffer and make sure that the netbeans server is not notified
420 call append(2, 'clear sky')
421 1d
422
423 " defineAnnoType test
424 call appendbufline(cmdbufnr, '$', 'define_anno_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200425 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
426 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200427 call assert_equal('send: 2:defineAnnoType!60 1 "s1" "x" "=>" blue none', l[-1])
428 sleep 1m
Bram Moolenaar37d1b4f2020-05-13 17:16:04 +0200429 call assert_equal({'name': '1', 'texthl': 'NB_s1', 'text': '=>'},
Bram Moolenaar32e5ec02020-11-06 13:44:21 +0100430 \ sign_getdefined()->get(0, {}))
Bram Moolenaar173d8412020-04-19 14:02:26 +0200431 let g:last += 3
432
433 " defineAnnoType with a long color name
434 call appendbufline(cmdbufnr, '$', 'E532_Test')
435 call WaitForError('E532:')
Bram Moolenaar95650152020-07-19 18:24:32 +0200436 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
437 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200438 call assert_equal('send: 2:defineAnnoType!61 1 "s1" "x" "=>" aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa none', l[-1])
439 let g:last += 3
440
441 " addAnno test
442 call appendbufline(cmdbufnr, '$', 'add_anno_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200443 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
444 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200445 call assert_equal('send: 2:addAnno!62 1 1 2/1 0', l[-1])
446 sleep 1m
447 call assert_equal([{'lnum': 2, 'id': 1, 'name': '1', 'priority': 10,
448 \ 'group': ''}], sign_getplaced()[0].signs)
449 let g:last += 3
450
451 " getAnno test
452 call appendbufline(cmdbufnr, '$', 'get_anno_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200453 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
454 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200455 call assert_equal(['send: 2:getAnno/63 1', '63 2'], l[-2:])
456 let g:last += 4
457
458 " removeAnno test
459 call appendbufline(cmdbufnr, '$', 'remove_anno_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200460 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
461 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200462 call assert_equal('send: 2:removeAnno!64 1', l[-1])
463 sleep 1m
464 call assert_equal([], sign_getplaced())
465 let g:last += 3
466
467 " getModified test to get the number of modified buffers
468 call appendbufline(cmdbufnr, '$', 'getModifiedAll_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200469 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
470 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200471 call assert_equal(['send: 0:getModified/65', '65 2'], l[-2:])
472 let g:last += 4
473
474 let bufcount = len(getbufinfo())
475
476 " create test to create a new buffer
477 call appendbufline(cmdbufnr, '$', 'create_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200478 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
479 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200480 call assert_equal('send: 3:create!66', l[-1])
481 " Wait for vim to process the previous netbeans message
482 sleep 10m
483 call assert_equal(bufcount + 1, len(getbufinfo()))
484 let g:last += 3
485
486 " setTitle test
487 call appendbufline(cmdbufnr, '$', 'setTitle_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200488 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
489 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200490 call assert_equal('send: 3:setTitle!67 "Xfile4"', l[-1])
491 let g:last += 3
492
493 " setFullName test
494 call appendbufline(cmdbufnr, '$', 'setFullName_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200495 call WaitFor('len(ReadXnetbeans()) >= (g:last + 5)')
496 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200497 call assert_equal('send: 3:setFullName!68 "Xfile4"', l[-3])
498 call assert_match('0:fileOpened=0 ".*/Xfile4" T F', l[-1])
499 call assert_equal('Xfile4', bufname())
500 let g:last += 5
501
502 " initDone test
503 call appendbufline(cmdbufnr, '$', 'initDone_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200504 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
505 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200506 call assert_equal('send: 3:initDone!69', l[-1])
507 let g:last += 3
508
509 " setVisible test
510 hide enew
511 call appendbufline(cmdbufnr, '$', 'setVisible_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200512 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
513 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200514 call assert_equal('send: 3:setVisible!70 T', l[-1])
515 let g:last += 3
516
517 " setModtime test
518 call appendbufline(cmdbufnr, '$', 'setModtime_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200519 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
520 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200521 call assert_equal('send: 3:setModtime!71 6', l[-1])
522 let g:last += 3
523
524 " insert test
525 call appendbufline(cmdbufnr, '$', 'insert_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200526 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
527 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200528 call assert_equal(['send: 3:insert/72 0 "line1\nline2\n"', '72'], l[-2:])
529 call assert_equal(['line1', 'line2'], getline(1, '$'))
530 let g:last += 4
531
532 " remove test
533 call appendbufline(cmdbufnr, '$', 'remove_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200534 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
535 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200536 call assert_equal(['send: 3:remove/73 3 4', '73'], l[-2:])
537 call assert_equal(['linine2'], getline(1, '$'))
538 let g:last += 4
539
540 " remove with invalid offset
541 call appendbufline(cmdbufnr, '$', 'remove_invalid_offset_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200542 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
543 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200544 call assert_equal(['send: 3:remove/74 900 4', '74 !bad position'], l[-2:])
545 let g:last += 4
546
547 " remove with invalid count
548 call appendbufline(cmdbufnr, '$', 'remove_invalid_count_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200549 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
550 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200551 call assert_equal(['send: 3:remove/75 1 800', '75 !bad count'], l[-2:])
552 let g:last += 4
553
554 " guard test
555 %d
556 call setline(1, ['foo bar', 'foo bar', 'foo bar'])
Bram Moolenaar95650152020-07-19 18:24:32 +0200557 call WaitFor('len(ReadXnetbeans()) >= (g:last + 8)')
Bram Moolenaar173d8412020-04-19 14:02:26 +0200558 let g:last += 8
559
560 call appendbufline(cmdbufnr, '$', 'guard_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200561 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
562 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200563 call assert_equal('send: 3:guard!76 8 7', l[-1])
564 sleep 1m
565 " second line is guarded. Try modifying the line
566 call assert_fails('normal 2GIbaz', 'E463:')
567 call assert_fails('normal 2GAbaz', 'E463:')
568 call assert_fails('normal dd', 'E463:')
569 call assert_equal([{'name': '1', 'texthl': 'NB_s1', 'text': '=>'},
570 \ {'name': '10000', 'linehl': 'NBGuarded'}],
571 \ sign_getdefined())
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100572 let s = sign_getplaced()[0].signs[0]
573 call assert_equal(2, s.lnum)
574 call assert_equal('10000', s.name)
Bram Moolenaar173d8412020-04-19 14:02:26 +0200575 let g:last += 3
576
577 " setModified test
578 call appendbufline(cmdbufnr, '$', 'setModified_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200579 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
580 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200581 call assert_equal('send: 3:setModified!77 T', l[-1])
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100582 sleep 1m
Bram Moolenaar173d8412020-04-19 14:02:26 +0200583 call assert_equal(1, &modified)
584 let g:last += 3
585
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100586 " clear setModified test
587 call appendbufline(cmdbufnr, '$', 'setModifiedClear_Test')
588 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
589 let l = ReadXnetbeans()
590 call assert_equal('send: 3:setModified!77 F', l[-1])
591 sleep 1m
592 call assert_equal(0, &modified)
593 let g:last += 3
594
Bram Moolenaar173d8412020-04-19 14:02:26 +0200595 " insertDone test
596 let v:statusmsg = ''
597 call appendbufline(cmdbufnr, '$', 'insertDone_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200598 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
599 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200600 call assert_equal('send: 3:insertDone!78 T F', l[-1])
601 sleep 1m
Bram Moolenaar3f40ce72020-07-05 14:10:13 +0200602 call assert_match('.*/Xfile4" 3L, 0B', v:statusmsg)
Bram Moolenaar173d8412020-04-19 14:02:26 +0200603 let g:last += 3
604
605 " saveDone test
606 let v:statusmsg = ''
607 call appendbufline(cmdbufnr, '$', 'saveDone_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200608 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
609 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200610 call assert_equal('send: 3:saveDone!79', l[-1])
611 sleep 1m
Bram Moolenaar3f40ce72020-07-05 14:10:13 +0200612 call assert_match('.*/Xfile4" 3L, 0B', v:statusmsg)
Bram Moolenaar173d8412020-04-19 14:02:26 +0200613 let g:last += 3
614
615 " unimplemented command test
616 call appendbufline(cmdbufnr, '$', 'invalidcmd_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200617 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
618 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200619 call assert_equal('send: 3:invalidcmd!80', l[-1])
620 let g:last += 3
621
622 " unimplemented function test
623 call appendbufline(cmdbufnr, '$', 'invalidfunc_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200624 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
625 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200626 call assert_equal(['send: 3:invalidfunc/81', '81'], l[-2:])
627 let g:last += 4
628
629 " Test for removeAnno cmd failure
630 call appendbufline(cmdbufnr, '$', 'removeAnno_fail_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200631 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
632 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200633 call assert_equal(['send: 0:removeAnno/82 1', '82'], l[-2:])
634 let g:last += 4
635
636 " Test for guard cmd failure
637 call appendbufline(cmdbufnr, '$', 'guard_fail_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200638 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
639 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200640 call assert_equal(['send: 0:guard/83 1 1', '83'], l[-2:])
641 let g:last += 4
642
643 " Test for save cmd failure
644 call appendbufline(cmdbufnr, '$', 'save_fail_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200645 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
646 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200647 call assert_equal(['send: 0:save/84', '84'], l[-2:])
648 let g:last += 4
649
650 " Test for netbeansBuffer cmd failure
651 call appendbufline(cmdbufnr, '$', 'netbeansBuffer_fail_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200652 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
653 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200654 call assert_equal(['send: 0:netbeansBuffer/85 T', '85'], l[-2:])
655 let g:last += 4
656
657 " nbkey test
658 call cursor(3, 3)
659 nbkey "\<C-F2>"
Bram Moolenaar95650152020-07-19 18:24:32 +0200660 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
661 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200662 call assert_equal(['3:newDotAndMark=85 18 18',
663 \ '3:keyCommand=85 ""\<C-F2>""',
664 \ '3:keyAtPos=85 ""\<C-F2>"" 18 3/2'], l[-3:])
665 let g:last += 3
666
667 " setExitDelay test
668 call appendbufline(cmdbufnr, '$', 'setExitDelay_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200669 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
670 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200671 call assert_equal('send: 0:setExitDelay!86 2', l[-1])
672 let g:last += 3
673
674 " setReadonly test
675 call appendbufline(cmdbufnr, '$', 'setReadOnly_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200676 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
677 let l = ReadXnetbeans()
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100678 call assert_equal('send: 3:setReadOnly!87 T', l[-1])
679 sleep 1m
680 call assert_equal(1, &readonly)
681 let g:last += 3
682
683 " clear setReadonly test
684 call appendbufline(cmdbufnr, '$', 'setReadOnlyClear_Test')
685 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
686 let l = ReadXnetbeans()
687 call assert_equal('send: 3:setReadOnly!88 F', l[-1])
688 sleep 1m
689 call assert_equal(0, &readonly)
690 let g:last += 3
691
692 " save test
693 call setbufvar(bufnr('Xfile4'), '&modified', 1)
694 call appendbufline(cmdbufnr, '$', 'save_Test')
695 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
696 let l = ReadXnetbeans()
697 call assert_equal('send: 3:save!89', l[-1])
698 sleep 1m
699 call assert_true(filereadable('Xfile4'))
Bram Moolenaar173d8412020-04-19 14:02:26 +0200700 let g:last += 3
701
702 " close test. Don't use buffer 10 after this
703 call appendbufline(cmdbufnr, '$', 'close_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200704 call WaitFor('len(ReadXnetbeans()) >= (g:last + 4)')
705 let l = ReadXnetbeans()
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100706 call assert_equal('send: 3:close!90', l[-2])
707 call assert_equal('3:killed=90', l[-1])
Bram Moolenaar173d8412020-04-19 14:02:26 +0200708 call assert_equal(1, winnr('$'))
709 let g:last += 4
710
711 " specialKeys test
712 call appendbufline(cmdbufnr, '$', 'specialKeys_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200713 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
714 let l = ReadXnetbeans()
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100715 call assert_equal('send: 0:specialKeys!91 "F12 F13 C-F13"', l[-1])
Bram Moolenaar173d8412020-04-19 14:02:26 +0200716 sleep 1m
717 call assert_equal(':nbkey F12<CR>', maparg('<F12>', 'n'))
718 call assert_equal(':nbkey F13<CR>', maparg('<F13>', 'n'))
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100719 call assert_equal(':nbkey C-F13<CR>', maparg('<C-F13>', 'n'))
Bram Moolenaar173d8412020-04-19 14:02:26 +0200720 let g:last += 3
721
722 " Open a buffer not monitored by netbeans
723 enew | only!
724 nbkey "\<C-F3>"
Bram Moolenaar95650152020-07-19 18:24:32 +0200725 call WaitFor('len(ReadXnetbeans()) >= (g:last + 1)')
726 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200727 call assert_equal('0:fileOpened=0 "" T F', l[-1])
728 let g:last += 1
729
Bram Moolenaar494e9062020-05-31 21:28:02 +0200730 " Test for writing a netbeans buffer
731 call appendbufline(cmdbufnr, '$', 'nbbufwrite_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200732 call WaitFor('len(ReadXnetbeans()) >= (g:last + 5)')
Bram Moolenaar494e9062020-05-31 21:28:02 +0200733 call assert_fails('write', 'E656:')
734 call setline(1, ['one', 'two'])
735 call assert_fails('1write!', 'E657:')
736 write
Bram Moolenaar95650152020-07-19 18:24:32 +0200737 call WaitFor('len(ReadXnetbeans()) >= (g:last + 10)')
Bram Moolenaar494e9062020-05-31 21:28:02 +0200738 let g:last += 10
739
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100740 if has('mouse')
741 " Test for mouse button release
742 let save_mouse = &mouse
743 set mouse=a
744 call feedkeys("\<LeftMouse>\<LeftRelease>", 'xt')
745 let &mouse = save_mouse
746 call WaitFor('len(ReadXnetbeans()) >= (g:last + 2)')
747 let l = ReadXnetbeans()
748 call assert_equal('4:newDotAndMark=93 0 0', l[-2])
749 call assert_equal('4:buttonRelease=93 0 1 -1', l[-1])
750 let g:last += 2
751 endif
752
753 " Test for startAtomic
754 call appendbufline(cmdbufnr, '$', 'startAtomic_Test')
755 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
756 let l = ReadXnetbeans()
757 call assert_equal('send: 0:startAtomic!94', l[-1])
758 let g:last += 3
759
760 " Test for endAtomic
761 call appendbufline(cmdbufnr, '$', 'endAtomic_Test')
762 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
763 let l = ReadXnetbeans()
764 call assert_equal('send: 0:endAtomic!95', l[-1])
765 let g:last += 3
766
767 " Test for invoking a netbeans key binding
768 let special_keys = [
769 \ ["\<F1>", 'F1'], ["\<S-F1>", 'S-F1'],
770 \ ["\<F2>", 'F2'], ["\<S-F2>", 'S-F2'],
771 \ ["\<F3>", 'F3'], ["\<S-F3>", 'S-F3'],
772 \ ["\<F4>", 'F4'], ["\<S-F4>", 'S-F4'],
773 \ ["\<F5>", 'F5'], ["\<S-F5>", 'S-F5'],
774 \ ["\<F6>", 'F6'], ["\<S-F6>", 'S-F6'],
775 \ ["\<F7>", 'F7'], ["\<S-F7>", 'S-F7'],
776 \ ["\<F8>", 'F8'], ["\<S-F8>", 'S-F8'],
777 \ ["\<F9>", 'F9'], ["\<S-F9>", 'S-F9'],
778 \ ["\<F11>", 'F11'], ["\<S-F11>", 'S-F11'],
779 \ ["\<F12>", 'F12'], ["\<S-F12>", 'S-F12'], ['!', '!']
780 \ ]
781 for [key, name] in special_keys
782 call feedkeys("\<F21>" .. key, 'xt')
783 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
784 let l = ReadXnetbeans()
785 call assert_match('4:keyCommand=\d\+ "' .. name .. '"', l[-2])
786 call assert_match('4:keyAtPos=\d\+ "' .. name .. '" 0 1/0', l[-1])
787 let g:last += 3
788 endfor
789 call feedkeys("\<F21>\<C-S-M-F9>", 'xt')
790 call WaitFor('len(ReadXnetbeans()) >= (g:last + 3)')
791 let l = ReadXnetbeans()
792 call assert_match('4:keyCommand=\d\+ "CSM-F9"', l[-2])
793 call assert_match('4:keyAtPos=\d\+ "CSM-F9" 0 1/0', l[-1])
794 let g:last += 3
795
796 if has('signs') && has('mouse')
797 sign define S1 linehl=Search text==>
798 sign define S2 linehl=ErrorMsg text=!!
799 sign place 10 line=1 name=S1
800 sign place 20 line=1 name=S2
801
802 let save_mouse = &mouse
803 set mouse=a
804 call assert_equal('S2', sign_getplaced()[0].signs[0].name)
805 call test_setmouse(1, 1)
806 call feedkeys("\<LeftMouse>\<LeftRelease>", 'xt')
807 call assert_equal('S1', sign_getplaced()[0].signs[0].name)
808 call test_setmouse(1, 1)
809 call feedkeys("\<LeftMouse>\<LeftRelease>", 'xt')
810 call assert_equal('S2', sign_getplaced()[0].signs[0].name)
811 let &mouse = save_mouse
812
813 sign unplace 10
814 sign unplace 20
815 sign undefine S1
816 sign undefine S2
817 endif
818
819 " define a large number of annotations
820 call appendbufline(cmdbufnr, '$', 'AnnoScale_Test')
821 call WaitFor('len(ReadXnetbeans()) >= (g:last + 26)')
822 let l = ReadXnetbeans()
823 call assert_equal('2:defineAnnoType!60 25 "s25" "x" "=>" blue none', l[-1])
824 sleep 1m
825 call assert_true(len(sign_getdefined()) >= 25)
826 let g:last += 26
827
Bram Moolenaar173d8412020-04-19 14:02:26 +0200828 " detach
829 call appendbufline(cmdbufnr, '$', 'detach_Test')
Bram Moolenaar95650152020-07-19 18:24:32 +0200830 call WaitFor('len(ReadXnetbeans()) >= (g:last + 8)')
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100831 call WaitForAssert({-> assert_equal('0:disconnect=97', ReadXnetbeans()[-1])})
Bram Moolenaar173d8412020-04-19 14:02:26 +0200832
Bram Moolenaar37d1b4f2020-05-13 17:16:04 +0200833 " the connection was closed
Bram Moolenaar8ddef482016-10-09 15:43:25 +0200834 call assert_false(has("netbeans_enabled"))
Bram Moolenaar321efdd2016-07-15 17:09:11 +0200835
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100836 " Remove all the signs
837 call sign_unplace('*')
838 call sign_undefine()
839
Bram Moolenaardbfa7952020-11-02 20:04:22 +0100840 call delete('Xfile4')
Bram Moolenaar321efdd2016-07-15 17:09:11 +0200841endfunc
842
843func Test_nb_basic()
844 call ch_log('Test_nb_basic')
845 call s:run_server('Nb_basic')
846endfunc
Bram Moolenaar603d6572016-07-15 17:41:56 +0200847
848func Nb_file_auth(port)
Bram Moolenaarc20e0d52017-11-02 18:19:19 +0100849 call delete("Xnetbeans")
Bram Moolenaarb152b6a2022-09-29 21:37:33 +0100850 call writefile([], "Xnetbeans", 'D')
Bram Moolenaarc20e0d52017-11-02 18:19:19 +0100851
Bram Moolenaar603d6572016-07-15 17:41:56 +0200852 call assert_fails('nbstart =notexist', 'E660:')
Bram Moolenaarb152b6a2022-09-29 21:37:33 +0100853 call writefile(['host=localhost', 'port=' . a:port, 'auth=bunny'], 'Xnbauth', 'D')
Bram Moolenaar53bdec22016-07-20 00:03:18 +0200854 if has('unix')
855 call setfperm('Xnbauth', "rw-r--r--")
856 call assert_fails('nbstart =Xnbauth', 'E668:')
857 endif
Bram Moolenaar603d6572016-07-15 17:41:56 +0200858 call setfperm('Xnbauth', "rw-------")
Bram Moolenaarffdf08c2016-08-27 19:52:47 +0200859 exe 'nbstart =Xnbauth'
Bram Moolenaar603d6572016-07-15 17:41:56 +0200860 call assert_true(has("netbeans_enabled"))
861
Bram Moolenaar95650152020-07-19 18:24:32 +0200862 call WaitFor('len(ReadXnetbeans()) > 2')
Bram Moolenaar603d6572016-07-15 17:41:56 +0200863 nbclose
Bram Moolenaar95650152020-07-19 18:24:32 +0200864 let lines = ReadXnetbeans()
Bram Moolenaar603d6572016-07-15 17:41:56 +0200865 call assert_equal('AUTH bunny', lines[0])
866 call assert_equal('0:version=0 "2.5"', lines[1])
867 call assert_equal('0:startupDone=0', lines[2])
868
869 call delete("Xnbauth")
Bram Moolenaar603d6572016-07-15 17:41:56 +0200870endfunc
871
872func Test_nb_file_auth()
873 call ch_log('Test_nb_file_auth')
874 call s:run_server('Nb_file_auth')
875endfunc
Bram Moolenaar173d8412020-04-19 14:02:26 +0200876
Bram Moolenaar8e7d6222020-12-18 19:49:56 +0100877" Test for quitting Vim with an open netbeans connection
Bram Moolenaar173d8412020-04-19 14:02:26 +0200878func Nb_quit_with_conn(port)
879 call delete("Xnetbeans")
Bram Moolenaarb152b6a2022-09-29 21:37:33 +0100880 call writefile([], "Xnetbeans", 'D')
Bram Moolenaar173d8412020-04-19 14:02:26 +0200881 let after =<< trim END
882 source shared.vim
Bram Moolenaar22286892020-11-05 20:50:51 +0100883 set cpo&vim
Bram Moolenaar173d8412020-04-19 14:02:26 +0200884
Bram Moolenaar95650152020-07-19 18:24:32 +0200885 func ReadXnetbeans()
886 let l = readfile("Xnetbeans")
887 return filter(l, 'v:val !~ "^0:geometry="')
888 endfunc
889
James McCoy765d82a2023-01-09 16:25:59 +0000890 try
891 " Establish the connection with the netbeans server
892 exe 'nbstart :localhost:' .. g:port .. ':star'
893 call assert_true(has("netbeans_enabled"))
894 call WaitFor('len(ReadXnetbeans()) >= 3')
895 let l = ReadXnetbeans()
896 call assert_equal(['AUTH star',
897 \ '0:version=0 "2.5"',
898 \ '0:startupDone=0'], l[-3:])
Bram Moolenaar173d8412020-04-19 14:02:26 +0200899
James McCoy765d82a2023-01-09 16:25:59 +0000900 " Open the command buffer to communicate with the server
901 split Xcmdbuf
902 call WaitFor('len(ReadXnetbeans()) >= 6')
903 let l = ReadXnetbeans()
904 call assert_equal('0:fileOpened=0 "Xcmdbuf" T F',
905 \ substitute(l[-3], '".*/', '"', ''))
906 call assert_equal('send: 1:putBufferNumber!15 "Xcmdbuf"',
907 \ substitute(l[-2], '".*/', '"', ''))
908 call assert_equal('1:startDocumentListen!16', l[-1])
909 sleep 1m
Bram Moolenaar173d8412020-04-19 14:02:26 +0200910
James McCoy765d82a2023-01-09 16:25:59 +0000911 quit!
912 quit!
913 finally
914 qall!
915 endtry
Bram Moolenaar173d8412020-04-19 14:02:26 +0200916 END
917 if RunVim(['let g:port = ' .. a:port], after, '')
Bram Moolenaar95650152020-07-19 18:24:32 +0200918 call WaitFor('len(ReadXnetbeans()) >= 9')
919 let l = ReadXnetbeans()
Bram Moolenaar173d8412020-04-19 14:02:26 +0200920 call assert_equal('1:unmodified=16', l[-3])
921 call assert_equal('1:killed=16', l[-2])
922 call assert_equal('0:disconnect=16', l[-1])
923 endif
Bram Moolenaar173d8412020-04-19 14:02:26 +0200924endfunc
925
926func Test_nb_quit_with_conn()
927 " Exiting Vim with a netbeans connection doesn't work properly on
928 " MS-Windows.
929 CheckUnix
930 call s:run_server('Nb_quit_with_conn')
931endfunc
932
Bram Moolenaar32e5ec02020-11-06 13:44:21 +0100933func Nb_bwipe_buffer(port)
934 call delete("Xnetbeans")
935 call writefile([], "Xnetbeans")
936
937 " Last line number in the Xnetbeans file. Used to verify the result of the
938 " communication with the netbeans server
939 let g:last = 0
940
941 " Establish the connection with the netbeans server
942 exe 'nbstart :localhost:' .. a:port .. ':bunny'
943 call WaitFor('len(ReadXnetbeans()) > (g:last + 2)')
944 let l = ReadXnetbeans()
945 call assert_equal(['AUTH bunny',
946 \ '0:version=0 "2.5"',
947 \ '0:startupDone=0'], l[-3:])
948 let g:last += 3
949
950 " Open the command buffer to communicate with the server
951 split Xcmdbuf
952 call WaitFor('len(ReadXnetbeans()) > (g:last + 2)')
953 let l = ReadXnetbeans()
954 call assert_equal('0:fileOpened=0 "Xcmdbuf" T F',
955 \ substitute(l[-3], '".*/', '"', ''))
956 call assert_equal('send: 1:putBufferNumber!15 "Xcmdbuf"',
957 \ substitute(l[-2], '".*/', '"', ''))
958 call assert_equal('1:startDocumentListen!16', l[-1])
959 let g:last += 3
960
961 sleep 10m
962endfunc
963
964" This test used to reference a buffer after it was freed leading to an ASAN
965" error.
966func Test_nb_bwipe_buffer()
967 call s:run_server('Nb_bwipe_buffer')
Bram Moolenaar50dc3ec2020-11-16 18:39:43 +0100968 silent! %bwipe!
Bram Moolenaar32e5ec02020-11-06 13:44:21 +0100969 sleep 100m
970 nbclose
971endfunc
972
Bram Moolenaar173d8412020-04-19 14:02:26 +0200973" vim: shiftwidth=2 sts=2 expandtab