2021-10-03 16:13:46 +02:00
|
|
|
local a = require "plenary.async_lib.tests"
|
2021-10-10 21:07:41 +02:00
|
|
|
local utils = require "lvim.utils"
|
2022-03-24 16:16:38 +01:00
|
|
|
local helpers = require "tests.lvim.helpers"
|
2022-04-12 11:18:17 +02:00
|
|
|
local spy = require "luassert.spy"
|
2021-10-03 16:13:46 +02:00
|
|
|
|
|
|
|
a.describe("lsp workflow", function()
|
2022-04-12 11:18:17 +02:00
|
|
|
before_each(function()
|
|
|
|
vim.cmd [[
|
|
|
|
let v:errmsg = ""
|
|
|
|
let v:errors = []
|
|
|
|
]]
|
|
|
|
end)
|
|
|
|
|
|
|
|
after_each(function()
|
|
|
|
local errmsg = vim.fn.eval "v:errmsg"
|
|
|
|
local exception = vim.fn.eval "v:exception"
|
|
|
|
local errors = vim.fn.eval "v:errors"
|
|
|
|
assert.equal("", errmsg)
|
|
|
|
assert.equal("", exception)
|
|
|
|
assert.True(vim.tbl_isempty(errors))
|
|
|
|
end)
|
|
|
|
|
|
|
|
lvim.lsp.templates_dir = join_paths(get_cache_dir(), "artifacts")
|
2023-04-28 10:27:40 +02:00
|
|
|
vim.go.loadplugins = true
|
|
|
|
local plugins = require "lvim.plugins"
|
|
|
|
require("lvim.plugin-loader").load { plugins, lvim.plugins }
|
2021-10-03 16:13:46 +02:00
|
|
|
|
2022-02-18 15:17:17 +01:00
|
|
|
a.it("should be able to delete ftplugin templates", function()
|
2021-10-03 16:13:46 +02:00
|
|
|
if utils.is_directory(lvim.lsp.templates_dir) then
|
|
|
|
assert.equal(vim.fn.delete(lvim.lsp.templates_dir, "rf"), 0)
|
|
|
|
end
|
|
|
|
assert.False(utils.is_directory(lvim.lsp.templates_dir))
|
|
|
|
end)
|
|
|
|
|
2022-02-18 15:17:17 +01:00
|
|
|
a.it("should be able to generate ftplugin templates", function()
|
2021-10-03 16:13:46 +02:00
|
|
|
if utils.is_directory(lvim.lsp.templates_dir) then
|
|
|
|
assert.equal(vim.fn.delete(lvim.lsp.templates_dir, "rf"), 0)
|
|
|
|
end
|
|
|
|
|
2021-10-10 21:07:41 +02:00
|
|
|
require("lvim.lsp").setup()
|
2021-10-03 16:13:46 +02:00
|
|
|
|
2023-04-28 10:27:40 +02:00
|
|
|
assert.True(#vim.fn.glob(lvim.lsp.templates_dir .. "/*.lua", 1, 1) > 0)
|
2021-10-03 16:13:46 +02:00
|
|
|
end)
|
|
|
|
|
2022-02-18 15:17:17 +01:00
|
|
|
a.it("should not include blacklisted servers in the generated templates", function()
|
2021-10-10 21:07:41 +02:00
|
|
|
require("lvim.lsp").setup()
|
2021-10-03 16:13:46 +02:00
|
|
|
|
2023-08-25 11:51:57 +02:00
|
|
|
for _, server_name in ipairs(lvim.lsp.automatic_configuration.skipped_servers) do
|
|
|
|
local setup_cmd = string.format([[require("lvim.lsp.manager").setup(%q)]], server_name)
|
|
|
|
local _, stdout, _ = helpers.search_file(lvim.lsp.templates_dir, setup_cmd)
|
|
|
|
assert.True(vim.tbl_isempty(stdout))
|
2021-10-03 16:13:46 +02:00
|
|
|
end
|
|
|
|
end)
|
2021-10-31 16:23:44 +01:00
|
|
|
|
2022-02-18 15:17:17 +01:00
|
|
|
a.it("should only include one server per generated template", function()
|
2021-10-31 16:23:44 +01:00
|
|
|
require("lvim.lsp").setup()
|
|
|
|
|
2022-08-09 10:41:17 +02:00
|
|
|
local allowed_dupes = { "tailwindcss" }
|
2021-10-31 16:23:44 +01:00
|
|
|
for _, file in ipairs(vim.fn.glob(lvim.lsp.templates_dir .. "/*.lua", 1, 1)) do
|
2021-11-09 18:59:27 +01:00
|
|
|
local content = {}
|
|
|
|
for entry in io.lines(file) do
|
2022-08-09 10:41:17 +02:00
|
|
|
local server_name = entry:match [[.*setup%("(.*)"%)]]
|
|
|
|
if not vim.tbl_contains(allowed_dupes, server_name) then
|
|
|
|
table.insert(content, server_name)
|
|
|
|
end
|
2021-10-31 16:23:44 +01:00
|
|
|
end
|
2021-11-09 18:59:27 +01:00
|
|
|
local err_msg = ""
|
|
|
|
if #content > 1 then
|
|
|
|
err_msg = string.format(
|
|
|
|
"found more than one server for [%q]: \n{\n %q \n}",
|
|
|
|
file:match "[^/]*.lua$",
|
|
|
|
table.concat(content, ", ")
|
|
|
|
)
|
|
|
|
end
|
|
|
|
assert.equal(err_msg, "")
|
2021-10-31 16:23:44 +01:00
|
|
|
end
|
|
|
|
end)
|
2022-04-12 11:18:17 +02:00
|
|
|
|
|
|
|
a.it("should not attempt to re-generate ftplugin templates", function()
|
|
|
|
local s = spy.on(require "lvim.lsp.templates", "generate_templates")
|
|
|
|
|
|
|
|
require("lvim.lsp").setup()
|
2023-08-25 11:51:57 +02:00
|
|
|
assert.spy(s):was_not_called()
|
2022-04-12 11:18:17 +02:00
|
|
|
s:revert()
|
|
|
|
end)
|
2021-10-03 16:13:46 +02:00
|
|
|
end)
|