Refactor:

- Support for module features
- Remove kubenix.module and rather use explicit modules
- Make tests framework independent of k8s module
- Remove metacontroller submodule, which will go to kubenix-modules
- Improved submodule propagation and passthru
- Added additional test for k8s-submodule
This commit is contained in:
Jaka Hudoklin 2019-03-12 20:33:56 +01:00
parent b670139906
commit 6183fcc190
No known key found for this signature in database
GPG key ID: 6A08896BFD32BD95
30 changed files with 513 additions and 508 deletions

View file

@ -9,23 +9,27 @@ let
instance4 = config.submodules.instances.instance4;
instance5 = config.submodules.instances.instance5;
module = {name, ...}: {
options.args.value = mkOption {
description = "Submodule value";
type = types.str;
};
submodule = {name, ...}: {
imports = [ kubenix.modules.submodule ];
options.args.defaultValue = mkOption {
description = "Submodule default value";
type = types.str;
options = {
args.value = mkOption {
description = "Submodule value";
type = types.str;
};
args.defaultValue = mkOption {
description = "Submodule default value";
type = types.str;
};
};
};
in {
imports = with kubenix.modules; [ test submodules ];
test = {
name = "submodules-defatuls";
description = "Simple k8s submodule test";
name = "submodules-defaults";
description = "Simple submodule test";
assertions = [{
message = "should apply defaults by tag1";
assertion = instance1.config.args.value == "value1";
@ -53,34 +57,34 @@ in {
};
submodules.imports = [{
modules = [module {
modules = [submodule {
submodule = {
name = "submodule1";
tags = ["tag1"];
};
}];
} {
modules = [module {
modules = [submodule {
submodule = {
name = "submodule2";
tags = ["tag2"];
};
}];
} {
modules = [module {
modules = [submodule {
submodule = {
name = "submodule3";
tags = ["tag2"];
};
}];
} {
modules = [module {
modules = [submodule {
submodule = {
name = "submodule4";
};
}];
} {
modules = [module {
modules = [submodule {
submodule = {
name = "submodule5";
};