mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2025-12-12 16:10:05 +01:00
feat(submodules): refactor defaults
This commit is contained in:
parent
d925d71ed7
commit
8536b03151
4 changed files with 175 additions and 34 deletions
|
|
@ -9,7 +9,7 @@ in {
|
||||||
|
|
||||||
options = {
|
options = {
|
||||||
kubernetes.propagateDefaults = mkOption {
|
kubernetes.propagateDefaults = mkOption {
|
||||||
description = "Whehter to propagate child defaults to submodules";
|
description = "Whether to propagate child defaults to submodules";
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
default = true;
|
default = true;
|
||||||
};
|
};
|
||||||
|
|
@ -25,25 +25,32 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
config.config = {
|
config.config = {
|
||||||
kubernetes.api.defaults.all.metadata.namespace =
|
kubernetes.api.defaults = [{
|
||||||
mkDefault config.namespace;
|
default.metadata.namespace = mkDefault config.namespace;
|
||||||
|
}];
|
||||||
};
|
};
|
||||||
}));
|
}));
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
submodules.defaults = mkMerge [{
|
submodules.defaults = [{
|
||||||
imports = [ kubenix.k8s ];
|
default = {
|
||||||
kubernetes.version = mkDefault config.kubernetes.version;
|
imports = [ kubenix.k8s ];
|
||||||
kubernetes.api.defaults =
|
kubernetes.version = mkDefault config.kubernetes.version;
|
||||||
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
|
kubernetes.api.defaults =
|
||||||
} ({config, ...}: {
|
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
|
||||||
kubernetes.api.defaults.all.metadata.labels = {
|
};
|
||||||
"kubenix/module-name" = config.submodule.name;
|
} {
|
||||||
"kubenix/module-version" = config.submodule.version;
|
default = ({config, ...}: {
|
||||||
};
|
kubernetes.api.defaults = [{
|
||||||
})];
|
default.metadata.labels = {
|
||||||
|
"kubenix/module-name" = config.submodule.name;
|
||||||
|
"kubenix/module-version" = config.submodule.version;
|
||||||
|
};
|
||||||
|
}];
|
||||||
|
});
|
||||||
|
}];
|
||||||
|
|
||||||
kubernetes.objects = mkMerge (mapAttrsToList (_: submodule:
|
kubernetes.objects = mkMerge (mapAttrsToList (_: submodule:
|
||||||
submodule.config.kubernetes.objects
|
submodule.config.kubernetes.objects
|
||||||
|
|
|
||||||
|
|
@ -5,6 +5,15 @@ with lib;
|
||||||
let
|
let
|
||||||
cfg = config.submodules;
|
cfg = config.submodules;
|
||||||
|
|
||||||
|
getDefaults = name: tags:
|
||||||
|
catAttrs "default" (filter (submodule:
|
||||||
|
(submodule.name == null || submodule.name == name) &&
|
||||||
|
(
|
||||||
|
(length submodule.tags == 0) ||
|
||||||
|
(length (intersectLists submodule.tags tags)) > 0
|
||||||
|
)
|
||||||
|
) config.submodules.defaults);
|
||||||
|
|
||||||
submoduleWithSpecialArgs = opts: specialArgs:
|
submoduleWithSpecialArgs = opts: specialArgs:
|
||||||
let
|
let
|
||||||
opts' = toList opts;
|
opts' = toList opts;
|
||||||
|
|
@ -69,9 +78,9 @@ let
|
||||||
default = "1.0.0";
|
default = "1.0.0";
|
||||||
};
|
};
|
||||||
|
|
||||||
passthru = mkOption {
|
tags = mkOption {
|
||||||
description = "Submodule passthru";
|
description = "List of submodule tags";
|
||||||
type = types.coercedTo types.attrs (value: [value]) (types.listOf types.attrs);
|
type = types.listOf types.str;
|
||||||
default = [];
|
default = [];
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
@ -114,24 +123,35 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
submodules.defaults = mkOption {
|
submodules.defaults = mkOption {
|
||||||
description = "Submodule defaults";
|
description = "List of defaults to apply to submodule instances";
|
||||||
type = types.coercedTo types.unspecified (value: [value]) (types.listOf types.unspecified);
|
type = types.listOf (types.submodule ({config, ...}: {
|
||||||
example = literalExample ''{config, ...}: {
|
options = {
|
||||||
kubernetes.version = config.kubernetes.version;
|
name = mkOption {
|
||||||
}'';
|
description = "Name of the submodule to apply defaults to";
|
||||||
default = [];
|
type = types.nullOr types.str;
|
||||||
};
|
default = null;
|
||||||
|
};
|
||||||
|
|
||||||
submodules.propagateDefaults = mkOption {
|
tags = mkOption {
|
||||||
description = "Whether to propagate defaults to submodules";
|
description = "List of tags to apply defaults to";
|
||||||
type = types.bool;
|
type = types.listOf types.str;
|
||||||
default = true;
|
default = [];
|
||||||
|
};
|
||||||
|
|
||||||
|
default = mkOption {
|
||||||
|
description = "Default to apply to submodule instance";
|
||||||
|
type = types.unspecified;
|
||||||
|
default = {};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}));
|
||||||
|
default = [];
|
||||||
};
|
};
|
||||||
|
|
||||||
submodules.propagate = mkOption {
|
submodules.propagate = mkOption {
|
||||||
description = "Whether to propagate defaults and imports to submodule's submodules";
|
description = "Whether to propagate defaults and imports to submodule's submodules";
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
default = true;
|
default = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
submodules.imports = mkOption {
|
submodules.imports = mkOption {
|
||||||
|
|
@ -150,6 +170,7 @@ in {
|
||||||
options = {
|
options = {
|
||||||
module = mkOption {
|
module = mkOption {
|
||||||
description = "Module defining submodule";
|
description = "Module defining submodule";
|
||||||
|
type = types.unspecified;
|
||||||
};
|
};
|
||||||
|
|
||||||
modules = mkOption {
|
modules = mkOption {
|
||||||
|
|
@ -172,12 +193,17 @@ in {
|
||||||
submodules.instances = mkOption {
|
submodules.instances = mkOption {
|
||||||
description = "Attribute set of submodule instances";
|
description = "Attribute set of submodule instances";
|
||||||
type = types.attrsOf (types.submodule ({name, config, ...}: let
|
type = types.attrsOf (types.submodule ({name, config, ...}: let
|
||||||
|
# submodule associated with
|
||||||
submodule = findModule {
|
submodule = findModule {
|
||||||
name = config.submodule;
|
name = config.submodule;
|
||||||
version = config.version;
|
version = config.version;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# definition of a submodule
|
||||||
submoduleDefinition = submodule.definition;
|
submoduleDefinition = submodule.definition;
|
||||||
|
|
||||||
|
# submodule defaults
|
||||||
|
defaults = getDefaults submoduleDefinition.name submoduleDefinition.tags;
|
||||||
in {
|
in {
|
||||||
options = {
|
options = {
|
||||||
name = mkOption {
|
name = mkOption {
|
||||||
|
|
@ -201,7 +227,7 @@ in {
|
||||||
config = mkOption {
|
config = mkOption {
|
||||||
description = "Submodule instance ${config.name} for ${submoduleDefinition.name}:${submoduleDefinition.version} config";
|
description = "Submodule instance ${config.name} for ${submoduleDefinition.name}:${submoduleDefinition.version} config";
|
||||||
type = submoduleWithSpecialArgs ({...}: {
|
type = submoduleWithSpecialArgs ({...}: {
|
||||||
imports = submodule.modules ++ cfg.defaults ++ [submoduleOptions ./submodules.nix];
|
imports = submodule.modules ++ defaults ++ [submoduleOptions];
|
||||||
_module.args.name = config.name;
|
_module.args.name = config.name;
|
||||||
}) specialArgs;
|
}) specialArgs;
|
||||||
default = {};
|
default = {};
|
||||||
|
|
@ -214,9 +240,14 @@ in {
|
||||||
|
|
||||||
config = {
|
config = {
|
||||||
submodules.specialArgs.kubenix = kubenix;
|
submodules.specialArgs.kubenix = kubenix;
|
||||||
submodules.defaults = mkIf cfg.propagate {
|
submodules.defaults = [(mkIf cfg.propagate {
|
||||||
submodules.defaults = cfg.defaults;
|
default = {
|
||||||
submodules.imports = cfg.imports;
|
imports = [./submodules.nix];
|
||||||
};
|
submodules = {
|
||||||
|
defaults = cfg.defaults;
|
||||||
|
imports = cfg.imports;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -32,6 +32,7 @@ let
|
||||||
./k8s/1.13/crd.nix
|
./k8s/1.13/crd.nix
|
||||||
./k8s/submodule.nix
|
./k8s/submodule.nix
|
||||||
./submodules/simple.nix
|
./submodules/simple.nix
|
||||||
|
./submodules/defaults.nix
|
||||||
];
|
];
|
||||||
testing.defaults = ({kubenix, ...}: {
|
testing.defaults = ({kubenix, ...}: {
|
||||||
imports = [kubenix.k8s];
|
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