mirror of
https://github.com/donovanglover/nix-config.git
synced 2025-01-25 07:08:38 +01:00
95b10ec3ef
Now that I've figured out how to dynamically import modules and use those modules as outputs, the next step is to ensure that these modules work as intended when being used by end users. NixOS offers a built-in testing solution that enables us to conveniently spin up virtual machines with a given configuration, then verify their correctness through python scripting. The lib.nix file in particular is based on Jörg Thalheim's very useful blog post that explains how to use the built-in testing functionality with Nix flakes, which isn't covered in official documentation. See: https://blog.thalheim.io/2023/01/08/how-to-use-nixos-testing-framework-with-flakes/
16 lines
339 B
Nix
16 lines
339 B
Nix
# TODO: Ensure that neovim config works without errors on startup
|
|
(import ./lib.nix) {
|
|
name = "neovim";
|
|
|
|
nodes.machine = { self, pkgs, ... }: {
|
|
imports = with self.nixosModules; [
|
|
neovim
|
|
];
|
|
};
|
|
|
|
testScript = /* python */ ''
|
|
output = machine.succeed("echo 'Hello world'")
|
|
assert "Hello world" in output
|
|
'';
|
|
}
|