Merge pull request #79016 from mayflower/nixos/openarena-test
nixos/tests/openarena: run real openarena clients
This commit is contained in:
commit
004b379cd5
@ -1,41 +1,71 @@
|
||||
import ./make-test-python.nix ({ pkgs, ...} : {
|
||||
name = "openarena";
|
||||
meta = with pkgs.stdenv.lib.maintainers; {
|
||||
maintainers = [ tomfitzhenry ];
|
||||
};
|
||||
import ./make-test-python.nix ({ pkgs, ...} :
|
||||
|
||||
machine =
|
||||
let
|
||||
client =
|
||||
{ pkgs, ... }:
|
||||
|
||||
{ imports = [];
|
||||
environment.systemPackages = with pkgs; [
|
||||
socat
|
||||
];
|
||||
services.openarena = {
|
||||
enable = true;
|
||||
extraFlags = [
|
||||
"+set dedicated 2"
|
||||
"+set sv_hostname 'My NixOS server'"
|
||||
"+map oa_dm1"
|
||||
];
|
||||
};
|
||||
{ imports = [ ./common/x11.nix ];
|
||||
hardware.opengl.driSupport = true;
|
||||
environment.systemPackages = [ pkgs.openarena ];
|
||||
};
|
||||
|
||||
in {
|
||||
name = "openarena";
|
||||
meta = with pkgs.stdenv.lib.maintainers; {
|
||||
maintainers = [ fpletz ];
|
||||
};
|
||||
|
||||
nodes =
|
||||
{ server =
|
||||
{ services.openarena = {
|
||||
enable = true;
|
||||
extraFlags = [ "+set g_gametype 0" "+map oa_dm7" "+addbot Angelyss" "+addbot Arachna" ];
|
||||
openPorts = true;
|
||||
};
|
||||
};
|
||||
|
||||
client1 = client;
|
||||
client2 = client;
|
||||
};
|
||||
|
||||
testScript =
|
||||
''
|
||||
machine.wait_for_unit("openarena.service")
|
||||
machine.wait_until_succeeds("ss --numeric --udp --listening | grep -q 27960")
|
||||
start_all()
|
||||
|
||||
# The log line containing 'resolve address' is last and only message that occurs after
|
||||
# the server starts accepting clients.
|
||||
machine.wait_until_succeeds(
|
||||
"journalctl -u openarena.service | grep 'resolve address: dpmaster.deathmask.net'"
|
||||
server.wait_for_unit("openarena")
|
||||
server.wait_until_succeeds("ss --numeric --udp --listening | grep -q 27960")
|
||||
|
||||
client1.wait_for_x()
|
||||
client2.wait_for_x()
|
||||
|
||||
client1.execute("openarena +set r_fullscreen 0 +set name Foo +connect server &")
|
||||
client2.execute("openarena +set r_fullscreen 0 +set name Bar +connect server &")
|
||||
|
||||
server.wait_until_succeeds(
|
||||
"journalctl -u openarena -e | grep -q 'Foo.*entered the game'"
|
||||
)
|
||||
server.wait_until_succeeds(
|
||||
"journalctl -u openarena -e | grep -q 'Bar.*entered the game'"
|
||||
)
|
||||
|
||||
# Check it's possible to join the server.
|
||||
# Can't use substring match instead of grep because the output is not utf-8
|
||||
machine.succeed(
|
||||
"echo -n -e '\\xff\\xff\\xff\\xffgetchallenge' | socat - UDP4-DATAGRAM:127.0.0.1:27960 | grep -q challengeResponse"
|
||||
)
|
||||
server.sleep(10) # wait for a while to get a nice screenshot
|
||||
|
||||
client1.screenshot("screen_client1_1")
|
||||
client2.screenshot("screen_client2_1")
|
||||
|
||||
client1.block()
|
||||
|
||||
server.sleep(10)
|
||||
|
||||
client1.screenshot("screen_client1_2")
|
||||
client2.screenshot("screen_client2_2")
|
||||
|
||||
client1.unblock()
|
||||
|
||||
server.sleep(10)
|
||||
|
||||
client1.screenshot("screen_client1_3")
|
||||
client2.screenshot("screen_client2_3")
|
||||
'';
|
||||
|
||||
})
|
||||
|
Loading…
Reference in New Issue
Block a user