summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/bootstrap_spec.lua13
-rw-r--r--tests/lsp_spec.lua98
-rw-r--r--tests/minimal_init.lua9
-rw-r--r--tests/plugins_load_spec.lua34
4 files changed, 141 insertions, 13 deletions
diff --git a/tests/bootstrap_spec.lua b/tests/bootstrap_spec.lua
index 73e0a673..e5f7244d 100644
--- a/tests/bootstrap_spec.lua
+++ b/tests/bootstrap_spec.lua
@@ -25,17 +25,4 @@ a.describe("initial start", function()
a.it("should be able to run treesitter without errors", function()
assert.truthy(vim.treesitter.highlighter.active)
end)
-
- a.it("should be able to load default packages without errors", function()
- -- TODO: maybe there's a way to avoid hard-coding the names of the modules?
- local startup_plugins = {
- "packer",
- "lspconfig",
- "nlspsettings",
- "null-ls",
- }
- for _, plugin in pairs(startup_plugins) do
- assert.truthy(package.loaded[tostring(plugin)])
- end
- end)
end)
diff --git a/tests/lsp_spec.lua b/tests/lsp_spec.lua
new file mode 100644
index 00000000..1695bdb4
--- /dev/null
+++ b/tests/lsp_spec.lua
@@ -0,0 +1,98 @@
+local a = require "plenary.async_lib.tests"
+local utils = require "utils"
+lvim.lsp.templates_dir = join_paths(get_runtime_dir(), "lvim", "tests", "artifacts")
+
+a.describe("lsp workflow", function()
+ local Log = require "core.log"
+ 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
+ require("lsp").setup()
+
+ -- 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"
+
+ local plugins = require "plugins"
+ require("plugin-loader"):load { plugins, lvim.plugins }
+
+ if utils.is_file(logfile) then
+ assert.equal(vim.fn.delete(logfile), 0)
+ end
+
+ assert.True(utils.is_directory(lvim.lsp.templates_dir))
+ require("lsp").setup()
+
+ -- 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 retrieve supported filetypes correctly", function()
+ local ocaml = {
+ name = "ocamlls",
+ filetypes = { "ocaml", "reason" },
+ }
+ local ocaml_fts = require("lsp.utils").get_supported_filetypes(ocaml.name)
+ assert.True(vim.deep_equal(ocaml.filetypes, ocaml_fts))
+
+ local tsserver = {
+ name = "tsserver",
+ filetypes = {
+ "javascript",
+ "javascriptreact",
+ "javascript.jsx",
+ "typescript",
+ "typescriptreact",
+ "typescript.tsx",
+ },
+ }
+ local tsserver_fts = require("lsp.utils").get_supported_filetypes(tsserver.name)
+ assert.True(vim.deep_equal(tsserver.filetypes, tsserver_fts))
+ end)
+
+ a.it("shoud ignore all javascript servers except tsserver and tailwindcss when generating templates", function()
+ local test_server = { name = "denols", filetypes = {} }
+ test_server.filetypes = require("lsp.utils").get_supported_filetypes(test_server.name)
+
+ assert.True(vim.tbl_contains(test_server.filetypes, "javascript"))
+
+ local is_ignored = require("lsp.templates").is_ignored(test_server.name)
+ assert.True(is_ignored)
+
+ local ts_template = utils.join_paths(lvim.lsp.templates_dir, "typescript.lua")
+
+ assert.True(utils.file_contains(ts_template, "tsserver"))
+ assert.True(utils.file_contains(ts_template, "tailwindcss"))
+ assert.False(utils.file_contains(ts_template, test_server.name))
+ end)
+
+ a.it("shoud not include blacklisted servers in the generated templates", function()
+ assert.True(utils.is_directory(lvim.lsp.templates_dir))
+ require("lsp").setup()
+
+ local blacklisted = { "jedi_language_server", "pylsp", "sqlls", "sqls", "angularls", "ansiblels" }
+
+ for _, file in ipairs(vim.fn.glob(lvim.lsp.templates_dir .. "/*.lua", 1, 1)) do
+ for _, server in ipairs(blacklisted) do
+ assert.False(utils.file_contains(file, server))
+ end
+ end
+ end)
+end)
diff --git a/tests/minimal_init.lua b/tests/minimal_init.lua
new file mode 100644
index 00000000..f495eba0
--- /dev/null
+++ b/tests/minimal_init.lua
@@ -0,0 +1,9 @@
+local path_sep = vim.loop.os_uname().version:match "Windows" and "\\" or "/"
+
+vim.opt.rtp:append(os.getenv "LUNARVIM_RUNTIME_DIR" .. path_sep .. "lvim")
+
+require("bootstrap"):init()
+
+local config = require "config"
+-- config:init()
+config:load()
diff --git a/tests/plugins_load_spec.lua b/tests/plugins_load_spec.lua
new file mode 100644
index 00000000..cf9ea3b6
--- /dev/null
+++ b/tests/plugins_load_spec.lua
@@ -0,0 +1,34 @@
+local a = require "plenary.async_lib.tests"
+
+a.describe("plugin-loader", function()
+ a.it("should be able to load default packages without errors", function()
+ local plugins = require "plugins"
+ require("plugin-loader"):load { plugins, lvim.plugins }
+
+ -- TODO: maybe there's a way to avoid hard-coding the names of the modules?
+ local startup_plugins = {
+ "packer",
+ }
+
+ for _, plugin in ipairs(startup_plugins) do
+ assert.truthy(package.loaded[plugin])
+ end
+ end)
+
+ a.it("should be able to load lsp packages without errors", function()
+ local plugins = require "plugins"
+ require("plugin-loader"):load { plugins, lvim.plugins }
+
+ require("lsp").setup()
+
+ local lsp_packages = {
+ "lspconfig",
+ "nlspsettings",
+ "null-ls",
+ }
+
+ for _, plugin in ipairs(lsp_packages) do
+ assert.truthy(package.loaded[plugin])
+ end
+ end)
+end)