From 6a7e47b5af9dbc4bcc67f0d9915d7847a460160f Mon Sep 17 00:00:00 2001 From: Mika Vilpas Date: Sun, 30 Jun 2024 21:46:46 +0300 Subject: [PATCH] docs: update developer documentation with cypress tests etc (#148) --- .../{setting-up.md => developing.md} | 76 +++++++++++++------ documentation/plugin-manager.md | 1 - lazy-lock.json | 5 -- repro.lua | 1 - 4 files changed, 54 insertions(+), 29 deletions(-) rename documentation/for-developers/{setting-up.md => developing.md} (58%) delete mode 100644 lazy-lock.json diff --git a/documentation/for-developers/setting-up.md b/documentation/for-developers/developing.md similarity index 58% rename from documentation/for-developers/setting-up.md rename to documentation/for-developers/developing.md index be1241e1..5cf90cb4 100644 --- a/documentation/for-developers/setting-up.md +++ b/documentation/for-developers/developing.md @@ -1,4 +1,4 @@ -# Setting up your development environment +# Managing your development environment ## Install dependencies @@ -48,16 +48,41 @@ having trouble. - which allows fast LSP startup - which shows errors and diagnostics - which formats your code on save. - Configure it to use "stylua" using the instructions in its README file + Configure it to use stylua and prettier using the instructions in its README + file ## Running tests -### On the command line +This project has two types of tests + +1. unit tests. These are run with + [busted](https://github.com/lunarmodules/busted), a lua headless unit testing + framework. + - very fast to run + - can make assertions about lua level results + - more difficult to test high level features such as actual integration with + yazi +2. integration tests. These are run with [cypress](https://www.cypress.io/), an + interactive JavaScript browser testing framework. + - very visual + - slower to run but still very nice + - can make assertions about the actual UI and integration with yazi + - (optionally) can be run to drive the development of new features - this is + explained in depth in the + [philosophy of cypress](https://www.cypress.io/how-it-works) + +### 1. Unit tests + +![unit tests](https://github.com/mikavilpas/yazi.nvim/assets/300791/2cbc89e3-6933-4ccc-aadd-a92e42d78b37) ```sh # run all tests make test -# run tests marked with #focus +# NOTE: if you get an error about "busted.runner" not being found, you may need +# to run the following command: +eval $(luarocks path --no-bin --lua-version 5.1) + +# run only the tests marked with #focus in their name make test-focus ``` @@ -65,25 +90,35 @@ Recommended: use a file watcher to run tests automatically when files change. I like [watchexec 🦀](https://github.com/watchexec/watchexec), and I run it with `watchexec make test` -### (optional) Install test integration plugins for Neovim - -See the "Tools" section of +Optionally, you can install test integration plugins for Neovim to start the +tests from within Neovim. See the "Tools" section of [nvim-best-practices](https://github.com/nvim-neorocks/nvim-best-practices/tree/main?tab=readme-ov-file#hammer_and_wrench-tools-3) for some ideas. -## (optional) Install markdown related tooling +### 2. Integration tests -Markdown (`.md`) is used in the documentation. Various checks are performed on -all markdown files. +![integration tests](https://github.com/mikavilpas/yazi.nvim/assets/300791/817ccb3f-725b-4830-b5e0-d99a9b87ad26) -Install everything with `npm`: +Optional, but recommended: install +[Node Version Manager](https://github.com/nvm-sh/nvm) to install the correct +version of node. -- Install [Node Version Manager](https://github.com/nvm-sh/nvm), which is used - to choose the correct node version. +Run the following commands in the root of the project: ```sh +# activate the correct version of node nvm use -npm install +# or nvm install if you don't have the correct version installed + +# install the dependencies +npm run install:all +``` + +Next, start the integration test environment inside the +[integration-tests](../../integration-tests/) directory: + +```sh +npm run dev ``` ## Managing your development code @@ -105,23 +140,20 @@ code: -- this file is /Users/mikavilpas/.config/nvim/lua/plugins/my-file-manager.lua ---@type LazySpec return { - ---@type LazyPlugin { - -- uncomment the one you want to use when you want to use the stable version - -- stable, from Github - -- "mikavilpas/yazi.nvim", + "mikavilpas/yazi.nvim", -- if you want to use a specific branch, tag, or commit, you can specify it too - -- development, from local directory + -- for development, load from local directory dir = "~/git/yazi.nvim/", - dependencies = { - "nvim-lua/plenary.nvim", - }, -- (... Many more settings) } } ``` +4. When you finish your development session, you can switch back to the stable + version by commenting the `dir` setting from the plugin specification. + An example can be found [here](https://github.com/mikavilpas/dotfiles/blob/75e070ce6ac45b7ed8ac4c818f77abadbdd4b152/.config/nvim/lua/plugins/my-file-manager.lua?plain=1#L9). diff --git a/documentation/plugin-manager.md b/documentation/plugin-manager.md index cd4c8cc5..8e965e84 100644 --- a/documentation/plugin-manager.md +++ b/documentation/plugin-manager.md @@ -19,7 +19,6 @@ In your yazi.nvim configuration, add a new lazy.nvim plugin specification for return { { "mikavilpas/yazi.nvim", - dependencies = { "nvim-lua/plenary.nvim", }, keys = { { "", diff --git a/lazy-lock.json b/lazy-lock.json deleted file mode 100644 index 682a430c..00000000 --- a/lazy-lock.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "nvim-treesitter": { "branch": "master", "commit": "6d56c5f404d3b116bab167bc03993cfb0a83f8aa" }, - "plenary.nvim": { "branch": "master", "commit": "a3e3bc82a3f95c5ed0d7201546d5d2c19b20d683" }, - "tokyonight.nvim": { "branch": "main", "commit": "b9b494fa7f7bbf2fe0747b47fa290fb7a4eddcc7" } -} \ No newline at end of file diff --git a/repro.lua b/repro.lua index d088ca91..b8e47234 100644 --- a/repro.lua +++ b/repro.lua @@ -29,7 +29,6 @@ vim.g.mapleader = ' ' ---@type LazySpec local plugins = { 'folke/tokyonight.nvim', - { 'nvim-lua/plenary.nvim', lazy = true }, { 'mikavilpas/yazi.nvim', event = 'VeryLazy',