mirror of
				https://github.com/neovim/neovim.git
				synced 2025-10-26 12:27:24 +00:00 
			
		
		
		
	 a39c8b7ce3
			
		
	
	a39c8b7ce3
	
	
	
		
			
			Travis disabled IPv6:
[ RUN      ] serverstart(), serverstop() parses endpoints correctly: FAIL
...build/neovim/neovim/test/functional/eval/server_spec.lua:83: Expected objects to be the same.
Passed in:
(table) {
  [1] = '127.0.0.1:12345' }
Expected:
(table) {
  [1] = '127.0.0.1:12345'
 *[2] = '::1:12345' }
Change all tests to ensure a server was actually started before
expecting it to be returned from serverlist().
		
	
		
			
				
	
	
		
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Lua
		
	
	
	
	
	
| 
 | |
| local helpers = require('test.functional.helpers')(after_each)
 | |
| local eq, neq, eval = helpers.eq, helpers.neq, helpers.eval
 | |
| local command = helpers.command
 | |
| local clear, funcs, meths = helpers.clear, helpers.funcs, helpers.meths
 | |
| local os_name = helpers.os_name
 | |
| 
 | |
| local function clear_serverlist()
 | |
|     for _, server in pairs(funcs.serverlist()) do
 | |
|       funcs.serverstop(server)
 | |
|     end
 | |
| end
 | |
| 
 | |
| describe('serverstart(), serverstop()', function()
 | |
|   before_each(clear)
 | |
| 
 | |
|   it('sets $NVIM_LISTEN_ADDRESS on first invocation', function()
 | |
|     -- Unset $NVIM_LISTEN_ADDRESS
 | |
|     command('let $NVIM_LISTEN_ADDRESS = ""')
 | |
| 
 | |
|     local s = eval('serverstart()')
 | |
|     assert(s ~= nil and s:len() > 0, "serverstart() returned empty")
 | |
|     eq(s, eval('$NVIM_LISTEN_ADDRESS'))
 | |
|     command("call serverstop('"..s.."')")
 | |
|     eq('', eval('$NVIM_LISTEN_ADDRESS'))
 | |
|   end)
 | |
| 
 | |
|   it('sets v:servername _only_ on nvim startup unless all servers are stopped',
 | |
|   function()
 | |
|     local initial_server = meths.get_vvar('servername')
 | |
|     assert(initial_server ~= nil and initial_server:len() > 0,
 | |
|            'v:servername was not initialized')
 | |
| 
 | |
|     -- v:servername is readonly so we cannot unset it--but we can test that it
 | |
|     -- does not get set again thereafter.
 | |
|     local s = funcs.serverstart()
 | |
|     assert(s ~= nil and s:len() > 0, "serverstart() returned empty")
 | |
|     neq(initial_server, s)
 | |
| 
 | |
|     -- serverstop() does _not_ modify v:servername...
 | |
|     funcs.serverstop(s)
 | |
|     eq(initial_server, meths.get_vvar('servername'))
 | |
| 
 | |
|     -- ...unless we stop _all_ servers.
 | |
|     funcs.serverstop(funcs.serverlist()[1])
 | |
|     eq('', meths.get_vvar('servername'))
 | |
| 
 | |
|     -- v:servername will take the next available server.
 | |
|     local servername = (os_name() == 'windows'
 | |
|                         and [[\\.\pipe\Xtest-functional-server-pipe]]
 | |
|                         or 'Xtest-functional-server-socket')
 | |
|     funcs.serverstart(servername)
 | |
|     eq(servername, meths.get_vvar('servername'))
 | |
|   end)
 | |
| 
 | |
|   it('serverstop() ignores invalid input', function()
 | |
|     command("call serverstop('')")
 | |
|     command("call serverstop('bogus-socket-name')")
 | |
|   end)
 | |
| 
 | |
|   it('parses endpoints correctly', function()
 | |
|     clear_serverlist()
 | |
|     eq({}, funcs.serverlist())
 | |
| 
 | |
|     local s = funcs.serverstart('127.0.0.1:0')  -- assign random port
 | |
|     if #s > 0 then
 | |
|       assert(string.match(s, '127.0.0.1:%d+'))
 | |
|       eq(s, funcs.serverlist()[1])
 | |
|       clear_serverlist()
 | |
|     end
 | |
| 
 | |
|     s = funcs.serverstart('127.0.0.1:')  -- assign random port
 | |
|     if #s > 0 then
 | |
|       assert(string.match(s, '127.0.0.1:%d+'))
 | |
|       eq(s, funcs.serverlist()[1])
 | |
|       clear_serverlist()
 | |
|     end
 | |
| 
 | |
|     local expected = {}
 | |
|     local v4 = '127.0.0.1:12345'
 | |
|     s = funcs.serverstart(v4)
 | |
|     if #s > 0 then
 | |
|       table.insert(expected, v4)
 | |
|       funcs.serverstart(v4)  -- exists already; ignore
 | |
|     end
 | |
| 
 | |
|     local v6 = '::1:12345'
 | |
|     s = funcs.serverstart(v6)
 | |
|     if #s > 0 then
 | |
|       table.insert(expected, v6)
 | |
|       funcs.serverstart(v6)  -- exists already; ignore
 | |
|     end
 | |
|     eq(expected, funcs.serverlist())
 | |
|     clear_serverlist()
 | |
| 
 | |
|     funcs.serverstart('127.0.0.1:65536')  -- invalid port
 | |
|     eq({}, funcs.serverlist())
 | |
|   end)
 | |
| end)
 | |
| 
 | |
| describe('serverlist()', function()
 | |
|   before_each(clear)
 | |
| 
 | |
|   it('returns the list of servers', function()
 | |
|     -- There should already be at least one server.
 | |
|     local n = eval('len(serverlist())')
 | |
| 
 | |
|     -- Add a few
 | |
|     local servs = (os_name() == 'windows'
 | |
|       and { [[\\.\pipe\Xtest-pipe0934]], [[\\.\pipe\Xtest-pipe4324]] }
 | |
|       or  { [[Xtest-pipe0934]], [[Xtest-pipe4324]] })
 | |
|     for _, s in ipairs(servs) do
 | |
|       eq(s, eval("serverstart('"..s.."')"))
 | |
|     end
 | |
| 
 | |
|     local new_servs = eval('serverlist()')
 | |
| 
 | |
|     -- Exactly #servs servers should be added.
 | |
|     eq(n + #servs, #new_servs)
 | |
|     -- The new servers should be at the end of the list.
 | |
|     for i = 1, #servs do
 | |
|       eq(servs[i], new_servs[i + n])
 | |
|       command("call serverstop('"..servs[i].."')")
 | |
|     end
 | |
|     -- After serverstop() the servers should NOT be in the list.
 | |
|     eq(n, eval('len(serverlist())'))
 | |
|   end)
 | |
| end)
 |