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 assert(string.match(s, '127.0.0.1:%d+')) eq(s, funcs.serverlist()[1]) clear_serverlist() s = funcs.serverstart('127.0.0.1:') -- assign random port assert(string.match(s, '127.0.0.1:%d+')) eq(s, funcs.serverlist()[1]) clear_serverlist() funcs.serverstart('127.0.0.1:12345') funcs.serverstart('127.0.0.1:12345') -- exists already; ignore funcs.serverstart('::1:12345') funcs.serverstart('::1:12345') -- exists already; ignore local expected = { '127.0.0.1:12345', '::1:12345', } 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)