summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZhaofeng Li <hello@zhaofeng.li>2021-12-17 15:55:13 -0800
committergithub-actions[bot] <github-actions[bot]@users.noreply.github.com>2021-12-18 12:04:57 +0000
commit61cb7ab54abfb92d98df7ae49767e6ffebc73925 (patch)
treef54f6062de234705539eddb970219126b097114f
parentunifi5: Follow new mitigation guidelines (diff)
downloadnixpkgs-61cb7ab54abfb92d98df7ae49767e6ffebc73925.tar.gz
unifi: Add NixOS tests
(cherry picked from commit 8bbae8e55873b31faf233cd40cf212b0b8b113c6)
-rw-r--r--nixos/tests/all-tests.nix1
-rw-r--r--nixos/tests/unifi.nix35
-rw-r--r--pkgs/servers/unifi/default.nix6
3 files changed, 41 insertions, 1 deletions
diff --git a/nixos/tests/all-tests.nix b/nixos/tests/all-tests.nix
index 36f4516453c9..184562d428b8 100644
--- a/nixos/tests/all-tests.nix
+++ b/nixos/tests/all-tests.nix
@@ -439,6 +439,7 @@ in
ucg = handleTest ./ucg.nix {};
udisks2 = handleTest ./udisks2.nix {};
unbound = handleTest ./unbound.nix {};
+ unifi = handleTest ./unifi.nix {};
unit-php = handleTest ./web-servers/unit-php.nix {};
upnp = handleTest ./upnp.nix {};
usbguard = handleTest ./usbguard.nix {};
diff --git a/nixos/tests/unifi.nix b/nixos/tests/unifi.nix
new file mode 100644
index 000000000000..34284811abfb
--- /dev/null
+++ b/nixos/tests/unifi.nix
@@ -0,0 +1,35 @@
+# Test UniFi controller
+
+{ system ? builtins.currentSystem
+, config ? { allowUnfree = true; }
+, pkgs ? import ../.. { inherit system config; }
+}:
+
+with import ../lib/testing-python.nix { inherit system pkgs; };
+with pkgs.lib;
+
+let
+ makeAppTest = unifi: makeTest {
+ name = "unifi-controller-${unifi.version}";
+ meta = with pkgs.lib.maintainers; {
+ maintainers = [ zhaofengli ];
+ };
+
+ nodes.server = {
+ services.unifi = {
+ enable = true;
+ unifiPackage = unifi;
+ openFirewall = false;
+ };
+ };
+
+ testScript = ''
+ server.wait_for_unit("unifi.service")
+ server.wait_until_succeeds("curl -Lk https://localhost:8443 >&2", timeout=300)
+ '';
+ };
+in with pkgs; {
+ unifiLTS = makeAppTest unifiLTS;
+ unifi5 = makeAppTest unifi5;
+ unifi6 = makeAppTest unifi6;
+}
diff --git a/pkgs/servers/unifi/default.nix b/pkgs/servers/unifi/default.nix
index 3742e565fcc2..a379aeb2a5df 100644
--- a/pkgs/servers/unifi/default.nix
+++ b/pkgs/servers/unifi/default.nix
@@ -1,4 +1,4 @@
-{ lib, stdenv, dpkg, fetchurl, zip }:
+{ lib, stdenv, dpkg, fetchurl, zip, nixosTests }:
let
generic = { version, sha256, suffix ? "", ... } @ args:
@@ -28,6 +28,10 @@ let
runHook postInstall
'';
+ passthru.tests = {
+ unifi = nixosTests.unifi;
+ };
+
meta = with lib; {
homepage = "http://www.ubnt.com/";
description = "Controller for Ubiquiti UniFi access points";