tests/lazyloading/lz-n: reduce repetition

This commit is contained in:
Austin Horstman 2024-12-08 14:03:16 -06:00
parent 76b567b43c
commit 26f1daa47e
No known key found for this signature in database

View file

@ -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 =