let
port = 4222;
username = "client";
password = "password";
topic = "foo.bar";
in
import ./make-test-python.nix (
{ pkgs, lib, ... }:
{
name = "nats";
meta = with pkgs.lib; {
maintainers = with maintainers; [ c0deaddict ];
};
nodes =
client =
{ pkgs, ... }:
environment.systemPackages = with pkgs; [ natscli ];
server =
networking.firewall.allowedTCPPorts = [ port ];
services.nats = {
inherit port;
enable = true;
settings = {
authorization = {
users = [
user = username;
inherit password;
}
];
client1 = client;
client2 = client;
testScript =
file = "/tmp/msg";
''
def nats_cmd(*args):
return (
"nats "
"--server=nats://server:${toString port} "
"--user=${username} "
"--password=${password} "
"{}"
).format(" ".join(args))
def parallel(*fns):
from threading import Thread
threads = [ Thread(target=fn) for fn in fns ]
for t in threads: t.start()
for t in threads: t.join()
start_all()
server.wait_for_unit("nats.service")
with subtest("pub sub"):
parallel(
lambda: client1.succeed(nats_cmd("sub", "--count", "1", "${topic}")),
lambda: client2.succeed("sleep 2 && {}".format(nats_cmd("pub", "${topic}", "hello"))),
)
'';