summary refs log tree commit diff
path: root/nixos/tests/redis.nix
diff options
context:
space:
mode:
authordadada <dadada@dadada.li>2021-01-03 19:20:02 +0100
committerdadada <dadada@dadada.li>2021-01-09 11:40:11 +0100
commit5d0b0fcc7d841ff749d2880f214980be15ff72bb (patch)
treeba48fe0ee0b4f8058550f0775b1ade56562ef82a /nixos/tests/redis.nix
parentf1a316b4fc4e511e15fbac01adc4e2e23865dbcb (diff)
downloadnixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.tar
nixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.tar.gz
nixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.tar.bz2
nixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.tar.lz
nixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.tar.xz
nixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.tar.zst
nixpkgs-5d0b0fcc7d841ff749d2880f214980be15ff72bb.zip
nixos/redis: add test for unix socket access
This adds a test to check if the unix socket is available to the `redis` group
added in #90027.
Diffstat (limited to 'nixos/tests/redis.nix')
-rw-r--r--nixos/tests/redis.nix27
1 files changed, 24 insertions, 3 deletions
diff --git a/nixos/tests/redis.nix b/nixos/tests/redis.nix
index 529965d7acd..f51bb029d64 100644
--- a/nixos/tests/redis.nix
+++ b/nixos/tests/redis.nix
@@ -1,4 +1,8 @@
-import ./make-test-python.nix ({ pkgs, ...} : {
+import ./make-test-python.nix ({ pkgs, ... }:
+let
+  redisSocket = "/run/redis/redis.sock";
+in
+{
   name = "redis";
   meta = with pkgs.stdenv.lib.maintainers; {
     maintainers = [ flokli ];
@@ -10,7 +14,20 @@ import ./make-test-python.nix ({ pkgs, ...} : {
 
       {
         services.redis.enable = true;
-        services.redis.unixSocket = "/run/redis/redis.sock";
+        services.redis.unixSocket = redisSocket;
+
+        # Allow access to the unix socket for the "redis" group.
+        services.redis.settings.unixsocketperm = "770";
+
+        users.users."member" = {
+          createHome = false;
+          description = "A member of the redis group";
+          extraGroups = [
+            "redis"
+          ];
+          group = "users";
+          shell = "/bin/sh";
+        };
       };
   };
 
@@ -18,7 +35,11 @@ import ./make-test-python.nix ({ pkgs, ...} : {
     start_all()
     machine.wait_for_unit("redis")
     machine.wait_for_open_port("6379")
+
+    # The unix socket is accessible to the redis group
+    machine.succeed('su member -c "redis-cli ping | grep PONG"')
+
     machine.succeed("redis-cli ping | grep PONG")
-    machine.succeed("redis-cli -s /run/redis/redis.sock ping | grep PONG")
+    machine.succeed("redis-cli -s ${redisSocket} ping | grep PONG")
   '';
 })