2020-11-29 17:51:50 +00:00
|
|
|
import ./make-test-python.nix (
|
|
|
|
{ pkgs, lib, ... }:
|
|
|
|
{
|
|
|
|
name = "hedgedoc";
|
|
|
|
|
|
|
|
meta = with lib.maintainers; {
|
|
|
|
maintainers = [ willibutz ];
|
2023-07-19 23:22:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
nodes = {
|
|
|
|
hedgedocSqlite =
|
|
|
|
{ ... }:
|
|
|
|
{
|
|
|
|
services.hedgedoc.enable = true;
|
|
|
|
};
|
2020-11-29 17:51:50 +00:00
|
|
|
|
2023-07-19 23:22:43 +00:00
|
|
|
hedgedocPostgresWithTCPSocket =
|
|
|
|
{ ... }:
|
|
|
|
{
|
2020-11-29 17:51:50 +00:00
|
|
|
systemd.services.hedgedoc.after = [ "postgresql.service" ];
|
|
|
|
services = {
|
|
|
|
hedgedoc = {
|
|
|
|
enable = true;
|
2023-07-19 23:22:43 +00:00
|
|
|
settings.db = {
|
|
|
|
dialect = "postgres";
|
|
|
|
user = "hedgedoc";
|
|
|
|
password = "$DB_PASSWORD";
|
|
|
|
host = "localhost";
|
|
|
|
port = 5432;
|
|
|
|
database = "hedgedocdb";
|
|
|
|
};
|
2020-11-29 17:51:50 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
/*
|
2023-07-19 23:22:43 +00:00
|
|
|
Do not use pkgs.writeText for secrets as
|
|
|
|
they will end up in the world-readable Nix store.
|
2024-12-10 19:26:33 +00:00
|
|
|
*/
|
2020-11-29 17:51:50 +00:00
|
|
|
environmentFile = pkgs.writeText "hedgedoc-env" ''
|
|
|
|
DB_PASSWORD=snakeoilpassword
|
2024-12-10 19:26:33 +00:00
|
|
|
'';
|
|
|
|
};
|
2023-07-19 23:22:43 +00:00
|
|
|
postgresql = {
|
|
|
|
enable = true;
|
|
|
|
initialScript = pkgs.writeText "pg-init-script.sql" ''
|
|
|
|
CREATE ROLE hedgedoc LOGIN PASSWORD 'snakeoilpassword';
|
|
|
|
CREATE DATABASE hedgedocdb OWNER hedgedoc;
|
2020-11-29 17:51:50 +00:00
|
|
|
'';
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
|
|
|
};
|
2020-11-29 17:51:50 +00:00
|
|
|
};
|
2024-12-10 19:26:33 +00:00
|
|
|
|
2023-07-19 23:22:43 +00:00
|
|
|
hedgedocPostgresWithUNIXSocket =
|
2020-11-29 17:51:50 +00:00
|
|
|
{ ... }:
|
2024-12-10 19:26:33 +00:00
|
|
|
{
|
2020-11-29 17:51:50 +00:00
|
|
|
systemd.services.hedgedoc.after = [ "postgresql.service" ];
|
|
|
|
services = {
|
|
|
|
hedgedoc = {
|
|
|
|
enable = true;
|
2023-07-19 23:22:43 +00:00
|
|
|
settings.db = {
|
|
|
|
dialect = "postgres";
|
|
|
|
user = "hedgedoc";
|
|
|
|
password = "$DB_PASSWORD";
|
|
|
|
host = "/run/postgresql";
|
|
|
|
database = "hedgedocdb";
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
|
|
|
|
2023-07-19 23:22:43 +00:00
|
|
|
environmentFile = pkgs.writeText "hedgedoc-env" ''
|
|
|
|
DB_PASSWORD=snakeoilpassword
|
2024-12-10 19:26:33 +00:00
|
|
|
'';
|
|
|
|
};
|
2023-07-19 23:22:43 +00:00
|
|
|
postgresql = {
|
|
|
|
enable = true;
|
2020-11-29 17:51:50 +00:00
|
|
|
initialScript = pkgs.writeText "pg-init-script.sql" ''
|
|
|
|
CREATE ROLE hedgedoc LOGIN PASSWORD 'snakeoilpassword';
|
|
|
|
CREATE DATABASE hedgedocdb OWNER hedgedoc;
|
|
|
|
'';
|
2024-12-10 19:26:33 +00:00
|
|
|
};
|
|
|
|
};
|
2020-11-29 17:51:50 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
testScript = ''
|
|
|
|
start_all()
|
|
|
|
|
|
|
|
with subtest("HedgeDoc sqlite"):
|
|
|
|
hedgedocSqlite.wait_for_unit("hedgedoc.service")
|
|
|
|
hedgedocSqlite.wait_for_open_port(3000)
|
|
|
|
hedgedocSqlite.wait_until_succeeds("curl -sSf http://localhost:3000/new")
|
|
|
|
|
2023-07-19 23:22:43 +00:00
|
|
|
with subtest("HedgeDoc postgres with TCP socket"):
|
|
|
|
hedgedocPostgresWithTCPSocket.wait_for_unit("postgresql.service")
|
|
|
|
hedgedocPostgresWithTCPSocket.wait_for_unit("hedgedoc.service")
|
|
|
|
hedgedocPostgresWithTCPSocket.wait_for_open_port(5432)
|
|
|
|
hedgedocPostgresWithTCPSocket.wait_for_open_port(3000)
|
|
|
|
hedgedocPostgresWithTCPSocket.wait_until_succeeds("curl -sSf http://localhost:3000/new")
|
|
|
|
|
|
|
|
with subtest("HedgeDoc postgres with UNIX socket"):
|
|
|
|
hedgedocPostgresWithUNIXSocket.wait_for_unit("postgresql.service")
|
|
|
|
hedgedocPostgresWithUNIXSocket.wait_for_unit("hedgedoc.service")
|
|
|
|
hedgedocPostgresWithUNIXSocket.wait_for_open_port(5432)
|
|
|
|
hedgedocPostgresWithUNIXSocket.wait_for_open_port(3000)
|
|
|
|
hedgedocPostgresWithUNIXSocket.wait_until_succeeds("curl -sSf http://localhost:3000/new")
|
2020-11-29 17:51:50 +00:00
|
|
|
'';
|
|
|
|
}
|
|
|
|
)
|