feat(submodules): refactor defaults

This commit is contained in:
Jaka Hudoklin 2019-02-26 21:23:14 +01:00
parent d925d71ed7
commit 8536b03151
No known key found for this signature in database
GPG key ID: 6A08896BFD32BD95
4 changed files with 175 additions and 34 deletions

View file

@ -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 = [{
default = {
imports = [ kubenix.k8s ]; imports = [ kubenix.k8s ];
kubernetes.version = mkDefault config.kubernetes.version; kubernetes.version = mkDefault config.kubernetes.version;
kubernetes.api.defaults = kubernetes.api.defaults =
mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults; mkIf config.kubernetes.propagateDefaults config.kubernetes.api.defaults;
} ({config, ...}: { };
kubernetes.api.defaults.all.metadata.labels = { } {
default = ({config, ...}: {
kubernetes.api.defaults = [{
default.metadata.labels = {
"kubenix/module-name" = config.submodule.name; "kubenix/module-name" = config.submodule.name;
"kubenix/module-version" = config.submodule.version; "kubenix/module-version" = config.submodule.version;
}; };
})]; }];
});
}];
kubernetes.objects = mkMerge (mapAttrsToList (_: submodule: kubernetes.objects = mkMerge (mapAttrsToList (_: submodule:
submodule.config.kubernetes.objects submodule.config.kubernetes.objects

View file

@ -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";
type = types.nullOr types.str;
default = null;
};
tags = mkOption {
description = "List of tags to apply defaults to";
type = types.listOf types.str;
default = []; default = [];
}; };
submodules.propagateDefaults = mkOption { default = mkOption {
description = "Whether to propagate defaults to submodules"; description = "Default to apply to submodule instance";
type = types.bool; type = types.unspecified;
default = true; 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;
}; };
}; };
})];
};
} }

View file

@ -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];

View 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";
}