summary refs log tree commit diff
diff options
context:
space:
mode:
authorPhillip Cloud <cloud@standard.ai>2021-01-23 18:19:50 -0500
committerPhillip Cloud <cloud@standard.ai>2021-01-23 19:44:37 -0500
commitde71f5b50670908026842672aebe2565d239cda0 (patch)
tree1d961927b2f27c3c985716c8f32bae5f484674d7
parent5ce4ce61746c19f09ae1504a49f3216de6770055 (diff)
downloadnixpkgs-de71f5b50670908026842672aebe2565d239cda0.tar
nixpkgs-de71f5b50670908026842672aebe2565d239cda0.tar.gz
nixpkgs-de71f5b50670908026842672aebe2565d239cda0.tar.bz2
nixpkgs-de71f5b50670908026842672aebe2565d239cda0.tar.lz
nixpkgs-de71f5b50670908026842672aebe2565d239cda0.tar.xz
nixpkgs-de71f5b50670908026842672aebe2565d239cda0.tar.zst
nixpkgs-de71f5b50670908026842672aebe2565d239cda0.zip
nixos/tests: add test for custom nomad state directory
-rw-r--r--nixos/tests/nomad.nix68
1 files changed, 56 insertions, 12 deletions
diff --git a/nixos/tests/nomad.nix b/nixos/tests/nomad.nix
index bd052152bd6..51b11a8fef9 100644
--- a/nixos/tests/nomad.nix
+++ b/nixos/tests/nomad.nix
@@ -2,7 +2,7 @@ import ./make-test-python.nix (
   { lib, ... }: {
     name = "nomad";
     nodes = {
-      server = { pkgs, lib, ... }: {
+      default_server = { pkgs, lib, ... }: {
         networking = {
           interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [{
             address = "192.168.1.1";
@@ -30,24 +30,68 @@ import ./make-test-python.nix (
           enableDocker = false;
         };
       };
+
+      custom_state_dir_server = { pkgs, lib, ... }: {
+        networking = {
+          interfaces.eth1.ipv4.addresses = lib.mkOverride 0 [{
+            address = "192.168.1.1";
+            prefixLength = 16;
+          }];
+        };
+
+        environment.etc."nomad.custom.json".source =
+          (pkgs.formats.json { }).generate "nomad.custom.json" {
+            region = "universe";
+            datacenter = "earth";
+          };
+
+        services.nomad = {
+          enable = true;
+          dropPrivileges = false;
+
+          settings = {
+            data_dir = "/nomad/data/dir";
+            server = {
+              enabled = true;
+              bootstrap_expect = 1;
+            };
+          };
+
+          extraSettingsPaths = [ "/etc/nomad.custom.json" ];
+          enableDocker = false;
+        };
+
+        systemd.services.nomad.serviceConfig.ExecStartPre = "${pkgs.writeShellScript "mk_data_dir" ''
+          set -euxo pipefail
+
+          ${pkgs.coreutils}/bin/mkdir -p /nomad/data/dir
+        ''}";
+      };
     };
 
     testScript = ''
-      server.wait_for_unit("nomad.service")
+      def test_nomad_server(server):
+          server.wait_for_unit("nomad.service")
+
+          # wait for healthy server
+          server.wait_until_succeeds(
+              "[ $(nomad operator raft list-peers | grep true | wc -l) == 1 ]"
+          )
+
+          # wait for server liveness
+          server.succeed("[ $(nomad server members | grep -o alive | wc -l) == 1 ]")
+
+          # check the region
+          server.succeed("nomad server members | grep -o universe")
 
-      # wait for healthy server
-      server.wait_until_succeeds(
-          "[ $(nomad operator raft list-peers | grep true | wc -l) == 1 ]"
-      )
+          # check the datacenter
+          server.succeed("[ $(nomad server members | grep -o earth | wc -l) == 1 ]")
 
-      # wait for server liveness
-      server.succeed("[ $(nomad server members | grep -o alive | wc -l) == 1 ]")
 
-      # check the region
-      server.succeed("nomad server members | grep -o universe")
+      servers = [default_server, custom_state_dir_server]
 
-      # check the datacenter
-      server.succeed("[ $(nomad server members | grep -o earth | wc -l) == 1 ]")
+      for server in servers:
+          test_nomad_server(server)
     '';
   }
 )