Merge pull request 'flake VM: add additional /dev/vdb disk with empty ext4 FS' (#102) from vm-disk into master

Reviewed-on: https://git.selfprivacy.org/SelfPrivacy/selfprivacy-rest-api/pulls/102
Reviewed-by: Inex Code <inex.code@selfprivacy.org>
Reviewed-by: houkime <houkime@protonmail.com>
This commit is contained in:
houkime 2024-03-15 11:42:37 +02:00
commit d464f3b82d

View file

@ -40,7 +40,7 @@
[testing in NixOS VM] [testing in NixOS VM]
nixos-test-driver - run an interactive NixOS VM with with all dependencies nixos-test-driver - run an interactive NixOS VM with all dependencies included and 2 disk volumes
pytest-vm - run pytest in an ephemeral NixOS VM with Redis, accepting pytest arguments pytest-vm - run pytest in an ephemeral NixOS VM with Redis, accepting pytest arguments
''; '';
in in
@ -78,7 +78,7 @@
}; };
nixosModules.default = nixosModules.default =
import ./nixos/module.nix self.packages.${system}.default; import ./nixos/module.nix self.packages.${system}.default;
devShells.${system}.default = pkgs.mkShell { devShells.${system}.default = pkgs.mkShellNoCC {
name = "SP API dev shell"; name = "SP API dev shell";
packages = with pkgs; [ packages = with pkgs; [
nixpkgs-fmt nixpkgs-fmt
@ -113,10 +113,22 @@
"black --check ${self.outPath} > $out"; "black --check ${self.outPath} > $out";
default = default =
pkgs.testers.runNixOSTest { pkgs.testers.runNixOSTest {
imports = [{
name = "default"; name = "default";
nodes.machine = { lib, pkgs, ... }: { nodes.machine = { lib, pkgs, ... }: {
imports = [{ # 2 additional disks (1024 MiB and 200 MiB) with empty ext4 FS
virtualisation.emptyDiskImages = [ 1024 200 ];
virtualisation.fileSystems."/volumes/vdb" = {
autoFormat = true;
device = "/dev/vdb"; # this name is chosen by QEMU, not here
fsType = "ext4";
noCheck = true;
};
virtualisation.fileSystems."/volumes/vdc" = {
autoFormat = true;
device = "/dev/vdc"; # this name is chosen by QEMU, not here
fsType = "ext4";
noCheck = true;
};
boot.consoleLogLevel = lib.mkForce 3; boot.consoleLogLevel = lib.mkForce 3;
documentation.enable = false; documentation.enable = false;
services.journald.extraConfig = lib.mkForce ""; services.journald.extraConfig = lib.mkForce "";
@ -135,7 +147,6 @@
environment.variables.TEST_MODE = "true"; environment.variables.TEST_MODE = "true";
systemd.tmpfiles.settings.src.${vmtest-src-dir}.L.argument = systemd.tmpfiles.settings.src.${vmtest-src-dir}.L.argument =
self.outPath; self.outPath;
}];
}; };
testScript = '' testScript = ''
start_all() start_all()
@ -144,7 +155,6 @@
machine.copy_from_vm("coverage.xml", ".") machine.copy_from_vm("coverage.xml", ".")
machine.succeed("coverage report >&2") machine.succeed("coverage report >&2")
''; '';
}];
}; };
}; };
}; };