import ./make-test-python.nix ({ ... } :

let
  node = { pkgs, ... } : {
    networking = {
      firewall = {
        allowedUDPPorts = [ 4791 ]; # open RoCE port
        allowedTCPPorts = [ 4800 ]; # port for test utils
      };
      rxe = {
        enable = true;
        interfaces = [ "eth1" ];
      };
    };

    environment.systemPackages = with pkgs; [ rdma-core screen ];
  };

in {
  name = "rxe";

  nodes = {
    server = node;
    client = node;
  };

  testScript = ''
    # Test if rxe interface comes up
    server.wait_for_unit("default.target")
    server.succeed("systemctl status rxe.service")
    server.succeed("ibv_devices | grep rxe_eth1")

    client.wait_for_unit("default.target")

    # ping pong tests
    for proto in "rc", "uc", "ud", "srq":
        server.succeed(
            "screen -dmS {0}_pingpong ibv_{0}_pingpong -p 4800 -s 1024 -g0".format(proto)
        )
        client.succeed("sleep 2; ibv_{}_pingpong -p 4800 -s 1024 -g0 server".format(proto))

    server.succeed("screen -dmS rping rping -s -a server -C 10")
    client.succeed("sleep 2; rping -c -a server -C 10")
  '';
})