kubenix/test/modules.nix
Jaka Hudoklin 70d33e20b8 fix tests
2017-12-20 16:55:45 +01:00

75 lines
1.9 KiB
Nix

{lib, k8s, ...}:
with k8s;
with lib;
{
config = {
kubernetes.moduleDefinitions.nginx.module = {name, config, ...}: {
options = {
port = mkOption {
description = "Port for nginx to listen on";
type = types.int;
default = 80;
};
password = mkSecretOption {
description = "Nginx simple auth credentials";
default = {
key = "test";
name = "test";
};
};
};
config = {
kubernetes.resources.deployments.nginx = mkMerge [
(loadJSON ./deployment.json)
{
metadata.name = "${name}-nginx";
spec.template.spec.containers.nginx.ports."80" = {
containerPort = config.port;
};
spec.template.spec.containers.nginx.env.name = mkIf (config.password != null) config.password;
}
];
kubernetes.resources.configMaps.nginx = mkMerge [
(loadJSON ./configMap.json)
{
metadata.name = mkForce "${name}-nginx";
}
];
kubernetes.customResources.cron.my-awesome-cron-object = mkMerge [
(k8s.loadJSON ./cr.json)
{metadata.name = name;}
];
};
};
kubernetes.modules.app-v1 = {
module = "nginx";
configuration.password.name = "test2";
configuration.password.key = "password";
};
kubernetes.modules.app-v2 = {
module = "nginx";
configuration.port = 8080;
};
kubernetes.resources.services.nginx = loadJSON ./service.json;
kubernetes.defaultModuleConfiguration.all = [{
config.kubernetes.defaults.deployments = [{spec.replicas = 3;}];
}];
kubernetes.defaultModuleConfiguration.nginx = [{
kubernetes.defaults.deployments = [{spec.replicas = mkDefault 4;}];
}];
kubernetes.defaults.all = [{metadata.namespace = "test";}];
};
}