forked from aniani/vim
		
	patch 8.2.0599: Netbeans interface insufficiently tested
Problem: Netbeans interface insufficiently tested. Solution: Add more tests. (Yegappan Lakshmanan, closes #5921)
This commit is contained in:
		| @@ -40,21 +40,26 @@ or environment providing a socket interface can control Vim using this | |||||||
| protocol. There are existing implementations in C, C++, Python and Java. The | protocol. There are existing implementations in C, C++, Python and Java. The | ||||||
| name NetBeans is kept today for historical reasons. | name NetBeans is kept today for historical reasons. | ||||||
|  |  | ||||||
| Current projects using the NetBeans protocol of Vim are: | Active project using the NetBeans protocol of Vim: | ||||||
| - VimIntegration, description of various projects doing Vim Integration: | - Eclim, http://eclim.org/ | ||||||
|  |  | ||||||
|  | VimIntegration, description of various projects doing Vim Integration: | ||||||
| 	http://www.freehackers.org/VimIntegration | 	http://www.freehackers.org/VimIntegration | ||||||
| - Agide, an IDE for the AAP project, written in Python: |  | ||||||
| 	http://www.a-a-p.org | Projects using the NetBeans protocol of Vim are or were: | ||||||
|  | - Agide, an IDE for the AAP project, written in Python (now replaced by | ||||||
|  |   |:Termdebug|): http://www.a-a-p.org | ||||||
| - Clewn, a gdb integration into Vim, written in C: | - Clewn, a gdb integration into Vim, written in C: | ||||||
| 	http://clewn.sourceforge.net/ | 	http://clewn.sourceforge.net/ | ||||||
| - Pyclewn, a gdb integration into Vim, written in Python: | - Pyclewn, a gdb integration into Vim, written in Python: | ||||||
| 	http://pyclewn.sourceforge.net/ | 	http://pyclewn.sourceforge.net/ | ||||||
|  | - VimWrapper, library to easy Vim integration into IDE: | ||||||
|  | 	http://www.freehackers.org/VimWrapper | ||||||
|  | Outdated projects (links don't work): | ||||||
| - VimPlugin, integration of Vim inside Eclipse: | - VimPlugin, integration of Vim inside Eclipse: | ||||||
| 	http://vimplugin.sourceforge.net/wiki/pmwiki.php | 	http://vimplugin.sourceforge.net/wiki/pmwiki.php | ||||||
| - PIDA, IDE written in Python integrating Vim: | - PIDA, IDE written in Python integrating Vim: | ||||||
| 	http://pida.co.uk/ | 	http://pida.co.uk/ | ||||||
| - VimWrapper, library to easy Vim integration into IDE: |  | ||||||
| 	http://www.freehackers.org/VimWrapper |  | ||||||
|  |  | ||||||
| Check the specific project pages to see how to use Vim with these projects. | Check the specific project pages to see how to use Vim with these projects. | ||||||
|  |  | ||||||
| @@ -461,11 +466,13 @@ guard off len | |||||||
| initDone	Mark the buffer as ready for use.  Implicitly makes the buffer | initDone	Mark the buffer as ready for use.  Implicitly makes the buffer | ||||||
| 		the current buffer.  Fires the BufReadPost autocommand event. | 		the current buffer.  Fires the BufReadPost autocommand event. | ||||||
|  |  | ||||||
| insertDone | insertDone starteol readonly | ||||||
| 		Sent by Vim Controller to tell Vim an initial file insert is | 		Sent by Vim Controller to tell Vim an initial file insert is | ||||||
| 		done.  This triggers a read message being printed.  Prior to | 		done.  This triggers a read message being printed.  If | ||||||
| 		version 2.3, no read messages were displayed after opening a | 		"starteol" is "F" then the last line doesn't have a EOL. If | ||||||
| 		file.  New in version 2.3. | 		"readonly" is "T" then the file is marked as readonly. Prior | ||||||
|  | 		to version 2.3, no read messages were displayed after opening | ||||||
|  | 		a file.  New in version 2.3. | ||||||
|  |  | ||||||
| moveAnnoToFront serNum | moveAnnoToFront serNum | ||||||
| 		Not implemented. | 		Not implemented. | ||||||
|   | |||||||
| @@ -743,6 +743,7 @@ netbeans_end(void) | |||||||
| 	nbdebug(("EVT: %s", buf)); | 	nbdebug(("EVT: %s", buf)); | ||||||
| 	// nb_send(buf, "netbeans_end");    avoid "write failed" messages | 	// nb_send(buf, "netbeans_end");    avoid "write failed" messages | ||||||
| 	nb_send(buf, NULL); | 	nb_send(buf, NULL); | ||||||
|  | 	buf_list[i].bufp = NULL; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -2749,6 +2749,10 @@ mch_init(void) | |||||||
|     void |     void | ||||||
| mch_exit(int r) | mch_exit(int r) | ||||||
| { | { | ||||||
|  | #ifdef FEAT_NETBEANS_INTG | ||||||
|  |     netbeans_send_disconnect(); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #ifdef VIMDLL | #ifdef VIMDLL | ||||||
|     if (gui.in_use || gui.starting) |     if (gui.in_use || gui.starting) | ||||||
| 	mch_exit_g(r); | 	mch_exit_g(r); | ||||||
|   | |||||||
| @@ -349,7 +349,6 @@ let s:flaky_tests = [ | |||||||
|       \ 'Test_diff_screen()', |       \ 'Test_diff_screen()', | ||||||
|       \ 'Test_exit_callback_interval()', |       \ 'Test_exit_callback_interval()', | ||||||
|       \ 'Test_map_timeout_with_timer_interrupt()', |       \ 'Test_map_timeout_with_timer_interrupt()', | ||||||
|       \ 'Test_nb_basic()', |  | ||||||
|       \ 'Test_out_cb()', |       \ 'Test_out_cb()', | ||||||
|       \ 'Test_pipe_through_sort_all()', |       \ 'Test_pipe_through_sort_all()', | ||||||
|       \ 'Test_pipe_through_sort_some()', |       \ 'Test_pipe_through_sort_some()', | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ import socket | |||||||
| import sys | import sys | ||||||
| import time | import time | ||||||
| import threading | import threading | ||||||
|  | import re | ||||||
|  |  | ||||||
| try: | try: | ||||||
|     # Python 3 |     # Python 3 | ||||||
| @@ -20,8 +21,119 @@ except ImportError: | |||||||
|  |  | ||||||
| class ThreadedTCPRequestHandler(socketserver.BaseRequestHandler): | class ThreadedTCPRequestHandler(socketserver.BaseRequestHandler): | ||||||
|  |  | ||||||
|  |     def process_msgs(self, msgbuf): | ||||||
|  |         # Process all the received netbeans commands/responses/events from Vim. | ||||||
|  |         # Each one is separated by a newline character. If a partial command | ||||||
|  |         # is received, process it later after the rest of it is received. | ||||||
|  |         while True: | ||||||
|  |             (line, sep, rest) = msgbuf.partition('\n') | ||||||
|  |             if sep == '': | ||||||
|  |                 # received partial line | ||||||
|  |                 return line | ||||||
|  |             msgbuf = rest | ||||||
|  |  | ||||||
|  |             # Process a command only after receiving a newline. | ||||||
|  |             response = '' | ||||||
|  |             if line.find('Xcmdbuf') > 0: | ||||||
|  |                 name = line.split('"')[1] | ||||||
|  |                 response = '1:putBufferNumber!15 "' + name + '"\n' | ||||||
|  |                 response += '1:startDocumentListen!16\n' | ||||||
|  |             elif re.match('1:insert=.* "\\\\n"', line): | ||||||
|  |                 # extract the command from the previous line | ||||||
|  |                 cmd = re.search('.*"(.*)"', self.prev_line).group(1) | ||||||
|  |                 testmap = { | ||||||
|  |                   'getCursor_Test' : '0:getCursor/30\n', | ||||||
|  |                   'E627_Test' : '0 setReadOnly!31\n', | ||||||
|  |                   'E628_Test' : '0:setReadOnly 32\n', | ||||||
|  |                   'E632_Test' : '0:getLength/33\n', | ||||||
|  |                   'E633_Test' : '0:getText/34\n', | ||||||
|  |                   'E634_Test' : '0:remove/35 1 1\n', | ||||||
|  |                   'E635_Test' : '0:insert/36 0 "line1\\n"\n', | ||||||
|  |                   'E636_Test' : '0:create!37\n', | ||||||
|  |                   'E637_Test' : '0:startDocumentListen!38\n', | ||||||
|  |                   'E638_Test' : '0:stopDocumentListen!39\n', | ||||||
|  |                   'E639_Test' : '0:setTitle!40 "Title"\n', | ||||||
|  |                   'E640_Test' : '0:initDone!41\n', | ||||||
|  |                   'E641_Test' : '0:putBufferNumber!42 "XSomeBuf"\n', | ||||||
|  |                   'E642_Test' : '9:putBufferNumber!43 "XInvalidBuf"\n', | ||||||
|  |                   'E643_Test' : '0:setFullName!44 "XSomeBuf"\n', | ||||||
|  |                   'E644_Test' : '0:editFile!45 "Xfile3"\n', | ||||||
|  |                   'E645_Test' : '0:setVisible!46 T\n', | ||||||
|  |                   'E646_Test' : '0:setModified!47 T\n', | ||||||
|  |                   'E647_Test' : '0:setDot!48 1/1\n', | ||||||
|  |                   'E648_Test' : '0:close!49\n', | ||||||
|  |                   'E650_Test' : '0:defineAnnoType!50 1 "abc" "a" "a" 1 1\n', | ||||||
|  |                   'E651_Test' : '0:addAnno!51 1 1 1 1\n', | ||||||
|  |                   'E652_Test' : '0:getAnno/52 8\n', | ||||||
|  |                   'editFile_Test' : '2:editFile!53 "Xfile3"\n', | ||||||
|  |                   'getLength_Test' : '2:getLength/54\n', | ||||||
|  |                   'getModified_Test' : '2:getModified/55\n', | ||||||
|  |                   'getText_Test' : '2:getText/56\n', | ||||||
|  |                   'setDot_Test' : '2:setDot!57 3/6\n', | ||||||
|  |                   'startDocumentListen_Test' : '2:startDocumentListen!58\n', | ||||||
|  |                   'stopDocumentListen_Test' : '2:stopDocumentListen!59\n', | ||||||
|  |                   'define_anno_Test' : '2:defineAnnoType!60 1 "s1" "x" "=>" blue none\n', | ||||||
|  |                   'E532_Test' : '2:defineAnnoType!61 1 "s1" "x" "=>" aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa none\n', | ||||||
|  |                   'add_anno_Test' : '2:addAnno!62 1 1 2/1 0\n', | ||||||
|  |                   'get_anno_Test' : '2:getAnno/63 1\n', | ||||||
|  |                   'remove_anno_Test' : '2:removeAnno!64 1\n', | ||||||
|  |                   'getModifiedAll_Test' : '0:getModified/65\n', | ||||||
|  |                   'create_Test' : '3:create!66\n', | ||||||
|  |                   'setTitle_Test' : '3:setTitle!67 "Xfile4"\n', | ||||||
|  |                   'setFullName_Test' : '3:setFullName!68 "Xfile4"\n', | ||||||
|  |                   'initDone_Test' : '3:initDone!69\n', | ||||||
|  |                   'setVisible_Test' : '3:setVisible!70 T\n', | ||||||
|  |                   'setModtime_Test' : '3:setModtime!71 6\n', | ||||||
|  |                   'insert_Test' : '3:insert/72 0 "line1\\nline2\\n"\n', | ||||||
|  |                   'remove_Test' : '3:remove/73 3 4\n', | ||||||
|  |                   'remove_invalid_offset_Test' : '3:remove/74 900 4\n', | ||||||
|  |                   'remove_invalid_count_Test' : '3:remove/75 1 800\n', | ||||||
|  |                   'guard_Test' : '3:guard!76 8 7\n', | ||||||
|  |                   'setModified_Test' : '3:setModified!77 T\n', | ||||||
|  |                   'insertDone_Test' : '3:insertDone!78 T F\n', | ||||||
|  |                   'saveDone_Test' : '3:saveDone!79\n', | ||||||
|  |                   'invalidcmd_Test' : '3:invalidcmd!80\n', | ||||||
|  |                   'invalidfunc_Test' : '3:invalidfunc/81\n', | ||||||
|  |                   'removeAnno_fail_Test' : '0:removeAnno/82 1\n', | ||||||
|  |                   'guard_fail_Test' : '0:guard/83 1 1\n', | ||||||
|  |                   'save_fail_Test' : '0:save/84\n', | ||||||
|  |                   'netbeansBuffer_fail_Test' : '0:netbeansBuffer/85 T\n', | ||||||
|  |                   'setExitDelay_Test' : '0:setExitDelay!86 2\n', | ||||||
|  |                   'setReadOnly_Test' : '3:setReadOnly!87\n', | ||||||
|  |                   'close_Test' : '3:close!88\n', | ||||||
|  |                   'specialKeys_Test' : '0:specialKeys!89 "F12 F13"\n', | ||||||
|  |                   'detach_Test' : '2:close!90\n1:close!91\nDETACH\n' | ||||||
|  |                 } | ||||||
|  |                 # execute the specified test | ||||||
|  |                 if cmd not in testmap: | ||||||
|  |                   print("=== invalid command %s ===" % (cmd)) | ||||||
|  |                 else: | ||||||
|  |                   response = testmap[cmd] | ||||||
|  |             elif line.find('disconnect') > 0: | ||||||
|  |                 # we're done | ||||||
|  |                 self.server.shutdown() | ||||||
|  |                 return | ||||||
|  |  | ||||||
|  |             # save the current line, this is used as the test to run after | ||||||
|  |             # receiving a newline only line. | ||||||
|  |             self.prev_line = line | ||||||
|  |  | ||||||
|  |             if len(response) > 0: | ||||||
|  |                 self.request.sendall(response.encode('utf-8')) | ||||||
|  |                 # Write the respoinse into the file, so that the test can knows | ||||||
|  |                 # the command was sent. | ||||||
|  |                 with open("Xnetbeans", "a") as myfile: | ||||||
|  |                     myfile.write('send: ' + response) | ||||||
|  |                 if self.debug: | ||||||
|  |                     with open("save_Xnetbeans", "a") as myfile: | ||||||
|  |                         myfile.write('send: ' + response) | ||||||
|  |  | ||||||
|     def handle(self): |     def handle(self): | ||||||
|         print("=== socket opened ===") |         print("=== socket opened ===") | ||||||
|  |         # To preserve the Xnetbeans file as save_Xnetbeans, set debug to 1 | ||||||
|  |         self.debug = 0 | ||||||
|  |         self.prev_line = '' | ||||||
|  |         msgbuf = '' | ||||||
|         while True: |         while True: | ||||||
|             try: |             try: | ||||||
|                 received = self.request.recv(4096).decode('utf-8') |                 received = self.request.recv(4096).decode('utf-8') | ||||||
| @@ -40,23 +152,15 @@ class ThreadedTCPRequestHandler(socketserver.BaseRequestHandler): | |||||||
|             # what happened. |             # what happened. | ||||||
|             with open("Xnetbeans", "a") as myfile: |             with open("Xnetbeans", "a") as myfile: | ||||||
|                 myfile.write(received) |                 myfile.write(received) | ||||||
|  |             if self.debug: | ||||||
|  |                 with open("save_Xnetbeans", "a") as myfile: | ||||||
|  |                     myfile.write(received) | ||||||
|  |  | ||||||
|             response = '' |             # Can receive more than one line in a response or a partial line. | ||||||
|             if received.find('XREADME.txt') > 0: |             # Accumulate all the received characters and process one line at | ||||||
|                 name = received.split('"')[1] |             # a time. | ||||||
|                 response = '5:putBufferNumber!33 "' + name + '"\n' |             msgbuf += received | ||||||
|                 response += '5:setDot!1 3/19\n' |             msgbuf = self.process_msgs(msgbuf) | ||||||
|             elif received.find('disconnect') > 0: |  | ||||||
|                 # we're done |  | ||||||
|                 self.server.shutdown() |  | ||||||
|                 return |  | ||||||
|  |  | ||||||
|             if len(response) > 0: |  | ||||||
|                 self.request.sendall(response.encode('utf-8')) |  | ||||||
|                 # Write the respoinse into the file, so that the test can knows |  | ||||||
|                 # the command was sent. |  | ||||||
|                 with open("Xnetbeans", "a") as myfile: |  | ||||||
|                     myfile.write('send: ' + response) |  | ||||||
|  |  | ||||||
| class ThreadedTCPServer(socketserver.ThreadingMixIn, socketserver.TCPServer): | class ThreadedTCPServer(socketserver.ThreadingMixIn, socketserver.TCPServer): | ||||||
|     pass |     pass | ||||||
|   | |||||||
| @@ -15,37 +15,610 @@ func s:run_server(testfunc, ...) | |||||||
|   call RunServer('test_netbeans.py', a:testfunc, a:000) |   call RunServer('test_netbeans.py', a:testfunc, a:000) | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | " Wait for an exception (error) to be thrown. This is used to check whether a | ||||||
|  | " message from the netbeans server causes an error. It takes some time for Vim | ||||||
|  | " to process a netbeans message. So a sleep is used below to account for this. | ||||||
|  | func WaitForError(errcode) | ||||||
|  |   let save_exception = '' | ||||||
|  |   for i in range(200) | ||||||
|  |     try | ||||||
|  |       sleep 5m | ||||||
|  |     catch | ||||||
|  |       let save_exception = v:exception | ||||||
|  |       break | ||||||
|  |     endtry | ||||||
|  |   endfor | ||||||
|  |   call assert_match(a:errcode, save_exception) | ||||||
|  | endfunc | ||||||
|  |  | ||||||
| func Nb_basic(port) | func Nb_basic(port) | ||||||
|   call delete("Xnetbeans") |   call delete("Xnetbeans") | ||||||
|   call writefile([], "Xnetbeans") |   call writefile([], "Xnetbeans") | ||||||
|   call writefile(repeat(['abcdefghijklmnopqrstuvwxyz'], 5), "XREADME.txt") |  | ||||||
|   exe 'nbstart :localhost:' . a:port . ':bunny' |   " Last line number in the Xnetbeans file. Used to verify the result of the | ||||||
|  |   " communication with the netbeans server | ||||||
|  |   let g:last = 0 | ||||||
|  |  | ||||||
|  |   " Establish the connection with the netbeans server | ||||||
|  |   exe 'nbstart :localhost:' .. a:port .. ':bunny' | ||||||
|   call assert_true(has("netbeans_enabled")) |   call assert_true(has("netbeans_enabled")) | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) > (g:last + 2)') | ||||||
|  |   let l = readfile("Xnetbeans") | ||||||
|  |   call assert_equal(['AUTH bunny', | ||||||
|  |         \ '0:version=0 "2.5"', | ||||||
|  |         \ '0:startupDone=0'], l[-3:]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|   call WaitFor('len(readfile("Xnetbeans")) > 2') |   " Trying to connect again to netbeans server should fail | ||||||
|   split +$ XREADME.txt |   call assert_fails("exe 'nbstart :localhost:' . a:port . ':bunny'", 'E511:') | ||||||
|  |  | ||||||
|   " Opening XREADME.txt will result in a setDot command |   " Open the command buffer to communicate with the server | ||||||
|   call WaitFor('len(readfile("Xnetbeans")) > 4') |   split Xcmdbuf | ||||||
|   call WaitFor('getcurpos()[1] == 3') |   let cmdbufnr = bufnr() | ||||||
|   let pos = getcurpos() |   call WaitFor('len(readfile("Xnetbeans")) > (g:last + 2)') | ||||||
|   call assert_equal(3, pos[1]) |   let l = readfile("Xnetbeans") | ||||||
|   call assert_equal(20, pos[2]) |   call assert_equal('0:fileOpened=0 "Xcmdbuf" T F', | ||||||
|   close |         \ substitute(l[-3], '".*/', '"', '')) | ||||||
|   nbclose |   call assert_equal('send: 1:putBufferNumber!15 "Xcmdbuf"', | ||||||
|  |         \ substitute(l[-2], '".*/', '"', '')) | ||||||
|  |   call assert_equal('1:startDocumentListen!16', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|   call WaitFor('len(readfile("Xnetbeans")) > 6') |   " Keep the command buffer loaded for communication | ||||||
|  |   hide | ||||||
|  |  | ||||||
|  |   sleep 1m | ||||||
|  |  | ||||||
|  |   " getCursor test | ||||||
|  |   call writefile(['foo bar', 'foo bar', 'foo bar'], 'Xfile1') | ||||||
|  |   split Xfile1 | ||||||
|  |   call cursor(3, 4) | ||||||
|  |   sleep 10m | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'getCursor_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 5)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:getCursor/30', '30 -1 3 3 19'], l[-2:]) | ||||||
|  |   let g:last += 5 | ||||||
|  |  | ||||||
|  |   " Test for E627 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E627_Test') | ||||||
|  |   call WaitForError('E627:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0 setReadOnly!31', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E628 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E628_Test') | ||||||
|  |   call WaitForError('E628:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setReadOnly 32', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E632 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E632_Test') | ||||||
|  |   call WaitForError('E632:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:getLength/33', '33 0'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for E633 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E633_Test') | ||||||
|  |   call WaitForError('E633:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:getText/34', '34 '], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for E634 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E634_Test') | ||||||
|  |   call WaitForError('E634:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:remove/35 1 1', '35'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for E635 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E635_Test') | ||||||
|  |   call WaitForError('E635:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:insert/36 0 "line1\n"', '36'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for E636 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E636_Test') | ||||||
|  |   call WaitForError('E636:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:create!37', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E637 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E637_Test') | ||||||
|  |   call WaitForError('E637:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:startDocumentListen!38', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E638 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E638_Test') | ||||||
|  |   call WaitForError('E638:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:stopDocumentListen!39', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E639 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E639_Test') | ||||||
|  |   call WaitForError('E639:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setTitle!40 "Title"', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E640 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E640_Test') | ||||||
|  |   call WaitForError('E640:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:initDone!41', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E641 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E641_Test') | ||||||
|  |   call WaitForError('E641:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:putBufferNumber!42 "XSomeBuf"', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E642 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E642_Test') | ||||||
|  |   call WaitForError('E642:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 9:putBufferNumber!43 "XInvalidBuf"', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E643 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E643_Test') | ||||||
|  |   call WaitForError('E643:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setFullName!44 "XSomeBuf"', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   enew! | ||||||
|  |  | ||||||
|  |   " Test for E644 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E644_Test') | ||||||
|  |   call WaitForError('E644:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:editFile!45 "Xfile3"', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E645 (shown only when verbose > 0) | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E645_Test') | ||||||
|  |   set verbose=1 | ||||||
|  |   call WaitForError('E645:') | ||||||
|  |   set verbose& | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setVisible!46 T', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E646 (shown only when verbose > 0) | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E646_Test') | ||||||
|  |   set verbose=1 | ||||||
|  |   call WaitForError('E646:') | ||||||
|  |   set verbose& | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setModified!47 T', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E647 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E647_Test') | ||||||
|  |   call WaitForError('E647:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setDot!48 1/1', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E648 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E648_Test') | ||||||
|  |   call WaitForError('E648:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:close!49', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E650 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E650_Test') | ||||||
|  |   call WaitForError('E650:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:defineAnnoType!50 1 "abc" "a" "a" 1 1', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E651 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E651_Test') | ||||||
|  |   call WaitForError('E651:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:addAnno!51 1 1 1 1', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Test for E652 | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E652_Test') | ||||||
|  |   call WaitForError('E652:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:getAnno/52 8', '52 0'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " editFile test | ||||||
|  |   call writefile(['foo bar1', 'foo bar2', 'foo bar3'], 'Xfile3') | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'editFile_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:editFile!53 "Xfile3"', l[-2]) | ||||||
|  |   call assert_match('0:fileOpened=0 ".*/Xfile3" T F', l[-1]) | ||||||
|  |   call assert_equal('Xfile3', bufname()) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " getLength test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'getLength_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 2:getLength/54', '54 27'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " getModified test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'getModified_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 2:getModified/55', '55 0'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " getText test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'getText_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 2:getText/56', | ||||||
|  |         \ '56 "foo bar1\nfoo bar2\nfoo bar3\n"'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " setDot test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setDot_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:setDot!57 3/6', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " startDocumentListen test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'startDocumentListen_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:startDocumentListen!58', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " make some changes to the buffer and check whether the netbeans server | ||||||
|  |   " received the notifications | ||||||
|  |   call append(2, 'blue sky') | ||||||
|  |   1d | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_match('2:insert=\d\+ 18 "blue sky"', l[-3]) | ||||||
|  |   call assert_match('2:insert=\d\+ 26 "\\n"', l[-2]) | ||||||
|  |   call assert_match('2:remove=\d\+ 0 9', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " stopDocumentListen test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'stopDocumentListen_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:stopDocumentListen!59', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Wait for vim to process the previous netbeans message | ||||||
|  |   sleep 1m | ||||||
|  |  | ||||||
|  |   " modify the buffer and make sure that the netbeans server is not notified | ||||||
|  |   call append(2, 'clear sky') | ||||||
|  |   1d | ||||||
|  |  | ||||||
|  |   " defineAnnoType test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'define_anno_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:defineAnnoType!60 1 "s1" "x" "=>" blue none', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   call assert_equal([{'name': '1', 'texthl': 'NB_s1', 'text': '=>'}], | ||||||
|  |         \ sign_getdefined()) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " defineAnnoType with a long color name | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'E532_Test') | ||||||
|  |   call WaitForError('E532:') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:defineAnnoType!61 1 "s1" "x" "=>" aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa none', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " addAnno test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'add_anno_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:addAnno!62 1 1 2/1 0', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   call assert_equal([{'lnum': 2, 'id': 1, 'name': '1', 'priority': 10, | ||||||
|  |         \ 'group': ''}], sign_getplaced()[0].signs) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " getAnno test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'get_anno_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 2:getAnno/63 1', '63 2'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " removeAnno test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'remove_anno_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 2:removeAnno!64 1', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   call assert_equal([], sign_getplaced()) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " getModified test to get the number of modified buffers | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'getModifiedAll_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:getModified/65', '65 2'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   let bufcount = len(getbufinfo()) | ||||||
|  |  | ||||||
|  |   " create test to create a new buffer | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'create_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:create!66', l[-1]) | ||||||
|  |   " Wait for vim to process the previous netbeans message | ||||||
|  |   sleep 10m | ||||||
|  |   call assert_equal(bufcount + 1, len(getbufinfo())) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setTitle test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setTitle_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:setTitle!67 "Xfile4"', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setFullName test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setFullName_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 5)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:setFullName!68 "Xfile4"', l[-3]) | ||||||
|  |   call assert_match('0:fileOpened=0 ".*/Xfile4" T F', l[-1]) | ||||||
|  |   call assert_equal('Xfile4', bufname()) | ||||||
|  |   let g:last += 5 | ||||||
|  |  | ||||||
|  |   " initDone test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'initDone_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:initDone!69', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setVisible test | ||||||
|  |   hide enew | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setVisible_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:setVisible!70 T', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setModtime test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setModtime_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:setModtime!71 6', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " insert test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'insert_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 3:insert/72 0 "line1\nline2\n"', '72'], l[-2:]) | ||||||
|  |   call assert_equal(['line1', 'line2'], getline(1, '$')) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " remove test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'remove_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 3:remove/73 3 4', '73'], l[-2:]) | ||||||
|  |   call assert_equal(['linine2'], getline(1, '$')) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " remove with invalid offset | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'remove_invalid_offset_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 3:remove/74 900 4', '74 !bad position'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " remove with invalid count | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'remove_invalid_count_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 3:remove/75 1 800', '75 !bad count'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " guard test | ||||||
|  |   %d | ||||||
|  |   call setline(1, ['foo bar', 'foo bar', 'foo bar']) | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 8)') | ||||||
|  |   let g:last += 8 | ||||||
|  |  | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'guard_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:guard!76 8 7', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   " second line is guarded. Try modifying the line | ||||||
|  |   call assert_fails('normal 2GIbaz', 'E463:') | ||||||
|  |   call assert_fails('normal 2GAbaz', 'E463:') | ||||||
|  |   call assert_fails('normal dd', 'E463:') | ||||||
|  |   call assert_equal([{'name': '1', 'texthl': 'NB_s1', 'text': '=>'}, | ||||||
|  |         \ {'name': '10000', 'linehl': 'NBGuarded'}], | ||||||
|  |         \ sign_getdefined()) | ||||||
|  |   call assert_equal([{'lnum': 2, 'id': 1000000, 'name': '10000', | ||||||
|  |         \ 'priority': 10, 'group': ''}], sign_getplaced()[0].signs) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setModified test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setModified_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:setModified!77 T', l[-1]) | ||||||
|  |   call assert_equal(1, &modified) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " insertDone test | ||||||
|  |   let v:statusmsg = '' | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'insertDone_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:insertDone!78 T F', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   call assert_match('.*/Xfile4" 3L, 0C', v:statusmsg) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " saveDone test | ||||||
|  |   let v:statusmsg = '' | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'saveDone_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:saveDone!79', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   call assert_match('.*/Xfile4" 3L, 0C', v:statusmsg) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " unimplemented command test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'invalidcmd_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:invalidcmd!80', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " unimplemented function test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'invalidfunc_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 3:invalidfunc/81', '81'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for removeAnno cmd failure | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'removeAnno_fail_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:removeAnno/82 1', '82'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for guard cmd failure | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'guard_fail_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:guard/83 1 1', '83'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for save cmd failure | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'save_fail_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:save/84', '84'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " Test for netbeansBuffer cmd failure | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'netbeansBuffer_fail_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['send: 0:netbeansBuffer/85 T', '85'], l[-2:]) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " nbkey test | ||||||
|  |   call cursor(3, 3) | ||||||
|  |   nbkey "\<C-F2>" | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal(['3:newDotAndMark=85 18 18', | ||||||
|  |         \ '3:keyCommand=85 ""\<C-F2>""', | ||||||
|  |         \ '3:keyAtPos=85 ""\<C-F2>"" 18 3/2'], l[-3:]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setExitDelay test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setExitDelay_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:setExitDelay!86 2', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " setReadonly test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'setReadOnly_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:setReadOnly!87', l[-1]) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " close test. Don't use buffer 10 after this | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'close_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 4)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 3:close!88', l[-2]) | ||||||
|  |   call assert_equal('3:killed=88', l[-1]) | ||||||
|  |   call assert_equal(1, winnr('$')) | ||||||
|  |   let g:last += 4 | ||||||
|  |  | ||||||
|  |   " specialKeys test | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'specialKeys_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 3)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('send: 0:specialKeys!89 "F12 F13"', l[-1]) | ||||||
|  |   sleep 1m | ||||||
|  |   call assert_equal(':nbkey F12<CR>', maparg('<F12>', 'n')) | ||||||
|  |   call assert_equal(':nbkey F13<CR>', maparg('<F13>', 'n')) | ||||||
|  |   let g:last += 3 | ||||||
|  |  | ||||||
|  |   " Open a buffer not monitored by netbeans | ||||||
|  |   enew | only! | ||||||
|  |   nbkey "\<C-F3>" | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 1)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('0:fileOpened=0 "" T F', l[-1]) | ||||||
|  |   let g:last += 1 | ||||||
|  |  | ||||||
|  |   " detach | ||||||
|  |   call appendbufline(cmdbufnr, '$', 'detach_Test') | ||||||
|  |   call WaitFor('len(readfile("Xnetbeans")) >= (g:last + 6)') | ||||||
|  |   let l = readfile('Xnetbeans') | ||||||
|  |   call assert_equal('0:disconnect=91', l[-1]) | ||||||
|  |  | ||||||
|  |   " close the connection | ||||||
|   call assert_false(has("netbeans_enabled")) |   call assert_false(has("netbeans_enabled")) | ||||||
|   let lines = readfile("Xnetbeans") |  | ||||||
|   call assert_equal('AUTH bunny', lines[0]) |  | ||||||
|   call assert_equal('0:version=0 "2.5"', lines[1]) |  | ||||||
|   call assert_equal('0:startupDone=0', lines[2]) |  | ||||||
|   call assert_equal('0:fileOpened=0 "XREADME.txt" T F', substitute(lines[3], '".*/', '"', '')) |  | ||||||
|  |  | ||||||
|   call assert_equal('0:disconnect=1', lines[6]) |  | ||||||
|  |  | ||||||
|   call delete("Xnetbeans") |   call delete("Xnetbeans") | ||||||
|   call delete("XREADME.txt") |   call delete('Xfile1') | ||||||
|  |   call delete('Xfile3') | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
| func Test_nb_basic() | func Test_nb_basic() | ||||||
| @@ -82,3 +655,52 @@ func Test_nb_file_auth() | |||||||
|   call ch_log('Test_nb_file_auth') |   call ch_log('Test_nb_file_auth') | ||||||
|   call s:run_server('Nb_file_auth') |   call s:run_server('Nb_file_auth') | ||||||
| endfunc | endfunc | ||||||
|  |  | ||||||
|  | " Test for quiting Vim with an open netbeans connection | ||||||
|  | func Nb_quit_with_conn(port) | ||||||
|  |   call delete("Xnetbeans") | ||||||
|  |   call writefile([], "Xnetbeans") | ||||||
|  |   let after =<< trim END | ||||||
|  |     source shared.vim | ||||||
|  |  | ||||||
|  |     " Establish the connection with the netbeans server | ||||||
|  |     exe 'nbstart :localhost:' .. g:port .. ':star' | ||||||
|  |     call assert_true(has("netbeans_enabled")) | ||||||
|  |     call WaitFor('len(readfile("Xnetbeans")) >= 3') | ||||||
|  |     let l = readfile("Xnetbeans") | ||||||
|  |     call assert_equal(['AUTH star', | ||||||
|  |       \ '0:version=0 "2.5"', | ||||||
|  |       \ '0:startupDone=0'], l[-3:]) | ||||||
|  |  | ||||||
|  |     " Open the command buffer to communicate with the server | ||||||
|  |     split Xcmdbuf | ||||||
|  |     call WaitFor('len(readfile("Xnetbeans")) >= 6') | ||||||
|  |     let l = readfile("Xnetbeans") | ||||||
|  |     call assert_equal('0:fileOpened=0 "Xcmdbuf" T F', | ||||||
|  |           \ substitute(l[-3], '".*/', '"', '')) | ||||||
|  |     call assert_equal('send: 1:putBufferNumber!15 "Xcmdbuf"', | ||||||
|  |           \ substitute(l[-2], '".*/', '"', '')) | ||||||
|  |     call assert_equal('1:startDocumentListen!16', l[-1]) | ||||||
|  |     sleep 1m | ||||||
|  |  | ||||||
|  |     quit! | ||||||
|  |     quit! | ||||||
|  |   END | ||||||
|  |   if RunVim(['let g:port = ' .. a:port], after, '') | ||||||
|  |     call WaitFor('len(readfile("Xnetbeans")) >= 9') | ||||||
|  |     let l = readfile('Xnetbeans') | ||||||
|  |     call assert_equal('1:unmodified=16', l[-3]) | ||||||
|  |     call assert_equal('1:killed=16', l[-2]) | ||||||
|  |     call assert_equal('0:disconnect=16', l[-1]) | ||||||
|  |   endif | ||||||
|  |   call delete('Xnetbeans') | ||||||
|  | endfunc | ||||||
|  |  | ||||||
|  | func Test_nb_quit_with_conn() | ||||||
|  |   " Exiting Vim with a netbeans connection doesn't work properly on | ||||||
|  |   " MS-Windows. | ||||||
|  |   CheckUnix | ||||||
|  |   call s:run_server('Nb_quit_with_conn') | ||||||
|  | endfunc | ||||||
|  |  | ||||||
|  | " vim: shiftwidth=2 sts=2 expandtab | ||||||
|   | |||||||
| @@ -746,6 +746,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 */ | ||||||
|  | /**/ | ||||||
|  |     599, | ||||||
| /**/ | /**/ | ||||||
|     598, |     598, | ||||||
| /**/ | /**/ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user