mirror of
https://github.com/TECHNOFAB11/kubenix.git
synced 2026-02-02 09:25:10 +01:00
fmt
This commit is contained in:
parent
c3fa598922
commit
db6d83c61e
53 changed files with 1916 additions and 1599 deletions
|
|
@ -1,7 +1,6 @@
|
|||
{ name, config, lib, kubenix, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
instance1 = config.submodules.instances.instance1;
|
||||
instance2 = config.submodules.instances.instance2;
|
||||
|
|
@ -10,7 +9,7 @@ let
|
|||
instance5 = config.submodules.instances.instance5;
|
||||
versioned-submodule = config.submodules.instances.versioned-submodule;
|
||||
|
||||
submodule = {name, ...}: {
|
||||
submodule = { name, ... }: {
|
||||
imports = [ kubenix.modules.submodule ];
|
||||
|
||||
options.submodule.args = {
|
||||
|
|
@ -25,7 +24,8 @@ let
|
|||
};
|
||||
};
|
||||
};
|
||||
in {
|
||||
in
|
||||
{
|
||||
imports = with kubenix.modules; [ test submodules ];
|
||||
|
||||
test = {
|
||||
|
|
@ -34,95 +34,130 @@ in {
|
|||
assertions = [{
|
||||
message = "should apply defaults by tag1";
|
||||
assertion = instance1.config.submodule.args.value == "value1";
|
||||
} {
|
||||
message = "should apply defaults by tag2";
|
||||
assertion = instance2.config.submodule.args.value == "value2";
|
||||
} {
|
||||
message = "should apply defaults by tag2";
|
||||
assertion = instance3.config.submodule.args.value == "value2";
|
||||
} {
|
||||
message = "should apply defaults to all";
|
||||
assertion =
|
||||
instance1.config.submodule.args.defaultValue == "value" &&
|
||||
instance2.config.submodule.args.defaultValue == "value";
|
||||
} {
|
||||
message = "instance1 and instance3 should have value of default-value";
|
||||
assertion = instance3.config.submodule.args.defaultValue == "default-value";
|
||||
} {
|
||||
message = "should apply defaults by submodule name";
|
||||
assertion = instance4.config.submodule.args.value == "value4";
|
||||
} {
|
||||
message = "should apply defaults by custom condition";
|
||||
assertion = instance5.config.submodule.args.defaultValue == "my-custom-value";
|
||||
} {
|
||||
message = "should apply defaults to versioned submodule";
|
||||
assertion = versioned-submodule.config.submodule.args.defaultValue == "versioned-submodule";
|
||||
}];
|
||||
}
|
||||
{
|
||||
message = "should apply defaults by tag2";
|
||||
assertion = instance2.config.submodule.args.value == "value2";
|
||||
}
|
||||
{
|
||||
message = "should apply defaults by tag2";
|
||||
assertion = instance3.config.submodule.args.value == "value2";
|
||||
}
|
||||
{
|
||||
message = "should apply defaults to all";
|
||||
assertion =
|
||||
instance1.config.submodule.args.defaultValue == "value" &&
|
||||
instance2.config.submodule.args.defaultValue == "value";
|
||||
}
|
||||
{
|
||||
message = "instance1 and instance3 should have value of default-value";
|
||||
assertion = instance3.config.submodule.args.defaultValue == "default-value";
|
||||
}
|
||||
{
|
||||
message = "should apply defaults by submodule name";
|
||||
assertion = instance4.config.submodule.args.value == "value4";
|
||||
}
|
||||
{
|
||||
message = "should apply defaults by custom condition";
|
||||
assertion = instance5.config.submodule.args.defaultValue == "my-custom-value";
|
||||
}
|
||||
{
|
||||
message = "should apply defaults to versioned submodule";
|
||||
assertion = versioned-submodule.config.submodule.args.defaultValue == "versioned-submodule";
|
||||
}];
|
||||
};
|
||||
|
||||
submodules.imports = [{
|
||||
modules = [submodule {
|
||||
submodule = {
|
||||
name = "submodule1";
|
||||
tags = ["tag1"];
|
||||
};
|
||||
modules = [
|
||||
submodule
|
||||
{
|
||||
submodule = {
|
||||
name = "submodule1";
|
||||
tags = [ "tag1" ];
|
||||
};
|
||||
}
|
||||
];
|
||||
}
|
||||
{
|
||||
modules = [
|
||||
submodule
|
||||
{
|
||||
submodule = {
|
||||
name = "submodule2";
|
||||
tags = [ "tag2" ];
|
||||
};
|
||||
}
|
||||
];
|
||||
}
|
||||
{
|
||||
modules = [
|
||||
submodule
|
||||
{
|
||||
submodule = {
|
||||
name = "submodule3";
|
||||
tags = [ "tag2" ];
|
||||
};
|
||||
}
|
||||
];
|
||||
}
|
||||
{
|
||||
modules = [
|
||||
submodule
|
||||
{
|
||||
submodule = {
|
||||
name = "submodule4";
|
||||
};
|
||||
}
|
||||
];
|
||||
}
|
||||
{
|
||||
modules = [
|
||||
submodule
|
||||
{
|
||||
submodule = {
|
||||
name = "submodule5";
|
||||
};
|
||||
submodule.args.value = "custom-value";
|
||||
}
|
||||
];
|
||||
}
|
||||
{
|
||||
modules = [
|
||||
submodule
|
||||
{
|
||||
submodule = {
|
||||
name = "versioned-submodule";
|
||||
version = "2.0.0";
|
||||
};
|
||||
}
|
||||
];
|
||||
}];
|
||||
} {
|
||||
modules = [submodule {
|
||||
submodule = {
|
||||
name = "submodule2";
|
||||
tags = ["tag2"];
|
||||
};
|
||||
}];
|
||||
} {
|
||||
modules = [submodule {
|
||||
submodule = {
|
||||
name = "submodule3";
|
||||
tags = ["tag2"];
|
||||
};
|
||||
}];
|
||||
} {
|
||||
modules = [submodule {
|
||||
submodule = {
|
||||
name = "submodule4";
|
||||
};
|
||||
}];
|
||||
} {
|
||||
modules = [submodule {
|
||||
submodule = {
|
||||
name = "submodule5";
|
||||
};
|
||||
submodule.args.value = "custom-value";
|
||||
}];
|
||||
} {
|
||||
modules = [submodule {
|
||||
submodule = {
|
||||
name = "versioned-submodule";
|
||||
version = "2.0.0";
|
||||
};
|
||||
}];
|
||||
}];
|
||||
|
||||
submodules.defaults = [{
|
||||
default.submodule.args.defaultValue = mkDefault "value";
|
||||
} {
|
||||
tags = ["tag1"];
|
||||
default.submodule.args.value = mkDefault "value1";
|
||||
} {
|
||||
tags = ["tag2"];
|
||||
default.submodule.args.value = mkDefault "value2";
|
||||
} {
|
||||
name = "submodule4";
|
||||
default.submodule.args.value = mkDefault "value4";
|
||||
} {
|
||||
default = {config, ...}: {
|
||||
submodule.args.defaultValue = mkIf (config.submodule.args.value == "custom-value") "my-custom-value";
|
||||
};
|
||||
} {
|
||||
name = "versioned-submodule";
|
||||
version = "2.0.0";
|
||||
default.submodule.args.value = mkDefault "versioned";
|
||||
}];
|
||||
}
|
||||
{
|
||||
tags = [ "tag1" ];
|
||||
default.submodule.args.value = mkDefault "value1";
|
||||
}
|
||||
{
|
||||
tags = [ "tag2" ];
|
||||
default.submodule.args.value = mkDefault "value2";
|
||||
}
|
||||
{
|
||||
name = "submodule4";
|
||||
default.submodule.args.value = mkDefault "value4";
|
||||
}
|
||||
{
|
||||
default = { config, ... }: {
|
||||
submodule.args.defaultValue = mkIf (config.submodule.args.value == "custom-value") "my-custom-value";
|
||||
};
|
||||
}
|
||||
{
|
||||
name = "versioned-submodule";
|
||||
version = "2.0.0";
|
||||
default.submodule.args.value = mkDefault "versioned";
|
||||
}];
|
||||
|
||||
submodules.instances.instance1.submodule = "submodule1";
|
||||
submodules.instances.instance2.submodule = "submodule2";
|
||||
|
|
|
|||
|
|
@ -1,7 +1,6 @@
|
|||
{ name, config, lib, kubenix, subm-lib, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
submodule = {
|
||||
imports = [ kubenix.modules.submodule ];
|
||||
|
|
@ -13,7 +12,8 @@ let
|
|||
};
|
||||
};
|
||||
};
|
||||
in {
|
||||
in
|
||||
{
|
||||
imports = with kubenix.modules; [ test submodules ];
|
||||
|
||||
test = {
|
||||
|
|
@ -26,7 +26,7 @@ in {
|
|||
};
|
||||
|
||||
submodules.imports = [{
|
||||
modules = [submodule];
|
||||
modules = [ submodule ];
|
||||
exportAs = "subm-lib";
|
||||
}];
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,7 +1,6 @@
|
|||
{ name, config, lib, kubenix, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
submodule = { name, ... }: {
|
||||
imports = [ kubenix.modules.submodule ];
|
||||
|
|
@ -11,14 +10,15 @@ let
|
|||
passthru.global.${name} = "true";
|
||||
};
|
||||
};
|
||||
in {
|
||||
in
|
||||
{
|
||||
imports = with kubenix.modules; [ test submodules ];
|
||||
|
||||
options = {
|
||||
global = mkOption {
|
||||
description = "Global value";
|
||||
type = types.attrs;
|
||||
default = {};
|
||||
default = { };
|
||||
};
|
||||
};
|
||||
|
||||
|
|
@ -29,17 +29,19 @@ in {
|
|||
assertions = [{
|
||||
message = "should passthru values if passthru enabled";
|
||||
assertion = hasAttr "inst1" config.global && config.global.inst1 == "true";
|
||||
} {
|
||||
message = "should not passthru values if passthru not enabled";
|
||||
assertion = !(hasAttr "inst2" config.global);
|
||||
} {
|
||||
message = "should passthru by default";
|
||||
assertion = hasAttr "inst3" config.global && config.global.inst3 == "true";
|
||||
}];
|
||||
}
|
||||
{
|
||||
message = "should not passthru values if passthru not enabled";
|
||||
assertion = !(hasAttr "inst2" config.global);
|
||||
}
|
||||
{
|
||||
message = "should passthru by default";
|
||||
assertion = hasAttr "inst3" config.global && config.global.inst3 == "true";
|
||||
}];
|
||||
};
|
||||
|
||||
submodules.imports = [{
|
||||
modules = [submodule];
|
||||
modules = [ submodule ];
|
||||
}];
|
||||
|
||||
submodules.instances.inst1 = {
|
||||
|
|
|
|||
|
|
@ -1,11 +1,11 @@
|
|||
{ name, config, lib, kubenix, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
cfg = config.submodules.instances.instance;
|
||||
args = cfg.config.submodule.args;
|
||||
in {
|
||||
in
|
||||
{
|
||||
imports = with kubenix.modules; [ test submodules ];
|
||||
|
||||
test = {
|
||||
|
|
@ -14,22 +14,27 @@ in {
|
|||
assertions = [{
|
||||
message = "Submodule name is set";
|
||||
assertion = cfg.name == "instance";
|
||||
} {
|
||||
message = "Submodule version is set";
|
||||
assertion = cfg.version == null;
|
||||
} {
|
||||
message = "Submodule config has submodule definition";
|
||||
assertion = cfg.config.submodule.name == "submodule";
|
||||
} {
|
||||
message = "Should have argument set";
|
||||
assertion = args.value == "test";
|
||||
} {
|
||||
message = "Should have submodule name set";
|
||||
assertion = args.name == "instance";
|
||||
} {
|
||||
message = "should have tag set";
|
||||
assertion = elem "tag" (cfg.config.submodule.tags);
|
||||
}];
|
||||
}
|
||||
{
|
||||
message = "Submodule version is set";
|
||||
assertion = cfg.version == null;
|
||||
}
|
||||
{
|
||||
message = "Submodule config has submodule definition";
|
||||
assertion = cfg.config.submodule.name == "submodule";
|
||||
}
|
||||
{
|
||||
message = "Should have argument set";
|
||||
assertion = args.value == "test";
|
||||
}
|
||||
{
|
||||
message = "Should have submodule name set";
|
||||
assertion = args.name == "instance";
|
||||
}
|
||||
{
|
||||
message = "should have tag set";
|
||||
assertion = elem "tag" (cfg.config.submodule.tags);
|
||||
}];
|
||||
};
|
||||
|
||||
submodules.propagate.enable = true;
|
||||
|
|
@ -51,7 +56,7 @@ in {
|
|||
|
||||
config = {
|
||||
submodule.name = "submodule";
|
||||
submodule.tags = ["tag"];
|
||||
submodule.tags = [ "tag" ];
|
||||
};
|
||||
};
|
||||
}];
|
||||
|
|
|
|||
|
|
@ -1,7 +1,6 @@
|
|||
{ name, config, lib, kubenix, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
let
|
||||
inst-exact = config.submodules.instances.inst-exact.config;
|
||||
inst-regex = config.submodules.instances.inst-regex.config;
|
||||
|
|
@ -17,7 +16,8 @@ let
|
|||
|
||||
config.submodule.name = "subm";
|
||||
};
|
||||
in {
|
||||
in
|
||||
{
|
||||
imports = with kubenix.modules; [ test submodules ];
|
||||
|
||||
test = {
|
||||
|
|
@ -26,36 +26,45 @@ in {
|
|||
assertions = [{
|
||||
message = "should select exact version";
|
||||
assertion = inst-exact.version == "1.1.0";
|
||||
} {
|
||||
message = "should select regex version";
|
||||
assertion = inst-regex.version == "1.2.1";
|
||||
} {
|
||||
message = "should select latest version";
|
||||
assertion = inst-latest.version == "1.2.1";
|
||||
}];
|
||||
}
|
||||
{
|
||||
message = "should select regex version";
|
||||
assertion = inst-regex.version == "1.2.1";
|
||||
}
|
||||
{
|
||||
message = "should select latest version";
|
||||
assertion = inst-latest.version == "1.2.1";
|
||||
}];
|
||||
};
|
||||
|
||||
submodules.imports = [{
|
||||
modules = [{
|
||||
config.submodule.version = "1.0.0";
|
||||
config.version = "1.0.0";
|
||||
} submodule];
|
||||
} {
|
||||
modules = [{
|
||||
config.submodule.version = "1.1.0";
|
||||
config.version = "1.1.0";
|
||||
} submodule];
|
||||
} {
|
||||
modules = [{
|
||||
config.submodule.version = "1.2.0";
|
||||
config.version = "1.2.0";
|
||||
} submodule];
|
||||
} {
|
||||
modules = [{
|
||||
config.submodule.version = "1.2.1";
|
||||
config.version = "1.2.1";
|
||||
} submodule];
|
||||
}];
|
||||
}
|
||||
submodule];
|
||||
}
|
||||
{
|
||||
modules = [{
|
||||
config.submodule.version = "1.1.0";
|
||||
config.version = "1.1.0";
|
||||
}
|
||||
submodule];
|
||||
}
|
||||
{
|
||||
modules = [{
|
||||
config.submodule.version = "1.2.0";
|
||||
config.version = "1.2.0";
|
||||
}
|
||||
submodule];
|
||||
}
|
||||
{
|
||||
modules = [{
|
||||
config.submodule.version = "1.2.1";
|
||||
config.version = "1.2.1";
|
||||
}
|
||||
submodule];
|
||||
}];
|
||||
|
||||
submodules.instances.inst-exact = {
|
||||
submodule = "subm";
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue