Merge pull request #278 from nix-community/nixos-facter
add nixos-facter to installer
This commit is contained in:
commit
9e7834cc3c
6 changed files with 129 additions and 27 deletions
|
@ -18,11 +18,11 @@
|
||||||
},
|
},
|
||||||
"nixos-unstable": {
|
"nixos-unstable": {
|
||||||
"locked": {
|
"locked": {
|
||||||
"lastModified": 1725448034,
|
"lastModified": 1726590405,
|
||||||
"narHash": "sha256-YWbVeDERbIHAEQCtDtUunHYUNH31ReIdJIP8juXfdpM=",
|
"narHash": "sha256-mDxHh5vQyBTjNKkp+l1/WL6cEDOjxyEQxv2c+dnw8Fg=",
|
||||||
"owner": "NixOS",
|
"owner": "NixOS",
|
||||||
"repo": "nixpkgs",
|
"repo": "nixpkgs",
|
||||||
"rev": "9b40840066f93767bb528810ea7dc9caacd8997f",
|
"rev": "513193ba87b70f4d4e4d892f43fac30af286861b",
|
||||||
"type": "github"
|
"type": "github"
|
||||||
},
|
},
|
||||||
"original": {
|
"original": {
|
||||||
|
|
28
flake.nix
28
flake.nix
|
@ -58,23 +58,31 @@
|
||||||
packages = forAllSystems (system: nixos-unstable.lib.mapAttrs' (n: nixos-unstable.lib.nameValuePair "package-${n}") self.packages.${system});
|
packages = forAllSystems (system: nixos-unstable.lib.mapAttrs' (n: nixos-unstable.lib.nameValuePair "package-${n}") self.packages.${system});
|
||||||
checks =
|
checks =
|
||||||
let
|
let
|
||||||
pkgs = nixos-unstable.legacyPackages.x86_64-linux;
|
pkgsUnstable = nixos-unstable.legacyPackages.x86_64-linux;
|
||||||
|
pkgsStable = nixos-stable.legacyPackages.x86_64-linux;
|
||||||
|
|
||||||
|
bootTests = pkgs: channel: suffix: pkgs.lib.mapAttrs' (name: pkgs.lib.nameValuePair "${name}${suffix}") (pkgs.callPackages ./nix/image-installer/tests.nix {
|
||||||
|
nixpkgs = channel;
|
||||||
|
nixosModules = self.nixosModules;
|
||||||
|
});
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
kexec-installer-unstable = pkgs.callPackage ./nix/kexec-installer/test.nix {
|
kexec-installer-unstable = pkgsUnstable.callPackage ./nix/kexec-installer/test.nix {
|
||||||
kexecTarball = self.packages.x86_64-linux.kexec-installer-nixos-unstable-noninteractive;
|
kexecTarball = self.packages.x86_64-linux.kexec-installer-nixos-unstable-noninteractive;
|
||||||
};
|
};
|
||||||
shellcheck = pkgs.runCommand "shellcheck"
|
|
||||||
{
|
|
||||||
nativeBuildInputs = [ pkgs.shellcheck ];
|
|
||||||
} ''
|
|
||||||
shellcheck ${(pkgs.nixos [self.nixosModules.kexec-installer]).config.system.build.kexecRun}
|
|
||||||
touch $out
|
|
||||||
'';
|
|
||||||
kexec-installer-stable = nixos-stable.legacyPackages.x86_64-linux.callPackage ./nix/kexec-installer/test.nix {
|
kexec-installer-stable = nixos-stable.legacyPackages.x86_64-linux.callPackage ./nix/kexec-installer/test.nix {
|
||||||
kexecTarball = self.packages.x86_64-linux.kexec-installer-nixos-stable-noninteractive;
|
kexecTarball = self.packages.x86_64-linux.kexec-installer-nixos-stable-noninteractive;
|
||||||
};
|
};
|
||||||
};
|
shellcheck = pkgsUnstable.runCommand "shellcheck"
|
||||||
|
{
|
||||||
|
nativeBuildInputs = [ pkgsUnstable.shellcheck ];
|
||||||
|
} ''
|
||||||
|
shellcheck ${(pkgsUnstable.nixos [self.nixosModules.kexec-installer]).config.system.build.kexecRun}
|
||||||
|
touch $out
|
||||||
|
'';
|
||||||
|
} // (bootTests pkgsUnstable nixos-unstable "-nixos-unstable")
|
||||||
|
// (bootTests pkgsStable nixos-stable "-nixos-stable");
|
||||||
in
|
in
|
||||||
nixos-unstable.lib.recursiveUpdate packages { x86_64-linux = checks; };
|
nixos-unstable.lib.recursiveUpdate packages { x86_64-linux = checks; };
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
builds:
|
|
||||||
include:
|
|
||||||
- '*.x86_64-linux.*'
|
|
||||||
- '*.aarch64-linux.*'
|
|
||||||
- nixosConfigurations.*
|
|
105
nix/image-installer/tests.nix
Normal file
105
nix/image-installer/tests.nix
Normal file
|
@ -0,0 +1,105 @@
|
||||||
|
{
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
nixpkgs,
|
||||||
|
nixos,
|
||||||
|
nixosModules,
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
testConfig = (
|
||||||
|
nixos [
|
||||||
|
(
|
||||||
|
{ modulesPath, ... }:
|
||||||
|
{
|
||||||
|
imports = [
|
||||||
|
nixosModules.image-installer
|
||||||
|
"${modulesPath}/testing/test-instrumentation.nix"
|
||||||
|
];
|
||||||
|
}
|
||||||
|
)
|
||||||
|
]
|
||||||
|
);
|
||||||
|
iso = testConfig.config.system.build.isoImage;
|
||||||
|
mkStartCommand =
|
||||||
|
{
|
||||||
|
memory ? 2048,
|
||||||
|
cdrom ? null,
|
||||||
|
usb ? null,
|
||||||
|
uefi ? false,
|
||||||
|
extraFlags ? [ ],
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
qemu-common = import (nixpkgs + "/nixos/lib/qemu-common.nix") { inherit lib pkgs; };
|
||||||
|
qemu = qemu-common.qemuBinary pkgs.qemu_test;
|
||||||
|
|
||||||
|
flags =
|
||||||
|
[
|
||||||
|
"-m"
|
||||||
|
(toString memory)
|
||||||
|
"-netdev"
|
||||||
|
"user,id=net0"
|
||||||
|
"-device"
|
||||||
|
"virtio-net-pci,netdev=net0"
|
||||||
|
]
|
||||||
|
++ lib.optionals (cdrom != null) [
|
||||||
|
"-cdrom"
|
||||||
|
cdrom
|
||||||
|
]
|
||||||
|
++ lib.optionals (usb != null) [
|
||||||
|
"-device"
|
||||||
|
"usb-ehci"
|
||||||
|
"-drive"
|
||||||
|
"id=usbdisk,file=${usb},if=none,readonly"
|
||||||
|
"-device"
|
||||||
|
"usb-storage,drive=usbdisk"
|
||||||
|
]
|
||||||
|
++ lib.optionals uefi [
|
||||||
|
"-drive"
|
||||||
|
"if=pflash,format=raw,unit=0,readonly=on,file=${pkgs.OVMF.firmware}"
|
||||||
|
"-drive"
|
||||||
|
"if=pflash,format=raw,unit=1,readonly=on,file=${pkgs.OVMF.variables}"
|
||||||
|
]
|
||||||
|
++ extraFlags;
|
||||||
|
|
||||||
|
flagsStr = lib.concatStringsSep " " flags;
|
||||||
|
in
|
||||||
|
"${qemu} ${flagsStr}";
|
||||||
|
|
||||||
|
makeBootTest =
|
||||||
|
name: config:
|
||||||
|
let
|
||||||
|
startCommand = mkStartCommand config;
|
||||||
|
in
|
||||||
|
pkgs.testers.runNixOSTest {
|
||||||
|
name = "boot-${name}";
|
||||||
|
nodes = { };
|
||||||
|
testScript = ''
|
||||||
|
machine = create_machine("${startCommand}")
|
||||||
|
machine.start()
|
||||||
|
machine.wait_for_unit("multi-user.target")
|
||||||
|
machine.succeed("nix store verify --no-trust -r --option experimental-features nix-command /run/current-system")
|
||||||
|
|
||||||
|
machine.shutdown()
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
in
|
||||||
|
{
|
||||||
|
uefi-cdrom = makeBootTest "uefi-cdrom" {
|
||||||
|
uefi = true;
|
||||||
|
cdrom = "${iso}/iso/nixos-installer-${pkgs.hostPlatform.system}.iso";
|
||||||
|
};
|
||||||
|
|
||||||
|
uefi-usb = makeBootTest "uefi-usb" {
|
||||||
|
uefi = true;
|
||||||
|
usb = "${iso}/iso/nixos-installer-${pkgs.hostPlatform.system}.iso";
|
||||||
|
};
|
||||||
|
|
||||||
|
bios-cdrom = makeBootTest "bios-cdrom" {
|
||||||
|
cdrom = "${iso}/iso/nixos-installer-${pkgs.hostPlatform.system}.iso";
|
||||||
|
};
|
||||||
|
|
||||||
|
bios-usb = makeBootTest "bios-usb" {
|
||||||
|
usb = "${iso}/iso/nixos-installer-${pkgs.hostPlatform.system}.iso";
|
||||||
|
};
|
||||||
|
}
|
|
@ -30,7 +30,8 @@
|
||||||
pkgs.jq
|
pkgs.jq
|
||||||
# for copying extra files of nixos-anywhere
|
# for copying extra files of nixos-anywhere
|
||||||
pkgs.rsync
|
pkgs.rsync
|
||||||
];
|
# alternative to nixos-generate-config
|
||||||
|
] ++ lib.optional (pkgs.lib.versionAtLeast lib.version "24.11") pkgs.nixos-facter;
|
||||||
|
|
||||||
imports = [
|
imports = [
|
||||||
./nix-settings.nix
|
./nix-settings.nix
|
||||||
|
|
|
@ -3,14 +3,7 @@
|
||||||
, kexecTarball
|
, kexecTarball
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
pkgs.testers.runNixOSTest {
|
||||||
makeTest = import (pkgs.path + "/nixos/tests/make-test-python.nix");
|
|
||||||
makeTest' = args: makeTest args {
|
|
||||||
inherit pkgs;
|
|
||||||
inherit (pkgs) system;
|
|
||||||
};
|
|
||||||
in
|
|
||||||
makeTest' {
|
|
||||||
name = "kexec-installer";
|
name = "kexec-installer";
|
||||||
meta = with pkgs.lib.maintainers; {
|
meta = with pkgs.lib.maintainers; {
|
||||||
maintainers = [ mic92 ];
|
maintainers = [ mic92 ];
|
||||||
|
|
Loading…
Reference in a new issue