mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
feat: run test for all k8s versions
This commit is contained in:
parent
fde2d5557c
commit
0d68a401f0
3 changed files with 25 additions and 3 deletions
|
|
@ -1,17 +1,24 @@
|
|||
{ pkgs ? import <nixpkgs> {}
|
||||
, kubenix ? import ../. {inherit pkgs;}
|
||||
, lib ? kubenix.lib
|
||||
, k8sVersions ? ["1.7" "1.8" "1.9" "1.10" "1.11" "1.12" "1.13"]
|
||||
|
||||
# whether any testing error should throw an error
|
||||
, throwError ? true }:
|
||||
|
||||
with lib;
|
||||
|
||||
(evalModules {
|
||||
listToAttrs (map (version: let
|
||||
version' = replaceStrings ["."] ["_"] version;
|
||||
in nameValuePair "v${version'}" (evalModules {
|
||||
modules = [
|
||||
./modules/testing.nix
|
||||
|
||||
{
|
||||
imports = [kubenix.k8s kubenix.submodules];
|
||||
|
||||
kubernetes.version = version;
|
||||
|
||||
testing.throwError = throwError;
|
||||
testing.tests = [
|
||||
./k8s/simple.nix
|
||||
|
|
@ -20,6 +27,10 @@ with lib;
|
|||
./k8s/1.13/crd.nix
|
||||
./submodules/simple.nix
|
||||
];
|
||||
testing.defaults = ({kubenix, ...}: {
|
||||
imports = [kubenix.k8s];
|
||||
kubernetes.version = version;
|
||||
});
|
||||
}
|
||||
];
|
||||
args = {
|
||||
|
|
@ -28,4 +39,4 @@ with lib;
|
|||
specialArgs = {
|
||||
inherit kubenix;
|
||||
};
|
||||
}).config.testing.result
|
||||
}).config.testing.result) k8sVersions)
|
||||
|
|
|
|||
|
|
@ -12,6 +12,7 @@ in {
|
|||
test = {
|
||||
name = "k8s/crd";
|
||||
description = "Simple test tesing CRD";
|
||||
enable = builtins.compareVersions config.kubernetes.version "1.8" >= 0;
|
||||
assertions = [{
|
||||
message = "should have group set";
|
||||
assertion = cfg.spec.group == "stable.example.com";
|
||||
|
|
|
|||
|
|
@ -4,6 +4,7 @@ with lib;
|
|||
|
||||
let
|
||||
cfg = config.testing;
|
||||
parentConfig = config;
|
||||
in {
|
||||
options = {
|
||||
testing.throwError = mkOption {
|
||||
|
|
@ -12,13 +13,22 @@ in {
|
|||
default = true;
|
||||
};
|
||||
|
||||
testing.defaults = mkOption {
|
||||
description = "Testing defaults";
|
||||
type = types.coercedTo types.unspecified (value: [value]) (types.listOf types.unspecified);
|
||||
example = literalExample ''{config, ...}: {
|
||||
kubernetes.version = config.kubernetes.version;
|
||||
}'';
|
||||
default = [];
|
||||
};
|
||||
|
||||
testing.tests = mkOption {
|
||||
description = "Attribute set of test cases";
|
||||
default = [];
|
||||
type = types.listOf (types.coercedTo types.path (module: {inherit module;}) (types.submodule ({config, ...}: let
|
||||
modules = [config.module ./test.nix {
|
||||
config._module.args.test = config;
|
||||
}];
|
||||
}] ++ cfg.defaults;
|
||||
|
||||
test = (kubenix.evalKubernetesModules {
|
||||
check = false;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue