Skip to content

Refact/zomboid2.0

Refact/zomboid2.0 #199

Workflow file for this run

#
# Project Zomboid Dedicated Server using SteamCMD Docker Image.
# Copyright (C) 2021-2022 Renegade-Master [[email protected]]
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
#
name: Build and Test Server Image
on:
push:
branches: [ main ]
pull_request:
branches: [ main ]
defaults:
run:
shell: bash
jobs:
build-and-run:
name: Build and Run Server
runs-on: ubuntu-latest
strategy:
matrix:
system: [docker, docker-compose, podman]
steps:
- name: Checkout Repository
uses: actions/checkout@v3
- name: Set Variables
id: variables
run: |
echo "::set-output name=datetime::$(date +%Y%m%dT%H%M%SZ)"
echo "::set-output name=userid::$(id -u)"
echo "::set-output name=groupid::$(id -g)"
- name: Set Permissions on Executable Scripts
run: |
chmod +x src/install_server.scmd
chmod +x src/run_server.sh
- name: Make Directories
run: mkdir ZomboidConfig ZomboidDedicatedServer
#######################
# Docker Build System #
#######################
- name: Build the Docker Image
if: ${{ success() && matrix.system == 'docker' }}
run: |
docker build \
--file docker/zomboid-dedicated-server.Dockerfile \
--tag docker.io/renegademaster/zomboid-dedicated-server:${{ steps.variables.outputs.datetime }} \
.
- name: Test Run the Docker Image
if: ${{ success() && matrix.system == 'docker' }}
continue-on-error: true
timeout-minutes: 10
run: |
# Start a timed shutdown signal
(sleep 360 && docker exec \
zomboid-dedicated-server bash -c \
"rcon -a $(cat ZomboidConfig/ip.txt):\${RCON_PORT} -p \${RCON_PASSWORD} quit") &
# Run the Docker Image
docker run \
--rm \
--name zomboid-dedicated-server \
--mount type=bind,source="$(pwd)/ZomboidDedicatedServer",target=/home/steam/ZomboidDedicatedServer \
--mount type=bind,source="$(pwd)/ZomboidConfig",target=/home/steam/Zomboid \
--env=AUTOSAVE_INTERVAL="16" \
--env=DEFAULT_PORT="25496" \
--env=GC_CONFIG="G1GC" \
--env=MAP_NAMES="BedfordFalls;North;South;West" \
--env=MAX_PLAYERS="14" \
--env=MAX_RAM="6144m" \
--env=MOD_NAMES="BedfordFalls" \
--env=MOD_WORKSHOP_IDS="522891356" \
--env=PAUSE_ON_EMPTY="true" \
--env=PUBLIC_SERVER="false" \
--env=RCON_PASSWORD="github_action_test_rcon_password" \
--env=RCON_PORT="27025" \
--env=SERVER_NAME="GitHubActionTest" \
--env=SERVER_PASSWORD="github_action_test_password" \
--env=UDP_PORT="25499" \
docker.io/renegademaster/zomboid-dedicated-server:${{ steps.variables.outputs.datetime }} \
2>&1 | tee ./docker-log.log
###############################
# Docker-Compose Build System #
###############################
- name: Update Docker-Compose File
if: ${{ success() && matrix.system == 'docker-compose' }}
run: |
sed -i "s/AUTOSAVE_INTERVAL=.*\"/AUTOSAVE_INTERVAL=16\"/g" "./docker-compose.yaml"
sed -i "s/DEFAULT_PORT=.*\"/DEFAULT_PORT=25496\"/g" "./docker-compose.yaml"
sed -i "s/GC_CONFIG=.*\"/GC_CONFIG=G1GC\"/g" "./docker-compose.yaml"
sed -i "s/MAP_NAMES=.*\"/MAP_NAMES=BedfordFalls;North;South;West\"/g" "./docker-compose.yaml"
sed -i "s/MAX_PLAYERS=.*\"/MAX_PLAYERS=14\"/g" "./docker-compose.yaml"
sed -i "s/MAX_RAM=.*m\"/MAX_RAM=6144m\"/g" "./docker-compose.yaml"
sed -i "s/MOD_NAMES=.*\"/MOD_NAMES=BedfordFalls\"/g" "./docker-compose.yaml"
sed -i "s/MOD_WORKSHOP_IDS=.*\"/MOD_WORKSHOP_IDS=522891356\"/g" "./docker-compose.yaml"
sed -i "s/PUBLIC_SERVER=.*/PUBLIC_SERVER=false\"/g" "./docker-compose.yaml"
sed -i "s/RCON_PASSWORD=.*/RCON_PASSWORD=github_action_test_rcon_password\"/g" "./docker-compose.yaml"
sed -i "s/RCON_PORT=.*\"/RCON_PORT=27025\"/g" "./docker-compose.yaml"
sed -i "s/SERVER_NAME=.*/SERVER_NAME=GitHubActionTest\"/g" "./docker-compose.yaml"
sed -i "s/SERVER_PASSWORD=.*/SERVER_PASSWORD=github_action_test_password\"/g" "./docker-compose.yaml"
sed -i "s/UDP_PORT=.*\"/UDP_PORT=25499\"/g" "./docker-compose.yaml"
cat docker-compose.yaml
- name: Build the Docker-Compose Image
if: ${{ success() && matrix.system == 'docker-compose' }}
run: |
docker-compose build
- name: Test Run the Docker-Compose Image
if: ${{ success() && matrix.system == 'docker-compose' }}
continue-on-error: true
timeout-minutes: 10
run: |
# Start a timed shutdown signal
(sleep 360 && docker exec \
zomboid-dedicated-server bash -c \
"rcon -a $(cat ZomboidConfig/ip.txt):\${RCON_PORT} -p \${RCON_PASSWORD} quit") &
# Run the Docker-Compose Image
docker-compose up \
2>&1 | tee ./docker-log.log
#######################
# Podman Build System #
#######################
- name: Build the Podman Image
if: ${{ success() && matrix.system == 'podman' }}
run: |
BUILDAH_LAYERS=true buildah bud \
--file docker/zomboid-dedicated-server.Dockerfile \
--tag docker.io/renegademaster/zomboid-dedicated-server:${{ steps.variables.outputs.datetime }} \
.
- name: Test Run the Podman Image
if: ${{ success() && matrix.system == 'podman' }}
continue-on-error: true
timeout-minutes: 10
run: |
# Start a timed shutdown signal
(sleep 360 && podman exec \
zomboid-dedicated-server bash -c \
"rcon -a $(cat ZomboidConfig/ip.txt):\${RCON_PORT} -p \${RCON_PASSWORD} quit") &
# Run the Podman Image
podman run \
--rm \
--name zomboid-dedicated-server \
--mount type=bind,source="$(pwd)/ZomboidDedicatedServer",target=/home/steam/ZomboidDedicatedServer \
--mount type=bind,source="$(pwd)/ZomboidConfig",target=/home/steam/Zomboid \
--env=AUTOSAVE_INTERVAL="16" \
--env=DEFAULT_PORT="25496" \
--env=GC_CONFIG="G1GC" \
--env=MAP_NAMES="BedfordFalls;North;South;West" \
--env=MAX_PLAYERS="14" \
--env=MAX_RAM="6144m" \
--env=MOD_NAMES="BedfordFalls" \
--env=MOD_WORKSHOP_IDS="522891356" \
--env=PAUSE_ON_EMPTY="true" \
--env=PUBLIC_SERVER="false" \
--env=RCON_PASSWORD="github_action_test_rcon_password" \
--env=RCON_PORT="27025" \
--env=SERVER_NAME="GitHubActionTest" \
--env=SERVER_PASSWORD="github_action_test_password" \
--env=UDP_PORT="25499" \
docker.io/renegademaster/zomboid-dedicated-server:${{ steps.variables.outputs.datetime }} \
2>&1 | tee ./docker-log.log
- name: Investigate File Structure
run: |
pwd
echo ''
ls -lAuhFn ./ZomboidDedicatedServer/ > ./dedicated-server-install-listing.txt
echo ''
ls -lAuhFn ./ZomboidConfig/ > ./dedicated-server-config-listing.txt
echo ''
tree -aL 10 ./ZomboidDedicatedServer/ > ./dedicated-server-install-tree.txt
echo ''
tree -aL 10 ./ZomboidConfig/ > ./dedicated-server-config-tree.txt
- name: Upload Docker Logs
if: ${{ always() }}
uses: actions/upload-artifact@v2
with:
name: docker-logs-${{ matrix.system }}
path: |
docker-log.log
- name: Upload Server Configuration
if: ${{ always() }}
uses: actions/upload-artifact@v2
with:
name: server-configs-${{ matrix.system }}
path: |
docker-compose.yaml
ZomboidConfig/Server/GitHubActionTest.ini
ZomboidConfig/Server/GitHubActionTest_SandboxVars.lua
ZomboidDedicatedServer/ProjectZomboid64.json
dedicated-server-install-listing.txt
dedicated-server-config-listing.txt
dedicated-server-install-tree.txt
dedicated-server-config-tree.txt
test-docker:
name: Test Server
runs-on: ubuntu-latest
needs:
- build-and-run
strategy:
matrix:
system: [docker, docker-compose, podman]
steps:
- name: Checkout Repository
uses: actions/checkout@v3
- name: Download Docker Logs
uses: actions/download-artifact@v2
with:
name: docker-logs-${{ matrix.system }}
- name: Download Server Configs
uses: actions/download-artifact@v2
with:
name: server-configs-${{ matrix.system }}
- name: Test - Server Started
run: |
check_for_config() {
if ! grep -q -iE "$1" "./docker-log.log"; then
printf "Could not find [%s] in [%s]\n" "$1" "./docker-log.log"
exit 1
else
printf "Found [%s] in [%s]\n" "$1" "./docker-log.log"
fi
}
check_for_config "LuaNet: Initialization \[DONE\]"
- name: Test - Server Stopped Gracefully
run: |
check_for_config() {
if ! grep -q -iE "$1" "./docker-log.log"; then
printf "Could not find [%s] in [%s]\n" "$1" "./docker-log.log"
exit 1
else
printf "Found [%s] in [%s]\n" "$1" "./docker-log.log"
fi
}
check_for_config "ZNet: SZombienet -> SSteamSDK: LogOff"
- name: Test - Configuration Completed
run: |
check_for_config() {
if ! grep -q -iE "$1" "./docker-log.log"; then
printf "Could not find [%s] in [%s]\n" "$1" "./docker-log.log"
else
printf "Found [%s] in [%s]\n" "$1" "./docker-log.log"
exit 1
fi
}
check_for_config "sed: can't read"
check_for_config "not found!"
- name: Test - Server JVM Configuration Applied
run: |
check_for_config() {
if ! grep -q -iE "$1" "./ZomboidDedicatedServer/ProjectZomboid64.json"; then
printf "Could not find [%s] in [%s]\n" "$1" "./ZomboidDedicatedServer/ProjectZomboid64.json"
exit 1
else
printf "Found [%s] in [%s]\n" "$1" "./ZomboidDedicatedServer/ProjectZomboid64.json"
fi
}
check_for_config "\-Xmx6144m"
check_for_config "\-XX:\+UseG1GC"
- name: Test - Server Configuration Applied
run: |
install_directory="./ZomboidDedicatedServer"
workshop_directory="${install_directory}/steamapps/workshop"
mods_directory="${workshop_directory}/content/108600/522891356/mods"
bedford_maps="${mods_directory}/Bedford Falls/media/maps"
map_search_string="$(cat << EOF
│   ├── content
│   │   └── 108600
│   │   └── 522891356
│   │   └── mods
│   │   └── Bedford Falls
│   │   ├── media
│   │   │   ├── lua
│   │   │   │   ├── client
EOF
)"
py_script="$(cat << EOF
to_find = """${map_search_string}"""
with open("dedicated-server-install-tree.txt", "r") as file:
file_string = file.read()
if (to_find in file_string):
print("FOUND")
else:
print("NOT_FOUND")
EOF
)"
check_for_config() {
if ! grep -q -iE "$1" "./ZomboidConfig/Server/GitHubActionTest.ini"; then
printf "Could not find [%s] in [%s]\n" "$1" "./ZomboidConfig/Server/GitHubActionTest.ini"
exit 1
else
printf "Found [%s] in [%s]\n" "$1" "./ZomboidConfig/Server/GitHubActionTest.ini"
fi
}
check_for_directory() {
if [[ $(python3 -c "${py_script}") == "FOUND" ]]; then
printf "Found map directory in [%s]\n" "${bedford_maps}"
else
printf "Could not find map directory in [%s]\n" "${bedford_maps}"
exit 1
fi
}
check_for_config "DefaultPort=25496"
check_for_config "Map=BedfordFalls;North;South;West"
check_for_config "MaxPlayers=14"
check_for_config "Open=false"
check_for_config "Password=github_action_test_password"
check_for_config "PauseEmpty=true"
check_for_config "PublicName=GitHubActionTest"
check_for_config "RCONPassword=github_action_test_rcon_password"
check_for_config "RCONPort=27025"
check_for_config "SaveWorldEveryMinutes=16"
check_for_config "UDPPort=25499"
check_for_directory