summary refs log tree commit diff
path: root/lib/tests/modules
diff options
context:
space:
mode:
authorRobert Hensing <robert@roberthensing.nl>2021-11-22 14:39:10 +0100
committerRobert Hensing <robert@roberthensing.nl>2021-11-22 16:50:50 +0100
commitd464ccfdd9e101d4f5a112ab58d91ccbb912524a (patch)
tree2e2e45996c8bcaf13baeb01c681fa50001226d65 /lib/tests/modules
parent426ab31fdeb828886c22ec0e561eca2b90b84b94 (diff)
downloadnixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.tar
nixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.tar.gz
nixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.tar.bz2
nixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.tar.lz
nixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.tar.xz
nixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.tar.zst
nixpkgs-d464ccfdd9e101d4f5a112ab58d91ccbb912524a.zip
modules: Add moduleType to module arguments
Diffstat (limited to 'lib/tests/modules')
-rw-r--r--lib/tests/modules/declare-variants.nix9
-rw-r--r--lib/tests/modules/define-variant.nix22
2 files changed, 31 insertions, 0 deletions
diff --git a/lib/tests/modules/declare-variants.nix b/lib/tests/modules/declare-variants.nix
new file mode 100644
index 00000000000..3ed6fa689e2
--- /dev/null
+++ b/lib/tests/modules/declare-variants.nix
@@ -0,0 +1,9 @@
+{ lib, moduleType, ... }:
+let inherit (lib) mkOption types;
+in
+{
+  options.variants = mkOption {
+    type = types.lazyAttrsOf moduleType;
+    default = {};
+  };
+}
diff --git a/lib/tests/modules/define-variant.nix b/lib/tests/modules/define-variant.nix
new file mode 100644
index 00000000000..423cb0e37cb
--- /dev/null
+++ b/lib/tests/modules/define-variant.nix
@@ -0,0 +1,22 @@
+{ config, lib, ... }:
+let inherit (lib) types mkOption attrNames;
+in
+{
+  options = {
+    attrs = mkOption { type = types.attrsOf lib.types.int; };
+    result = mkOption { };
+    resultFoo = mkOption { };
+    resultFooBar = mkOption { };
+    resultFooFoo = mkOption { };
+  };
+  config = {
+    attrs.a = 1;
+    variants.foo.attrs.b = 1;
+    variants.bar.attrs.y = 1;
+    variants.foo.variants.bar.attrs.z = 1;
+    variants.foo.variants.foo.attrs.c = 3;
+    resultFoo = lib.concatMapStringsSep " " toString (attrNames config.variants.foo.attrs);
+    resultFooBar = lib.concatMapStringsSep " " toString (attrNames config.variants.foo.variants.bar.attrs);
+    resultFooFoo = lib.concatMapStringsSep " " toString (attrNames config.variants.foo.variants.foo.attrs);
+  };
+}