about summary refs log tree commit diff
path: root/nixos/tests/monetdb.nix
blob: acbf01f7697564030360ecc3daa7d43a9a1a6429 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import ./make-test-python.nix ({ pkgs, ...} :
  let creds = pkgs.writeText ".monetdb" ''
        user=monetdb
        password=monetdb
      '';
      createUser = pkgs.writeText "createUser.sql" ''
        CREATE USER "voc" WITH PASSWORD 'voc' NAME 'VOC Explorer' SCHEMA "sys";
        CREATE SCHEMA "voc" AUTHORIZATION "voc";
        ALTER USER "voc" SET SCHEMA "voc";
      '';
      credsVoc = pkgs.writeText ".monetdb" ''
        user=voc
        password=voc
      '';
      transaction = pkgs.writeText "transaction" ''
        START TRANSACTION;
        CREATE TABLE test (id int, data varchar(30));
        ROLLBACK;
      '';
      vocData = pkgs.fetchzip {
        url = "https://dev.monetdb.org/Assets/VOC/voc_dump.zip";
        hash = "sha256-sQ5acTsSAiXQfOgt2PhN7X7Z9TZGZtLrPPxgQT2pCGQ=";
      };
      onboardPeople = pkgs.writeText "onboardPeople" ''
        CREATE VIEW onboard_people AS
        SELECT * FROM (
        SELECT 'craftsmen' AS type, craftsmen.* FROM craftsmen
        UNION ALL
        SELECT 'impotenten' AS type, impotenten.* FROM impotenten
        UNION ALL
        SELECT 'passengers' AS type, passengers.* FROM passengers
        UNION ALL
        SELECT 'seafarers' AS type, seafarers.* FROM seafarers
        UNION ALL
        SELECT 'soldiers' AS type, soldiers.* FROM soldiers
        UNION ALL
        SELECT 'total' AS type, total.* FROM total
        ) AS onboard_people_table;
        SELECT type, COUNT(*) AS total
        FROM onboard_people GROUP BY type ORDER BY type;
      '';
      onboardExpected = pkgs.lib.strings.replaceStrings ["\n"] ["\\n"] ''
        +------------+-------+
        | type       | total |
        +============+=======+
        | craftsmen  |  2349 |
        | impotenten |   938 |
        | passengers |  2813 |
        | seafarers  |  4468 |
        | soldiers   |  4177 |
        | total      |  2467 |
        +------------+-------+
      '';
  in {
    name = "monetdb";
    meta = with pkgs.lib.maintainers; {
      maintainers = [ StillerHarpo ];
    };
    nodes.machine.services.monetdb.enable = true;
    testScript = ''
      machine.start()
      machine.wait_for_unit("monetdb")
      machine.succeed("monetdbd create mydbfarm")
      machine.succeed("monetdbd start mydbfarm")
      machine.succeed("monetdb create voc")
      machine.succeed("monetdb release voc")
      machine.succeed("cp ${creds} ./.monetdb")
      assert "hello world" in machine.succeed("mclient -d voc -s \"SELECT 'hello world'\"")
      machine.succeed("mclient -d voc ${createUser}")
      machine.succeed("cp ${credsVoc} ./.monetdb")
      machine.succeed("mclient -d voc ${transaction}")
      machine.succeed("mclient -d voc ${vocData}/voc_dump.sql")
      assert "8131" in machine.succeed("mclient -d voc -s \"SELECT count(*) FROM voyages\"")
      assert "${onboardExpected}" in machine.succeed("mclient -d voc ${onboardPeople}")

  '';
  })