mirror of
https://github.com/nix-community/nixvim.git
synced 2025-06-24 09:48:42 +02:00
tests/lazyloading/lz-n: reduce repetition
This commit is contained in:
parent
76b567b43c
commit
26f1daa47e
1 changed files with 103 additions and 122 deletions
|
@ -1,3 +1,13 @@
|
||||||
|
let
|
||||||
|
getFirstLznPlugin =
|
||||||
|
config:
|
||||||
|
let
|
||||||
|
inherit (config.plugins.lz-n) plugins;
|
||||||
|
in
|
||||||
|
if plugins == [ ] then null else builtins.head plugins;
|
||||||
|
|
||||||
|
getPluginKeys = plugin: if plugin != null && builtins.isList plugin.keys then plugin.keys else [ ];
|
||||||
|
in
|
||||||
{
|
{
|
||||||
lazy-load-neovim-plugin-configured =
|
lazy-load-neovim-plugin-configured =
|
||||||
{ config, lib, ... }:
|
{ config, lib, ... }:
|
||||||
|
@ -24,31 +34,26 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
assertions = [
|
assertions =
|
||||||
{
|
let
|
||||||
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
plugin = getFirstLznPlugin config;
|
||||||
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
keys = getPluginKeys plugin;
|
||||||
}
|
in
|
||||||
{
|
[
|
||||||
assertion =
|
{
|
||||||
let
|
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
||||||
inherit (config.plugins.lz-n) plugins;
|
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
||||||
plugin = if plugins == [ ] then null else builtins.head plugins;
|
}
|
||||||
keys = if plugin != null && builtins.isList plugin.keys then plugin.keys else [ ];
|
{
|
||||||
in
|
assertion = (builtins.length keys) == 1;
|
||||||
(builtins.length keys) == 1;
|
message = "`lz-n.plugins[0].keys` should have contained a configuration.";
|
||||||
message = "`lz-n.plugins[0].keys` should have contained a configuration.";
|
}
|
||||||
}
|
{
|
||||||
{
|
assertion =
|
||||||
assertion =
|
plugin != null && lib.hasInfix config.plugins.neotest.luaConfig.content plugin.after.__raw;
|
||||||
let
|
message = "`lz-n.plugins[0].after` should have contained `neotest` lua content.";
|
||||||
inherit (config.plugins.lz-n) plugins;
|
}
|
||||||
plugin = if plugins == [ ] then null else builtins.head plugins;
|
];
|
||||||
in
|
|
||||||
plugin != null && lib.hasInfix config.plugins.neotest.luaConfig.content plugin.after.__raw;
|
|
||||||
message = "`lz-n.plugins[0].after` should have contained `neotest` lua content.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
lazy-load-lz-n-configured =
|
lazy-load-lz-n-configured =
|
||||||
|
@ -104,47 +109,31 @@
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
assertions = [
|
assertions =
|
||||||
{
|
let
|
||||||
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
plugin = getFirstLznPlugin config;
|
||||||
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
keys = getPluginKeys plugin;
|
||||||
}
|
cmd = plugin.cmd or null;
|
||||||
{
|
cmd' = lib.optionals (builtins.isList cmd) cmd;
|
||||||
assertion =
|
in
|
||||||
let
|
[
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
{
|
||||||
keys = if builtins.isList plugin.keys then plugin.keys else [ ];
|
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
||||||
in
|
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
||||||
(builtins.length keys) == 4;
|
}
|
||||||
message =
|
{
|
||||||
let
|
assertion = (builtins.length keys) == 4;
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
message = "`lz-n.plugins[0].keys` should have contained 4 key configurations, but contained ${builtins.toJSON plugin.keys}";
|
||||||
in
|
}
|
||||||
"`lz-n.plugins[0].keys` should have contained 4 key configurations, but contained ${builtins.toJSON plugin.keys}";
|
{
|
||||||
}
|
assertion = (builtins.length cmd') == 4;
|
||||||
{
|
message = "`lz-n.plugins[0].cmd` should have contained 4 cmd configurations, but contained ${builtins.toJSON plugin.cmd}";
|
||||||
assertion =
|
}
|
||||||
let
|
{
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
assertion = lib.hasInfix config.plugins.codesnap.luaConfig.content plugin.after.__raw;
|
||||||
cmd = plugin.cmd or null;
|
message = "`lz-n.plugins[0].after` should have contained `codesnap` lua content.";
|
||||||
cmd' = lib.optionals (builtins.isList cmd) cmd;
|
}
|
||||||
in
|
];
|
||||||
(builtins.length cmd') == 4;
|
|
||||||
message =
|
|
||||||
let
|
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
|
||||||
in
|
|
||||||
"`lz-n.plugins[0].cmd` should have contained 4 cmd configurations, but contained ${builtins.toJSON plugin.cmd}";
|
|
||||||
}
|
|
||||||
{
|
|
||||||
assertion =
|
|
||||||
let
|
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
|
||||||
in
|
|
||||||
lib.hasInfix config.plugins.codesnap.luaConfig.content plugin.after.__raw;
|
|
||||||
message = "`lz-n.plugins[0].after` should have contained `codesnap` lua content.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
dont-lazy-load-colorscheme-automatically =
|
dont-lazy-load-colorscheme-automatically =
|
||||||
|
@ -201,32 +190,24 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
assertions = [
|
assertions =
|
||||||
{
|
let
|
||||||
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
plugin = getFirstLznPlugin config;
|
||||||
message = "`lz-n.plugins` should have contained no plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
in
|
||||||
}
|
[
|
||||||
{
|
{
|
||||||
assertion =
|
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
||||||
let
|
message = "`lz-n.plugins` should have contained no plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
}
|
||||||
in
|
{
|
||||||
plugin.colorscheme == "catppuccin";
|
assertion = plugin.colorscheme == "catppuccin";
|
||||||
message =
|
message = "`lz-n.plugins[0].colorscheme` should have been `catppuccin`, but contained ${builtins.toJSON plugin.colorscheme}";
|
||||||
let
|
}
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
{
|
||||||
in
|
assertion = lib.hasInfix config.colorschemes.catppuccin.luaConfig.content plugin.after.__raw;
|
||||||
"`lz-n.plugins[0].colorscheme` should have been `catppuccin`, but contained ${builtins.toJSON plugin.colorscheme}";
|
message = "`lz-n.plugins[0].after` should have contained `catppuccin` lua content.";
|
||||||
}
|
}
|
||||||
{
|
];
|
||||||
assertion =
|
|
||||||
let
|
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
|
||||||
in
|
|
||||||
lib.hasInfix config.colorschemes.catppuccin.luaConfig.content plugin.after.__raw;
|
|
||||||
message = "`lz-n.plugins[0].after` should have contained `catppuccin` lua content.";
|
|
||||||
}
|
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
lazy-load-enabled-automatically =
|
lazy-load-enabled-automatically =
|
||||||
|
@ -253,22 +234,21 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
assertions = [
|
assertions =
|
||||||
{
|
let
|
||||||
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
plugin = getFirstLznPlugin config;
|
||||||
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
keys = getPluginKeys plugin;
|
||||||
}
|
in
|
||||||
{
|
[
|
||||||
assertion =
|
{
|
||||||
let
|
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
||||||
inherit (config.plugins.lz-n) plugins;
|
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
||||||
plugin = if plugins == [ ] then null else builtins.head plugins;
|
}
|
||||||
keys = if plugin != null && builtins.isList plugin.keys then plugin.keys else [ ];
|
{
|
||||||
in
|
assertion = (builtins.length keys) == 1;
|
||||||
(builtins.length keys) == 1;
|
message = "`lz-n.plugins[0].keys` should have contained a configuration.";
|
||||||
message = "`lz-n.plugins[0].keys` should have contained a configuration.";
|
}
|
||||||
}
|
];
|
||||||
];
|
|
||||||
};
|
};
|
||||||
|
|
||||||
wrap-functionless-luaConfig =
|
wrap-functionless-luaConfig =
|
||||||
|
@ -290,20 +270,21 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
assertions = [
|
assertions =
|
||||||
{
|
let
|
||||||
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
plugin = getFirstLznPlugin config;
|
||||||
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
in
|
||||||
}
|
[
|
||||||
{
|
{
|
||||||
assertion =
|
assertion = (builtins.length config.plugins.lz-n.plugins) == 1;
|
||||||
let
|
message = "`lz-n.plugins` should have contained a single plugin configuration, but contained ${builtins.toJSON config.plugins.lz-n.plugins}";
|
||||||
plugin = builtins.head config.plugins.lz-n.plugins;
|
}
|
||||||
in
|
{
|
||||||
plugin.after.__raw == "function()\n " + config.plugins.telescope.luaConfig.content + " \nend";
|
assertion =
|
||||||
message = "`lz-n.plugins[0].after` should have contained a function wrapped `telescope` lua content.";
|
plugin.after.__raw == "function()\n " + config.plugins.telescope.luaConfig.content + " \nend";
|
||||||
}
|
message = "`lz-n.plugins[0].after` should have contained a function wrapped `telescope` lua content.";
|
||||||
];
|
}
|
||||||
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
use-provided-raw-after =
|
use-provided-raw-after =
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue