summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/bootstrap_spec.lua28
-rw-r--r--tests/lsp_spec.lua97
-rw-r--r--tests/minimal_init.lua9
-rw-r--r--tests/plugins_load_spec.lua34
4 files changed, 168 insertions, 0 deletions
diff --git a/tests/bootstrap_spec.lua b/tests/bootstrap_spec.lua
new file mode 100644
index 00000000..e5f7244d
--- /dev/null
+++ b/tests/bootstrap_spec.lua
@@ -0,0 +1,28 @@
+local a = require "plenary.async_lib.tests"
+
+a.describe("initial start", function()
+ local uv = vim.loop
+ local home_dir = uv.os_homedir()
+ local lvim_config_path = get_config_dir() or home_dir .. "/.config/lvim"
+ local lvim_runtime_path = get_runtime_dir() or home_dir .. "/.local/share/lunarvim"
+
+ a.it("shoud be able to detect test environment", function()
+ assert.truthy(os.getenv "LVIM_TEST_ENV")
+ assert.falsy(package.loaded["impatient"])
+ end)
+
+ a.it("should not be reading default neovim directories in the home directoies", function()
+ local rtp_list = vim.opt.rtp:get()
+ assert.falsy(vim.tbl_contains(rtp_list, vim.fn.stdpath "config"))
+ end)
+
+ a.it("should be able to read lunarvim directories", function()
+ local rtp_list = vim.opt.rtp:get()
+ assert.truthy(vim.tbl_contains(rtp_list, lvim_runtime_path .. "/lvim"))
+ assert.truthy(vim.tbl_contains(rtp_list, lvim_config_path))
+ end)
+
+ a.it("should be able to run treesitter without errors", function()
+ assert.truthy(vim.treesitter.highlighter.active)
+ end)
+end)
diff --git a/tests/lsp_spec.lua b/tests/lsp_spec.lua
new file mode 100644
index 00000000..9bd7b96c
--- /dev/null
+++ b/tests/lsp_spec.lua
@@ -0,0 +1,97 @@
+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.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)