diff --git a/.busted b/.busted deleted file mode 100644 index 3b51f1ba..00000000 --- a/.busted +++ /dev/null @@ -1,17 +0,0 @@ -return { - _all = { - coverage = false, - lua = "./test/nvim-shim", - }, - default = { - verbose = true, - }, - unit = { - ROOT = { "./test/unit/" }, - verbose = true, - }, - -- e2e = { - -- ROOT = {'./test/e2e/'}, - -- pattern = '', -- No fancy names for E2E tests - -- }, -} diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index f99bd336..9fcffa91 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -14,18 +14,13 @@ jobs: with: neovim: true version: ${{ matrix.version }} - - name: Set up pkgx with LuaJIT and LuaRocks - uses: pkgxdev/setup@v1 - with: - +: luajit.org@2 luarocks.org - - # Install into LuaRocks (not Neovim) - - name: Install neotest - run: luarocks --lua-dir=$HOME/.pkgx/luajit.org/v2 --lua-version=5.1 install neotest - - name: Install nvim-treesitter - run: luarocks --lua-dir=$HOME/.pkgx/luajit.org/v2 --lua-version=5.1 install nvim-treesitter - - name: Install busted - run: luarocks --lua-dir=$HOME/.pkgx/luajit.org/v2 --lua-version=5.1 install busted - + - name: Neovim version + run: nvim --version + - name: Install dependencies + run: ./test/install.sh + - name: Run Init + run: nvim --headless -c 'lua require("test/minimal_init.lua")' + - name: Run TSInstall + run: nvim --headless -c 'TSInstallSync lua go | quit' - name: Run tests - run: make unit-test + run: nvim --headless -c "lua PlenaryBustedDirectory test {minimal_init = 'test/minimal_init.lua', sequential = true}" -c "qa!" diff --git a/.gitignore b/.gitignore index a76deee4..f0d4bc08 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1 @@ -test/xdg +.tests diff --git a/.luarc.json b/.luarc.json deleted file mode 100644 index 8c8662d5..00000000 --- a/.luarc.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "$schema": "https://raw.githubusercontent.com/LuaLS/vscode-lua/master/setting/schema.json", - "workspace.ignoreDir": ["test/xdg"] -} diff --git a/.nvimrc b/.nvimrc deleted file mode 100644 index c7a30dc2..00000000 --- a/.nvimrc +++ /dev/null @@ -1,2 +0,0 @@ -" Use the custom shim as the busted binary for testing -let g:bustedprg='./test/busted' diff --git a/.pkgx.yml b/.pkgx.yml deleted file mode 100644 index 999e0ca6..00000000 --- a/.pkgx.yml +++ /dev/null @@ -1,3 +0,0 @@ -dependencies: - - luajit.org - - luarocks.org diff --git a/Makefile b/Makefile deleted file mode 100644 index 5950d871..00000000 --- a/Makefile +++ /dev/null @@ -1,15 +0,0 @@ -.PHONY: check unit-test e2e-test clean - -check: unit-test e2e-test - -unit-test: - @./test/busted --run unit - -# e2e-test: -# @./test/busted --run e2e - -clean: - @rm -rf test/xdg/local/state/nvim/* - @rm -rf test/xdg/local/share/nvim/site/pack/testing/start/nvim-treesitter/parser/* - @# The symlink might have been left over from a failed test run - @rm -rf test/xdg/local/share/nvim/site/pack/self-* diff --git a/test/busted b/test/busted deleted file mode 100755 index f1b7ce3d..00000000 --- a/test/busted +++ /dev/null @@ -1,34 +0,0 @@ -#!/bin/sh -# SPDX-License-Identifier: Unlicense - -# This is free and unencumbered software released into the public domain. -# -# Anyone is free to copy, modify, publish, use, compile, sell, or distribute -# this software, either in source code form or as a compiled binary, for any -# purpose, commercial or non-commercial, and by any means. -# -# In jurisdictions that recognize copyright laws, the author or authors of -# this software dedicate any and all copyright interest in the software to -# the public domain. We make this dedication for the benefit of the public -# at large and to the detriment of our heirs and successors. We intend this -# dedication to be an overt act of relinquishment in perpetuity of all -# present and future rights to this software under copyright law. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -# THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# -# For more information, please refer to - -# A shim which acts as a command-line interface adapter for the busted test -# framework. If busted is installed using LuaRocks we cannot invoke it -# directly, but some tools might want to do so. This thin adapter can be used -# as a drop-in replacement for the busted executable. - -export LUA_PATH="./lua/?.lua;;" -export LUA_CPATH="./lua/?.so;;" - -eval $(luarocks path --lua-version 5.1 --bin) && $HOME/.luarocks/bin/busted $@ diff --git a/test/install.sh b/test/install.sh new file mode 100755 index 00000000..7796059c --- /dev/null +++ b/test/install.sh @@ -0,0 +1,32 @@ +#!/bin/bash +set -e + +# This script is executed via tests/minimal_init.lua + +GITHUB="https://github.com" +GITHUB_PLENARY="$GITHUB/nvim-lua/plenary.nvim" +GITHUB_TELESCOPE="$GITHUB/nvim-telescope/telescope.nvim" +GITHUB_LSPCONFIG="$GITHUB/neovim/nvim-lspconfig" +GITHUB_NIO="$GITHUB/nvim-neotest/nvim-nio" +GITHUB_NEOTEST="$GITHUB/nvim-neotest/neotest" + +SCRIPT_FILE=$(readlink -f "${BASH_SOURCE[0]}") +REPO_DIR=$(dirname "$(dirname "$SCRIPT_FILE")") + +TEST_ALL_DIR="$REPO_DIR/.tests/all/site/pack/deps/start" + +clone() { + repo=$1 + dest=$2 + if [ ! -d "$dest" ]; then + git clone --depth 1 "$repo" "$dest" + fi +} + +# Just for the main minimal_init.lua for neotest +mkdir -p $TEST_ALL_DIR +clone $GITHUB_PLENARY "$TEST_ALL_DIR/plenary.nvim" +clone $GITHUB_LSPCONFIG "$TEST_ALL_DIR/lspconfig.nvim" +clone $GITHUB_TELESCOPE "$TEST_ALL_DIR/telescope.nvim" +clone $GITHUB_NIO "$TEST_ALL_DIR/nvim-nio" +clone $GITHUB_NEOTEST "$TEST_ALL_DIR/neotest" diff --git a/test/minimal_init.lua b/test/minimal_init.lua new file mode 100644 index 00000000..4faf662a --- /dev/null +++ b/test/minimal_init.lua @@ -0,0 +1,27 @@ +local M = {} + +-- function M.root(root) +-- local f = debug.getinfo(1, "S").source:sub(2) +-- return vim.fn.fnamemodify(f, ":p:h:h") .. "/" .. (root or "") +-- end + +function M.init() + vim.cmd([[set runtimepath=$VIMRUNTIME]]) + vim.opt.runtimepath:append(".") + vim.opt.swapfile = false + + vim.opt.packpath = { + ".tests/all/site", + } + + vim.cmd([[ + packadd plenary.nvim + packadd neotest + packadd nvim-nio + ]]) +end + +-- Ensure the required Neovim plugins are installed/cloned +os.execute("test/install.sh") + +M.init() diff --git a/test/nvim-shim b/test/nvim-shim deleted file mode 100755 index d53b4cf1..00000000 --- a/test/nvim-shim +++ /dev/null @@ -1,71 +0,0 @@ -#!/bin/sh -# SPDX-License-Identifier: Unlicense - -# This is free and unencumbered software released into the public domain. -# -# Anyone is free to copy, modify, publish, use, compile, sell, or distribute -# this software, either in source code form or as a compiled binary, for any -# purpose, commercial or non-commercial, and by any means. -# -# In jurisdictions that recognize copyright laws, the author or authors of -# this software dedicate any and all copyright interest in the software to -# the public domain. We make this dedication for the benefit of the public -# at large and to the detriment of our heirs and successors. We intend this -# dedication to be an overt act of relinquishment in perpetuity of all -# present and future rights to this software under copyright law. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -# THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. -# -# For more information, please refer to - - -# A shim which acts as a command-line interface adapter to use Neovim as a Lua -# interpreter. - -# Set custom XDG base directory paths to isolate the test Neovim from the -# user's own configuration and data files. -export XDG_CONFIG_HOME='test/xdg/config/' -export XDG_STATE_HOME='test/xdg/local/state/' -export XDG_DATA_HOME='test/xdg/local/share/' - -# Handle Lua command-line arguments; not all options are supported -while getopts 'ilEve:' opt; do - case $opt in - e) lua_expr=$OPTARG;; - v) nvim --version; exit;; - i | l | E) echo "Option '$opt' not supported by shim"; exit 1;; - esac -done - - -# We need to add this plugin to the custom configuration. The easiest way is -# to create a symlink. Why not always have a symlink in the project? The Lua -# language server will search for Lua files in every directory, so if it enters -# the symlink it will be trapped in a cycle. What we do instead is create the -# symlink only for the duration of a test session and remove it again -# afterwards. - -# We need separate symlinks if we want to run different tasks in parallel. -# Otherwise the one the finishes first would delete the symlink from underneath -# the one that is still running. -uuid=$(uuidgen) -mkdir -p ${XDG_DATA_HOME}/nvim/site/pack/self-${uuid}/start/ -ln -fs $(pwd) ${XDG_DATA_HOME}/nvim/site/pack/self-${uuid}/start/ - -if [ -n "$lua_expr" ]; then - nvim --headless -c "lua $lua_expr" -c 'quitall!' -else - # We have to explicitly enable plugins, see ':h -l' - nvim --cmd 'set loadplugins' -l $@ -fi - -exit_code=$? - -rm -rf ${XDG_DATA_HOME}/nvim/site/pack/self-${uuid}/ - -exit $exit_code