mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 08:00:06 +01:00
feat(submodules): refactor defaults
This commit is contained in:
parent
d925d71ed7
commit
8536b03151
4 changed files with 175 additions and 34 deletions
|
|
@ -32,6 +32,7 @@ let
|
|||
./k8s/1.13/crd.nix
|
||||
./k8s/submodule.nix
|
||||
./submodules/simple.nix
|
||||
./submodules/defaults.nix
|
||||
];
|
||||
testing.defaults = ({kubenix, ...}: {
|
||||
imports = [kubenix.k8s];
|
||||
|
|
|
|||
102
tests/submodules/defaults.nix
Normal file
102
tests/submodules/defaults.nix
Normal file
|
|
@ -0,0 +1,102 @@
|
|||
{ name, config, lib, kubenix, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
instance1 = config.submodules.instances.instance1;
|
||||
instance2 = config.submodules.instances.instance2;
|
||||
instance3 = config.submodules.instances.instance3;
|
||||
instance4 = config.submodules.instances.instance4;
|
||||
|
||||
module = {name, ...}: {
|
||||
options.args.value = mkOption {
|
||||
description = "Submodule value";
|
||||
type = types.str;
|
||||
};
|
||||
|
||||
options.args.defaultValue = mkOption {
|
||||
description = "Submodule default value";
|
||||
type = types.str;
|
||||
};
|
||||
};
|
||||
in {
|
||||
imports = [
|
||||
kubenix.submodules
|
||||
];
|
||||
|
||||
test = {
|
||||
name = "submodules-defatuls";
|
||||
description = "Simple k8s submodule test";
|
||||
assertions = [{
|
||||
message = "instance1 should have value of value1";
|
||||
assertion = instance1.config.args.value == "value1";
|
||||
} {
|
||||
message = "instance2 should have value of value2";
|
||||
assertion = instance2.config.args.value == "value2";
|
||||
} {
|
||||
message = "instance2 should have value of value2";
|
||||
assertion = instance3.config.args.value == "value2";
|
||||
} {
|
||||
message = "instance1 and instance2 should have value of value";
|
||||
assertion =
|
||||
instance1.config.args.defaultValue == "value" &&
|
||||
instance2.config.args.defaultValue == "value";
|
||||
} {
|
||||
message = "instance1 and instance3 should have value of default-value";
|
||||
assertion = instance3.config.args.defaultValue == "default-value";
|
||||
} {
|
||||
message = "instance4 should have value of value4";
|
||||
assertion = instance4.config.args.value == "value4";
|
||||
}];
|
||||
};
|
||||
|
||||
submodules.imports = [{
|
||||
modules = [module {
|
||||
submodule = {
|
||||
name = "submodule1";
|
||||
tags = ["tag1"];
|
||||
};
|
||||
}];
|
||||
} {
|
||||
modules = [module {
|
||||
submodule = {
|
||||
name = "submodule2";
|
||||
tags = ["tag2"];
|
||||
};
|
||||
}];
|
||||
} {
|
||||
modules = [module {
|
||||
submodule = {
|
||||
name = "submodule3";
|
||||
tags = ["tag2"];
|
||||
};
|
||||
}];
|
||||
} {
|
||||
modules = [module {
|
||||
submodule = {
|
||||
name = "submodule4";
|
||||
};
|
||||
}];
|
||||
}];
|
||||
|
||||
submodules.defaults = [{
|
||||
default.args.defaultValue = mkDefault "value";
|
||||
} {
|
||||
tags = ["tag1"];
|
||||
default.args.value = mkDefault "value1";
|
||||
} {
|
||||
tags = ["tag2"];
|
||||
default.args.value = mkDefault "value2";
|
||||
} {
|
||||
name = "submodule4";
|
||||
default.args.value = mkDefault "value4";
|
||||
}];
|
||||
|
||||
submodules.instances.instance1.submodule = "submodule1";
|
||||
submodules.instances.instance2.submodule = "submodule2";
|
||||
submodules.instances.instance3 = {
|
||||
submodule = "submodule3";
|
||||
config.args.defaultValue = "default-value";
|
||||
};
|
||||
submodules.instances.instance4.submodule = "submodule4";
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue