mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
feat: improve testing
This commit is contained in:
parent
ae431d1acc
commit
987c6e4173
6 changed files with 51 additions and 18 deletions
|
|
@ -1,2 +1,6 @@
|
||||||
language: nix
|
language: nix
|
||||||
script: nix build -f ./tests v1_13.testing.result --arg e2e false
|
script:
|
||||||
|
- nix-env -iA nixpkgs.jq
|
||||||
|
- nix build -f ./release.nix test-results --arg e2e false
|
||||||
|
- cat result | jq '.'
|
||||||
|
- nix eval -f ./release.nix --arg e2e false tests-check
|
||||||
|
|
|
||||||
|
|
@ -245,14 +245,14 @@ in {
|
||||||
|
|
||||||
testing.result = mkOption {
|
testing.result = mkOption {
|
||||||
description = "Testing result";
|
description = "Testing result";
|
||||||
type = types.package;
|
type = types.attrs;
|
||||||
default = pkgs.writeText "testing-report.json" (builtins.toJSON {
|
default = {
|
||||||
success = cfg.success;
|
success = cfg.success;
|
||||||
tests = map (test: {
|
tests = map (test: {
|
||||||
inherit (test) name description evaled success test;
|
inherit (test) name description evaled success test;
|
||||||
assertions = moduleToAttrs test.assertions;
|
assertions = moduleToAttrs test.assertions;
|
||||||
}) (filter (test: test.enable) cfg.tests);
|
}) (filter (test: test.enable) cfg.tests);
|
||||||
});
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
30
release.nix
30
release.nix
|
|
@ -1,4 +1,6 @@
|
||||||
{ pkgs ? import <nixpkgs> {} }:
|
{ pkgs ? import <nixpkgs> {}, lib ? pkgs.lib, e2e ? true, throwError ? true }:
|
||||||
|
|
||||||
|
with lib;
|
||||||
|
|
||||||
let
|
let
|
||||||
kubenix = import ./. { inherit pkgs; };
|
kubenix = import ./. { inherit pkgs; };
|
||||||
|
|
@ -15,7 +17,11 @@ let
|
||||||
inherit pkgs;
|
inherit pkgs;
|
||||||
inherit (pkgs) lib;
|
inherit (pkgs) lib;
|
||||||
};
|
};
|
||||||
in {
|
|
||||||
|
runK8STests = k8sVersion: pkgs.recurseIntoAttrs (import ./tests {
|
||||||
|
inherit pkgs lib kubenix k8sVersion e2e throwError;
|
||||||
|
});
|
||||||
|
in rec {
|
||||||
generate.k8s = pkgs.linkFarm "k8s-generated.nix" [{
|
generate.k8s = pkgs.linkFarm "k8s-generated.nix" [{
|
||||||
name = "v1.7.nix";
|
name = "v1.7.nix";
|
||||||
path = generateK8S "${pkgs.fetchFromGitHub {
|
path = generateK8S "${pkgs.fetchFromGitHub {
|
||||||
|
|
@ -79,9 +85,25 @@ in {
|
||||||
path = generateIstio;
|
path = generateIstio;
|
||||||
}];
|
}];
|
||||||
|
|
||||||
tests = import ./tests {
|
tests = {
|
||||||
inherit pkgs lib kubenix;
|
k8s-1_7 = runK8STests "1.7";
|
||||||
|
k8s-1_8 = runK8STests "1.8";
|
||||||
|
k8s-1_9 = runK8STests "1.9";
|
||||||
|
k8s-1_10 = runK8STests "1.10";
|
||||||
|
k8s-1_11 = runK8STests "1.11";
|
||||||
|
k8s-1_12 = runK8STests "1.12";
|
||||||
|
k8s-1_13 = runK8STests "1.13";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
test-results = pkgs.writeText "kubenix-test-result.json" (builtins.toJSON {
|
||||||
|
success = all (test: test.success) (attrValues tests);
|
||||||
|
results = mapAttrs (_: test: test.result) tests;
|
||||||
|
});
|
||||||
|
|
||||||
|
tests-check =
|
||||||
|
if !(all (test: test.success) (attrValues tests))
|
||||||
|
then throw "tests failed"
|
||||||
|
else true;
|
||||||
|
|
||||||
examples = import ./examples {};
|
examples = import ./examples {};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
{ pkgs ? import <nixpkgs> {}
|
{ pkgs ? import <nixpkgs> {}
|
||||||
, lib ? pkgs.lib
|
, lib ? pkgs.lib
|
||||||
, kubenix ? import ../. { inherit pkgs lib; }
|
, kubenix ? import ../. { inherit pkgs lib; }
|
||||||
, k8sVersions ? ["1.7" "1.8" "1.9" "1.10" "1.11" "1.12" "1.13"]
|
, k8sVersion ? "1.13"
|
||||||
|
|
||||||
# whether any testing error should throw an error
|
# whether any testing error should throw an error
|
||||||
, throwError ? true
|
, throwError ? true
|
||||||
|
|
@ -12,9 +12,7 @@ with lib;
|
||||||
let
|
let
|
||||||
images = pkgs.callPackage ./images.nix {};
|
images = pkgs.callPackage ./images.nix {};
|
||||||
|
|
||||||
tests = listToAttrs (map (version: let
|
test = (kubenix.evalModules {
|
||||||
version' = replaceStrings ["."] ["_"] version;
|
|
||||||
in nameValuePair "v${version'}" (kubenix.evalModules {
|
|
||||||
modules = [
|
modules = [
|
||||||
kubenix.modules.testing
|
kubenix.modules.testing
|
||||||
|
|
||||||
|
|
@ -37,7 +35,7 @@ let
|
||||||
];
|
];
|
||||||
testing.defaults = ({kubenix, ...}: {
|
testing.defaults = ({kubenix, ...}: {
|
||||||
imports = [kubenix.modules.k8s];
|
imports = [kubenix.modules.k8s];
|
||||||
kubernetes.version = version;
|
kubernetes.version = k8sVersion;
|
||||||
_module.args.images = images;
|
_module.args.images = images;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
@ -48,5 +46,5 @@ let
|
||||||
specialArgs = {
|
specialArgs = {
|
||||||
inherit kubenix;
|
inherit kubenix;
|
||||||
};
|
};
|
||||||
}).config) k8sVersions);
|
}).config;
|
||||||
in tests
|
in test.testing
|
||||||
|
|
|
||||||
|
|
@ -29,11 +29,12 @@ let
|
||||||
finalImageTag = "latest";
|
finalImageTag = "latest";
|
||||||
};
|
};
|
||||||
in {
|
in {
|
||||||
imports = [ kubenix.modules.test kubenix.modules.helm ];
|
imports = [ kubenix.modules.test kubenix.modules.helm kubenix.modules.k8s ];
|
||||||
|
|
||||||
test = {
|
test = {
|
||||||
name = "helm-simple";
|
name = "helm-simple";
|
||||||
description = "Simple k8s testing wheter name, apiVersion and kind are preset";
|
description = "Simple k8s testing wheter name, apiVersion and kind are preset";
|
||||||
|
enable = builtins.compareVersions config.kubernetes.version "1.8" >= 0;
|
||||||
assertions = [{
|
assertions = [{
|
||||||
message = "should have generated resources";
|
message = "should have generated resources";
|
||||||
assertion =
|
assertion =
|
||||||
|
|
|
||||||
|
|
@ -12,8 +12,16 @@ in {
|
||||||
name = "k8s-deployment";
|
name = "k8s-deployment";
|
||||||
description = "Simple k8s testing a simple deployment";
|
description = "Simple k8s testing a simple deployment";
|
||||||
assertions = [{
|
assertions = [{
|
||||||
message = "should have correct apiVersion and kind set";
|
message = "should have correct apiVersion and kind set for 1.8+";
|
||||||
assertion = cfg.apiVersion == "apps/v1" && cfg.kind == "Deployment";
|
assertion =
|
||||||
|
if ((builtins.compareVersions config.kubernetes.version "1.7") <= 0)
|
||||||
|
then cfg.apiVersion == "apps/v1beta1"
|
||||||
|
else if ((builtins.compareVersions config.kubernetes.version "1.8") <= 0)
|
||||||
|
then cfg.apiVersion == "apps/v1beta2"
|
||||||
|
else cfg.apiVersion == "apps/v1";
|
||||||
|
} {
|
||||||
|
message = "should have corrent kind set";
|
||||||
|
assertion = cfg.kind == "Deployment";
|
||||||
} {
|
} {
|
||||||
message = "should have replicas set";
|
message = "should have replicas set";
|
||||||
assertion = cfg.spec.replicas == 10;
|
assertion = cfg.spec.replicas == 10;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue