summaryrefslogtreecommitdiffstats
path: root/nixos/tests/grafana.nix
diff options
context:
space:
mode:
authorWilliButz <wbutz@cyberfnord.de>2019-07-15 16:41:55 +0200
committerWilliButz <wbutz@cyberfnord.de>2019-07-15 18:33:26 +0200
commitb01b1fd62dc756a47409695ef5713175bd40f3c0 (patch)
tree84aa799201c0a70e883f0a2e4cf29f0dbe8d040d /nixos/tests/grafana.nix
parenta9ce5f6c598c7772e5db7d08f502e4cab095a66a (diff)
nixos/tests: extend grafana test
Also test configurations with postgresql and mariadb.
Diffstat (limited to 'nixos/tests/grafana.nix')
-rw-r--r--nixos/tests/grafana.nix90
1 files changed, 78 insertions, 12 deletions
diff --git a/nixos/tests/grafana.nix b/nixos/tests/grafana.nix
index 9dc765a879bc..7a1b4c8ffbbc 100644
--- a/nixos/tests/grafana.nix
+++ b/nixos/tests/grafana.nix
@@ -1,25 +1,91 @@
-import ./make-test.nix ({ lib, ... }:
-{
- name = "grafana";
+import ./make-test.nix ({ lib, pkgs, ... }:
- meta = with lib.maintainers; {
- maintainers = [ willibutz ];
- };
+let
+ inherit (lib) mkMerge nameValuePair maintainers;
- machine = { ... }: {
+ baseGrafanaConf = {
services.grafana = {
enable = true;
addr = "localhost";
analytics.reporting.enable = false;
domain = "localhost";
- security.adminUser = "testusername";
+ security = {
+ adminUser = "testadmin";
+ adminPassword = "snakeoilpwd";
+ };
};
};
+ extraNodeConfs = {
+ postgresql = {
+ services.grafana.database = {
+ host = "127.0.0.1:5432";
+ user = "grafana";
+ };
+ services.postgresql = {
+ enable = true;
+ ensureDatabases = [ "grafana" ];
+ ensureUsers = [{
+ name = "grafana";
+ ensurePermissions."DATABASE grafana" = "ALL PRIVILEGES";
+ }];
+ };
+ systemd.services.grafana.after = [ "postgresql.service" ];
+ };
+
+ mysql = {
+ services.grafana.database.user = "grafana";
+ services.mysql = {
+ enable = true;
+ ensureDatabases = [ "grafana" ];
+ ensureUsers = [{
+ name = "grafana";
+ ensurePermissions."grafana.*" = "ALL PRIVILEGES";
+ }];
+ package = pkgs.mariadb;
+ };
+ systemd.services.grafana.after = [ "mysql.service" ];
+ };
+ };
+
+ nodes = builtins.listToAttrs (map (dbName:
+ nameValuePair dbName (mkMerge [
+ baseGrafanaConf
+ (extraNodeConfs.${dbName} or {})
+ ])) [ "sqlite" "postgresql" "mysql" ]);
+
+in {
+ name = "grafana";
+
+ meta = with maintainers; {
+ maintainers = [ willibutz ];
+ };
+
+ inherit nodes;
+
testScript = ''
- $machine->start;
- $machine->waitForUnit("grafana.service");
- $machine->waitForOpenPort(3000);
- $machine->succeed("curl -sSfL http://127.0.0.1:3000/");
+ startAll();
+
+ subtest "Grafana sqlite", sub {
+ $sqlite->waitForUnit("grafana.service");
+ $sqlite->waitForOpenPort(3000);
+ $sqlite->succeed("curl -sSfN -u testadmin:snakeoilpwd http://127.0.0.1:3000/api/org/users | grep -q testadmin\@localhost");
+ };
+
+ subtest "Grafana postgresql", sub {
+ $postgresql->waitForUnit("grafana.service");
+ $postgresql->waitForUnit("postgresql.service");
+ $postgresql->waitForOpenPort(3000);
+ $postgresql->waitForOpenPort(5432);
+ $postgresql->succeed("curl -sSfN -u testadmin:snakeoilpwd http://127.0.0.1:3000/api/org/users | grep -q testadmin\@localhost");
+ };
+
+ subtest "Grafana mysql", sub {
+ $mysql->waitForUnit("grafana.service");
+ $mysql->waitForUnit("mysql.service");
+ $mysql->waitForOpenPort(3000);
+ $mysql->waitForOpenPort(3306);
+ $mysql->succeed("curl -sSfN -u testadmin:snakeoilpwd http://127.0.0.1:3000/api/org/users | grep -q testadmin\@localhost");
+ };
'';
})