Test server chat in CI (#13)
This commit is contained in:
parent
ec90f185e4
commit
96a29c9429
3
.github/workflows/integration.yml
vendored
3
.github/workflows/integration.yml
vendored
|
@ -58,3 +58,6 @@ jobs:
|
||||||
- name: '[SERVER] Test connect'
|
- name: '[SERVER] Test connect'
|
||||||
run: |
|
run: |
|
||||||
./integration_test/run.sh server/connect.rb
|
./integration_test/run.sh server/connect.rb
|
||||||
|
- name: '[SERVER] Test chat'
|
||||||
|
run: |
|
||||||
|
./integration_test/run.sh server/chat.rb
|
||||||
|
|
|
@ -154,7 +154,7 @@ fail() {
|
||||||
echo "[-] end of ruby server log:"
|
echo "[-] end of ruby server log:"
|
||||||
tail -n 10 "$ruby_logfile"
|
tail -n 10 "$ruby_logfile"
|
||||||
echo "[-] end of client log:"
|
echo "[-] end of client log:"
|
||||||
cat "$logdir/client.txt"
|
tail -n 10 "$logdir/client.txt"
|
||||||
fi
|
fi
|
||||||
if [ ! -s "$ruby_logfile_err" ]
|
if [ ! -s "$ruby_logfile_err" ]
|
||||||
then
|
then
|
||||||
|
@ -228,7 +228,7 @@ assert_in_log() {
|
||||||
local needle="$1"
|
local needle="$1"
|
||||||
local logfile_path="$2"
|
local logfile_path="$2"
|
||||||
local num_matches="$3"
|
local num_matches="$3"
|
||||||
if ! grep -q "$needle" "$logfile_path"
|
if ! grep -qF "$needle" "$logfile_path"
|
||||||
then
|
then
|
||||||
echo "[-] Error: did not find expected string in logs"
|
echo "[-] Error: did not find expected string in logs"
|
||||||
echo "[-]"
|
echo "[-]"
|
||||||
|
@ -240,7 +240,7 @@ assert_in_log() {
|
||||||
if [ "$num_matches" != "" ]
|
if [ "$num_matches" != "" ]
|
||||||
then
|
then
|
||||||
local actual_matches
|
local actual_matches
|
||||||
actual_matches="$(grep -c "$needle" "$logfile_path")"
|
actual_matches="$(grep -cF "$needle" "$logfile_path")"
|
||||||
if [ "$actual_matches" != "$num_matches" ]
|
if [ "$actual_matches" != "$num_matches" ]
|
||||||
then
|
then
|
||||||
echo "[-] Error: found string unexpected amount of times in log file"
|
echo "[-] Error: found string unexpected amount of times in log file"
|
||||||
|
@ -324,6 +324,22 @@ then
|
||||||
|
|
||||||
assert_in_log "'test_client' joined the game" "$ruby_logfile" 1
|
assert_in_log "'test_client' joined the game" "$ruby_logfile" 1
|
||||||
assert_in_log "rcon='shutdown'" "$ruby_logfile" 1
|
assert_in_log "rcon='shutdown'" "$ruby_logfile" 1
|
||||||
|
elif [ "$testname" == "server/chat.rb" ]
|
||||||
|
then
|
||||||
|
fifo "say hello gamers" "$cl_fifo"
|
||||||
|
sleep 1
|
||||||
|
fifo "say uwu" "$cl_fifo"
|
||||||
|
sleep 1
|
||||||
|
fifo "rcon_auth test" "$cl_fifo"
|
||||||
|
sleep 1
|
||||||
|
fifo "rcon shutdown" "$cl_fifo"
|
||||||
|
sleep 1
|
||||||
|
fifo "quit" "$cl_fifo"
|
||||||
|
# ddnet quitting can get stuck so send a kill to ensure it dies
|
||||||
|
kill "$_client_pid"
|
||||||
|
|
||||||
|
assert_in_log "hello gamers" "$ruby_logfile" 1
|
||||||
|
assert_in_log "[testchat] test_client: uwu" "$ruby_logfile" 1
|
||||||
else
|
else
|
||||||
echo "Error: unkown test '$testname'"
|
echo "Error: unkown test '$testname'"
|
||||||
exit 1
|
exit 1
|
||||||
|
|
14
integration_test/server/chat.rb
Executable file
14
integration_test/server/chat.rb
Executable file
|
@ -0,0 +1,14 @@
|
||||||
|
#!/usr/bin/env ruby
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require_relative '../../lib/teeworlds_server'
|
||||||
|
|
||||||
|
server = TeeworldsServer.new(verbose: false)
|
||||||
|
|
||||||
|
server.on_chat do |context, chat_msg|
|
||||||
|
context.cancel
|
||||||
|
|
||||||
|
puts "[testchat] #{chat_msg.author.name}: #{chat_msg.message}"
|
||||||
|
end
|
||||||
|
|
||||||
|
server.run('127.0.0.1', 8377)
|
Loading…
Reference in a new issue