about summary refs log tree commit diff
path: root/nixos/tests/envoy.nix
diff options
context:
space:
mode:
authorAndreas Stührk <andy@yaxi.tech>2023-02-09 12:19:58 +0100
committerpennae <82953136+pennae@users.noreply.github.com>2023-02-11 18:21:21 +0100
commit8dade1f713c7f64f0514ba4c00fa6e2bb1be8d79 (patch)
treec1ee27b2884024809ccb80de4d3fd9a451b235f7 /nixos/tests/envoy.nix
parent84220a70983948dd611f0cfdecb70ffe02556312 (diff)
nixos/envoy: add option `requireValidConfig` to make config validation errors non-fatal
Co-authored-by: Vincent Haupert <vincent@yaxi.tech>
Diffstat (limited to 'nixos/tests/envoy.nix')
-rw-r--r--nixos/tests/envoy.nix33
1 files changed, 27 insertions, 6 deletions
diff --git a/nixos/tests/envoy.nix b/nixos/tests/envoy.nix
index a14c1fca3bb5f..1e4bfe626398e 100644
--- a/nixos/tests/envoy.nix
+++ b/nixos/tests/envoy.nix
@@ -22,12 +22,33 @@ import ./make-test-python.nix ({ pkgs, lib, ...} : {
         clusters = [];
       };
     };
+    specialisation = {
+      withoutConfigValidation.configuration = { ... }: {
+        services.envoy = {
+          requireValidConfig = false;
+          settings.admin.access_log_path = lib.mkForce "/var/log/envoy/access.log";
+        };
+      };
+    };
   };
 
-  testScript = ''
-    machine.start()
-    machine.wait_for_unit("envoy.service")
-    machine.wait_for_open_port(80)
-    machine.wait_until_succeeds("curl -fsS localhost:80/ready")
-  '';
+  testScript = { nodes, ... }:
+    let
+      specialisations = "${nodes.machine.system.build.toplevel}/specialisation";
+    in
+    ''
+      machine.start()
+
+      with subtest("envoy.service starts and responds with ready"):
+        machine.wait_for_unit("envoy.service")
+        machine.wait_for_open_port(80)
+        machine.wait_until_succeeds("curl -fsS localhost:80/ready")
+
+      with subtest("envoy.service works with config path not available at eval time"):
+        machine.succeed('${specialisations}/withoutConfigValidation/bin/switch-to-configuration test')
+        machine.wait_for_unit("envoy.service")
+        machine.wait_for_open_port(80)
+        machine.wait_until_succeeds("curl -fsS localhost:80/ready")
+        machine.succeed('test -f /var/log/envoy/access.log')
+    '';
 })