From d0ff66c9abe9d6abbca12fd811e0c3cb69c1033a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Fri, 22 Nov 2019 23:26:32 +0800 Subject: =?UTF-8?q?=E6=95=B4=E7=90=86=E4=B8=80=E4=B8=8B=E7=9B=AE=E5=BD=95?= =?UTF-8?q?=E7=BB=93=E6=9E=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- script-beta/test/crossfile/hover.lua | 347 +++++++++++++++++++++++++++++++++++ 1 file changed, 347 insertions(+) create mode 100644 script-beta/test/crossfile/hover.lua (limited to 'script-beta/test/crossfile/hover.lua') diff --git a/script-beta/test/crossfile/hover.lua b/script-beta/test/crossfile/hover.lua new file mode 100644 index 00000000..1d4328e1 --- /dev/null +++ b/script-beta/test/crossfile/hover.lua @@ -0,0 +1,347 @@ +local service = require 'service' +local workspace = require 'workspace' +local fs = require 'bee.filesystem' +local core = require 'core' +local uric = require 'uri' + +rawset(_G, 'TEST', true) + +local EXISTS = {} + +local function eq(a, b) + if a == EXISTS and b ~= nil then + return true + end + if b == EXISTS and a ~= nil then + return true + end + local tp1, tp2 = type(a), type(b) + if tp1 ~= tp2 then + return false + end + if tp1 == 'table' then + local mark = {} + for k in pairs(a) do + if not eq(a[k], b[k]) then + return false + end + mark[k] = true + end + for k in pairs(b) do + if not mark[k] then + return false + end + end + return true + end + return a == b +end + +local function catch_target(script, sep) + local list = {} + local cur = 1 + local cut = 0 + while true do + local start, finish = script:find(('<%%%s.-%%%s>'):format(sep, sep), cur) + if not start then + break + end + list[#list+1] = { start - cut, finish - 4 - cut } + cur = finish + 1 + cut = cut + 4 + end + local new_script = script:gsub(('<%%%s(.-)%%%s>'):format(sep, sep), '%1') + return new_script, list +end + +function TEST(data) + local lsp = service() + local ws = workspace(lsp, 'test') + lsp.workspace = ws + ws.root = ROOT + + local targetScript = data[1].content + local targetUri = uric.encode(fs.path(data[1].path)) + + local sourceScript, sourceList = catch_target(data[2].content, '?') + local sourceUri = uric.encode(fs.path(data[2].path)) + + lsp:saveText(targetUri, 1, targetScript) + ws:addFile(uric.decode(targetUri)) + lsp:compileVM(targetUri) + lsp:saveText(sourceUri, 1, sourceScript) + ws:addFile(uric.decode(sourceUri)) + lsp:compileVM(sourceUri) + + local sourceVM = lsp:loadVM(sourceUri) + assert(sourceVM) + local sourcePos = (sourceList[1][1] + sourceList[1][2]) // 2 + local source = core.findSource(sourceVM, sourcePos) + local hover = core.hover(source, lsp) + assert(hover) + if data.hover.description then + local uriROOT = uric.encode(ROOT):gsub('%%', '%%%%') + data.hover.description = data.hover.description:gsub('%$ROOT%$', uriROOT) + end + if hover.label then + hover.label = hover.label:gsub('\r\n', '\n') + end + assert(eq(hover, data.hover)) +end + +TEST { + { + path = 'a.lua', + content = '', + }, + { + path = 'b.lua', + content = 'require ', + }, + hover = { + description = [[[a.lua]($ROOT$/a.lua)]], + } +} + +TEST { + { + path = 'a.lua', + content = [[ + local function f(a, b) + end + return f + ]], + }, + { + path = 'b.lua', + content = [[ + local x = require 'a' + () + ]] + }, + hover = { + label = 'function f(a: any, b: any)', + name = 'f', + args = EXISTS, + } +} + +TEST { + { + path = 'a.lua', + content = [[ + return function (a, b) + end + ]], + }, + { + path = 'b.lua', + content = [[ + local f = require 'a' + () + ]] + }, + hover = { + label = 'function (a: any, b: any)', + name = '', + args = EXISTS, + } +} + +TEST { + { + path = 'a.lua', + content = [[ + local mt = {} + mt.__index = mt + + function mt:add(a, b) + end + + return function () + return setmetatable({}, mt) + end + ]], + }, + { + path = 'b.lua', + content = [[ + local m = require 'a' + local obj = m() + obj:() + ]] + }, + hover = { + label = 'function mt:add(a: any, b: any)', + name = 'mt:add', + args = EXISTS, + }, +} + +TEST { + { + path = 'a.lua', + content = [[ + t = { + [{}] = 1, + } + ]], + }, + { + path = 'b.lua', + content = [[ + [{}] = 2 + ]] + }, + hover = { + label = [[ +global t: { + [*table]: number = 1, + [*table]: number = 2, +}]], + name = 't', + }, +} + +TEST { + { + path = 'a.lua', + content = [[ + t = { + [{}] = 1, + } + ]], + }, + { + path = 'a.lua', + content = [[ + [{}] = 2 + ]] + }, + hover = { + label = [[ +global t: { + [*table]: number = 2, +}]], + name = 't', + }, +} + +TEST { + { + path = 'a.lua', + content = '', + }, + { + path = 'b.lua', + content = [[ + --- abc + ---@param x number + function (x) end + ]], + }, + hover = { + label = [[function f(x: number)]], + name = 'f', + description = 'abc', + args = EXISTS, + } +} + +TEST { + { + path = 'a.lua', + content = '', + }, + { + path = 'b.lua', + content = [[ + --- abc + = 1 + ]], + }, + hover = { + label = [[global x: number = 1]], + name = 'x', + description = 'abc', + } +} + +TEST { + { + path = 'a.lua', + content = '', + }, + { + path = 'b.lua', + content = [[ + ---@param x string + ---| "'选项1'" # 注释1 + ---| > "'选项2'" # 注释2 + function (x) end + ]] + }, + hover = { + label = 'function f(x: string)', + name = 'f', + args = EXISTS, + rawEnum = EXISTS, + enum = [[ + +x: string + | '选项1' -- 注释1 + |>'选项2' -- 注释2]] + } +} + +TEST { + { + path = 'a.lua', + content = '', + }, + { + path = 'b.lua', + content = [[ + ---@alias option + ---| "'选项1'" # 注释1 + ---| > "'选项2'" # 注释2 + ---@param x option + function (x) end + ]] + }, + hover = { + label = 'function f(x: option)', + name = 'f', + args = EXISTS, + rawEnum = EXISTS, + enum = [[ + +x: option + | '选项1' -- 注释1 + |>'选项2' -- 注释2]] + } +} + +TEST { + { + path = 'a.lua', + content = '', + }, + { + path = 'b.lua', + content = [[ + ---@param x string {comment = 'aaaa'} + ---@param y string {comment = 'bbbb'} + local function (x, y) end + ]] + }, + hover = { + label = 'function f(x: string, y: string)', + name = 'f', + args = EXISTS, + description = [[ ++ `x`*(string)*: aaaa + ++ `y`*(string)*: bbbb]] + } +} -- cgit v1.2.3