nixos/tests/kernel-rust: test against 6.7 and testing (6.8rc1)
In #283893 we realized that not only 6.7, but also testing is affected. And with more stable kernels following, we'll probably want to test against all of them whether Rust support is working fine. As long as it's not the default at least, then we should probably move this to `kernel-generic`. Every kernel that's new enough to support `rust-out-of-tree-module` (and `linux_testing`) is part of this text matrix.
This commit is contained in:
parent
cff853ca15
commit
37ac24e2c7
@ -451,7 +451,7 @@ in {
|
|||||||
kerberos = handleTest ./kerberos/default.nix {};
|
kerberos = handleTest ./kerberos/default.nix {};
|
||||||
kernel-generic = handleTest ./kernel-generic.nix {};
|
kernel-generic = handleTest ./kernel-generic.nix {};
|
||||||
kernel-latest-ath-user-regd = handleTest ./kernel-latest-ath-user-regd.nix {};
|
kernel-latest-ath-user-regd = handleTest ./kernel-latest-ath-user-regd.nix {};
|
||||||
kernel-rust = runTestOn ["x86_64-linux"] ./kernel-rust.nix;
|
kernel-rust = handleTestOn ["x86_64-linux"] ./kernel-rust.nix {};
|
||||||
keter = handleTest ./keter.nix {};
|
keter = handleTest ./keter.nix {};
|
||||||
kexec = handleTest ./kexec.nix {};
|
kexec = handleTest ./kexec.nix {};
|
||||||
keycloak = discoverTests (import ./keycloak.nix);
|
keycloak = discoverTests (import ./keycloak.nix);
|
||||||
|
@ -1,30 +1,43 @@
|
|||||||
{ pkgs, ... }: {
|
{ system ? builtins.currentSystem
|
||||||
name = "kernel-rust";
|
, config ? { }
|
||||||
meta = with pkgs.lib.maintainers; {
|
, pkgs ? import ../.. { inherit system config; }
|
||||||
maintainers = [ blitz ];
|
}:
|
||||||
};
|
|
||||||
|
|
||||||
nodes.machine = { config, pkgs, ... }:
|
let
|
||||||
{
|
inherit (pkgs.lib) const filterAttrs mapAttrs;
|
||||||
boot.kernelPackages = pkgs.linuxPackages_testing;
|
|
||||||
|
|
||||||
boot.extraModulePackages = [
|
kernelRustTest = kernelPackages: import ./make-test-python.nix ({ lib, ... }: {
|
||||||
config.boot.kernelPackages.rust-out-of-tree-module
|
name = "kernel-rust";
|
||||||
];
|
meta.maintainers = with lib.maintainers; [ blitz ma27 ];
|
||||||
|
nodes.machine = { config, ... }: {
|
||||||
boot.kernelPatches = [
|
boot = {
|
||||||
{
|
inherit kernelPackages;
|
||||||
name = "Rust Support";
|
extraModulePackages = [ config.boot.kernelPackages.rust-out-of-tree-module ];
|
||||||
patch = null;
|
kernelPatches = [
|
||||||
features = {
|
{
|
||||||
rust = true;
|
name = "Rust Support";
|
||||||
};
|
patch = null;
|
||||||
}
|
features = {
|
||||||
];
|
rust = true;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
];
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
testScript = ''
|
||||||
|
machine.wait_for_unit("default.target")
|
||||||
|
machine.succeed("modprobe rust_out_of_tree")
|
||||||
|
'';
|
||||||
|
});
|
||||||
|
|
||||||
testScript = ''
|
kernels = {
|
||||||
machine.wait_for_unit("default.target")
|
inherit (pkgs.linuxKernel.packages) linux_testing;
|
||||||
machine.succeed("modprobe rust_out_of_tree")
|
}
|
||||||
'';
|
// filterAttrs
|
||||||
}
|
(const (x: let
|
||||||
|
inherit (builtins.tryEval (
|
||||||
|
x.rust-out-of-tree-module or null != null
|
||||||
|
)) success value;
|
||||||
|
in success && value))
|
||||||
|
pkgs.linuxKernel.vanillaPackages;
|
||||||
|
in mapAttrs (const kernelRustTest) kernels
|
||||||
|
Loading…
Reference in New Issue
Block a user