2020-07-28 13:47:36 +01:00
|
|
|
import ./make-test-python.nix ({ pkgs, ...} :
|
|
|
|
|
|
|
|
let
|
|
|
|
port = 10004;
|
|
|
|
tcpPort = 10005;
|
|
|
|
httpPort = 10080;
|
2020-09-27 19:49:23 +01:00
|
|
|
tcpStreamPort = 10006;
|
2021-02-07 22:22:06 +00:00
|
|
|
bufferSize = 742;
|
2020-07-28 13:47:36 +01:00
|
|
|
in {
|
|
|
|
name = "snapcast";
|
2021-01-10 19:08:30 +00:00
|
|
|
meta = with pkgs.lib.maintainers; {
|
2020-07-28 13:47:36 +01:00
|
|
|
maintainers = [ hexa ];
|
|
|
|
};
|
|
|
|
|
|
|
|
nodes = {
|
|
|
|
server = {
|
|
|
|
services.snapserver = {
|
|
|
|
enable = true;
|
|
|
|
port = port;
|
|
|
|
tcp.port = tcpPort;
|
|
|
|
http.port = httpPort;
|
2022-01-04 07:44:10 +00:00
|
|
|
openFirewall = true;
|
2021-02-07 22:22:06 +00:00
|
|
|
buffer = bufferSize;
|
2020-07-28 13:47:36 +01:00
|
|
|
streams = {
|
|
|
|
mpd = {
|
|
|
|
type = "pipe";
|
|
|
|
location = "/run/snapserver/mpd";
|
2020-09-27 19:49:23 +01:00
|
|
|
query.mode = "create";
|
2020-07-28 13:47:36 +01:00
|
|
|
};
|
|
|
|
bluetooth = {
|
|
|
|
type = "pipe";
|
|
|
|
location = "/run/snapserver/bluetooth";
|
|
|
|
};
|
2020-09-27 19:49:23 +01:00
|
|
|
tcp = {
|
|
|
|
type = "tcp";
|
|
|
|
location = "127.0.0.1:${toString tcpStreamPort}";
|
|
|
|
};
|
2021-03-25 02:55:46 +00:00
|
|
|
meta = {
|
|
|
|
type = "meta";
|
|
|
|
location = "/mpd/bluetooth/tcp";
|
|
|
|
};
|
2020-07-28 13:47:36 +01:00
|
|
|
};
|
|
|
|
};
|
2021-12-16 22:25:12 +00:00
|
|
|
environment.systemPackages = [ pkgs.snapcast ];
|
2020-07-28 13:47:36 +01:00
|
|
|
};
|
2021-02-07 22:22:06 +00:00
|
|
|
client = {
|
|
|
|
environment.systemPackages = [ pkgs.snapcast ];
|
|
|
|
};
|
2020-07-28 13:47:36 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
testScript = ''
|
|
|
|
import json
|
|
|
|
|
|
|
|
get_rpc_version = {"id": "1", "jsonrpc": "2.0", "method": "Server.GetRPCVersion"}
|
|
|
|
|
|
|
|
start_all()
|
|
|
|
|
|
|
|
server.wait_for_unit("snapserver.service")
|
|
|
|
server.wait_until_succeeds("ss -ntl | grep -q ${toString port}")
|
|
|
|
server.wait_until_succeeds("ss -ntl | grep -q ${toString tcpPort}")
|
|
|
|
server.wait_until_succeeds("ss -ntl | grep -q ${toString httpPort}")
|
2020-09-27 19:49:23 +01:00
|
|
|
server.wait_until_succeeds("ss -ntl | grep -q ${toString tcpStreamPort}")
|
2020-07-28 13:47:36 +01:00
|
|
|
|
|
|
|
with subtest("check that pipes are created"):
|
|
|
|
server.succeed("test -p /run/snapserver/mpd")
|
|
|
|
server.succeed("test -p /run/snapserver/bluetooth")
|
|
|
|
|
|
|
|
with subtest("test tcp json-rpc"):
|
|
|
|
server.succeed(f"echo '{json.dumps(get_rpc_version)}' | nc -w 1 localhost ${toString tcpPort}")
|
|
|
|
|
|
|
|
with subtest("test http json-rpc"):
|
|
|
|
server.succeed(
|
|
|
|
"curl --fail http://localhost:${toString httpPort}/jsonrpc -d '{json.dumps(get_rpc_version)}'"
|
|
|
|
)
|
2021-02-07 22:22:06 +00:00
|
|
|
|
2021-12-16 22:25:12 +00:00
|
|
|
with subtest("test a ipv6 connection"):
|
|
|
|
server.execute("systemd-run --unit=snapcast-local-client snapclient -h ::1 -p ${toString port}")
|
|
|
|
server.wait_until_succeeds(
|
|
|
|
"journalctl -o cat -u snapserver.service | grep -q 'Hello from'"
|
|
|
|
)
|
|
|
|
server.wait_until_succeeds("journalctl -o cat -u snapcast-local-client | grep -q 'buffer: ${toString bufferSize}'")
|
|
|
|
|
2021-02-07 22:22:06 +00:00
|
|
|
with subtest("test a connection"):
|
2021-06-03 19:29:02 +01:00
|
|
|
client.execute("systemd-run --unit=snapcast-client snapclient -h server -p ${toString port}")
|
2021-02-07 22:22:06 +00:00
|
|
|
server.wait_until_succeeds(
|
|
|
|
"journalctl -o cat -u snapserver.service | grep -q 'Hello from'"
|
|
|
|
)
|
2021-06-03 19:29:02 +01:00
|
|
|
client.wait_until_succeeds("journalctl -o cat -u snapcast-client | grep -q 'buffer: ${toString bufferSize}'")
|
2020-07-28 13:47:36 +01:00
|
|
|
'';
|
|
|
|
})
|