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"
|
2021-10-03 16:13:46 +02:00
|
|
|
lvim.lsp.templates_dir = join_paths(get_runtime_dir(), "lvim", "tests", "artifacts")
|
|
|
|
|
|
|
|
a.describe("lsp workflow", function()
|
2021-10-10 21:07:41 +02:00
|
|
|
local Log = require "lvim.core.log"
|
2021-10-03 16:13:46 +02:00
|
|
|
local logfile = Log:get_path()
|
|
|
|
|
|
|
|
a.it("shoud be able to delete ftplugin templates", function()
|
|
|
|
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)
|
|
|
|
|
|
|
|
a.it("shoud be able to generate ftplugin templates", function()
|
|
|
|
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
|
|
|
|
|
|
|
-- we need to delay this check until the generation is completed
|
|
|
|
vim.schedule(function()
|
|
|
|
assert.True(utils.is_directory(lvim.lsp.templates_dir))
|
|
|
|
end)
|
|
|
|
end)
|
|
|
|
|
|
|
|
a.it("shoud not attempt to re-generate ftplugin templates", function()
|
|
|
|
lvim.log.level = "debug"
|
|
|
|
|
2021-10-10 21:07:41 +02:00
|
|
|
local plugins = require "lvim.plugins"
|
|
|
|
require("lvim.plugin-loader"):load { plugins, lvim.plugins }
|
2021-10-03 16:13:46 +02:00
|
|
|
|
|
|
|
if utils.is_file(logfile) then
|
|
|
|
assert.equal(vim.fn.delete(logfile), 0)
|
|
|
|
end
|
|
|
|
|
|
|
|
assert.True(utils.is_directory(lvim.lsp.templates_dir))
|
2021-10-10 21:07:41 +02:00
|
|
|
require("lvim.lsp").setup()
|
2021-10-03 16:13:46 +02:00
|
|
|
|
|
|
|
-- we need to delay this check until the log gets populated
|
|
|
|
vim.schedule(function()
|
|
|
|
assert.False(utils.log_contains "templates")
|
|
|
|
end)
|
|
|
|
end)
|
|
|
|
|
|
|
|
a.it("shoud not include blacklisted servers in the generated templates", function()
|
|
|
|
assert.True(utils.is_directory(lvim.lsp.templates_dir))
|
2021-10-10 21:07:41 +02:00
|
|
|
require("lvim.lsp").setup()
|
2021-10-03 16:13:46 +02:00
|
|
|
|
|
|
|
for _, file in ipairs(vim.fn.glob(lvim.lsp.templates_dir .. "/*.lua", 1, 1)) do
|
2021-10-23 18:12:11 +02:00
|
|
|
for _, server in ipairs(lvim.lsp.override) do
|
2021-10-03 16:13:46 +02:00
|
|
|
assert.False(utils.file_contains(file, server))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end)
|
2021-10-31 16:23:44 +01:00
|
|
|
|
|
|
|
a.it("shoud only include one server per generated template", function()
|
|
|
|
assert.True(utils.is_directory(lvim.lsp.templates_dir))
|
|
|
|
require("lvim.lsp").setup()
|
|
|
|
|
|
|
|
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
|
|
|
|
table.insert(content, entry)
|
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)
|
2021-10-03 16:13:46 +02:00
|
|
|
end)
|