before_script:\r
- ln -s $PWD data/xonotic-data.pk3dir\r
\r
+ - export MAKEFLAGS=-j$(nproc); echo MAKEFLAGS=$MAKEFLAGS\r
+# FIXME: -march=native -mtune=native _changes the hash_, why?!?\r
+# - export CC="gcc -pipe -march=native -mtune=native"\r
+ - export CC="gcc -pipe"\r
+\r
- git clone --depth=1 --branch=main https://gitlab.com/xonotic/gmqcc.git gmqcc\r
- - cd gmqcc && make -j $(nproc) && export QCC="$PWD/gmqcc"\r
- - cd ..\r
+ - make -C gmqcc || exit 1\r
+ - export QCC="$PWD/gmqcc/gmqcc"\r
+\r
+ # Makefile: don't complain about lack of tags (fetching them is slow)\r
+ - export QCCFLAGS_WATERMARK=gitlab_pipeline\r
+ # Makefile: don't compress anything or complain about lack of zip program\r
+ - export ZIP=/bin/true\r
\r
test_compilation_units:\r
rules:\r
- qcsrc/**/*\r
stage: test\r
script:\r
- - ./qcsrc/tools/compilationunits.sh\r
+ - make test\r
\r
test_sv_game:\r
stage: test\r
script:\r
- git clone --depth=1 --branch=div0-stable https://gitlab.com/xonotic/darkplaces.git darkplaces\r
- - cd darkplaces && make sv-debug -j $(nproc) && export ENGINE="$PWD/darkplaces-dedicated -xonotic"\r
- - cd ..\r
+ - make -C darkplaces sv-release || exit 1\r
+ - export ENGINE="$PWD/darkplaces/darkplaces-dedicated -xonotic -noconfig -nohome"\r
+ - make qc || exit 1\r
\r
- mkdir -p data/maps\r
+ - wget -O data/maps/gitlab-ci.bsp https://gitlab.com/xonotic/xonotic-maps.pk3dir/raw/master/maps/_init/_init.bsp\r
+\r
+ - while read LINE; do\r
+ echo $LINE;\r
+ [ "$LINE" = "All tests OK" ] && PASS=1;\r
+ done < <(${ENGINE} +developer 1 +map gitlab-ci +sv_cmd runtest +wait +quit)\r
+ - test "$PASS" = "1" || { echo 'sv_cmd runtest failed!'; exit 1; }\r
+\r
+ - ${ENGINE} +map gitlab-ci +sv_cmd dumpnotifs +wait +quit\r
+ - diff notifications.cfg data/data/notifications_dump.cfg ||\r
+ { echo 'Please update notifications.cfg using `dumpnotifs`!'; exit 1; }\r
+\r
- wget -O data/stormkeep.pk3 http://beta.xonotic.org/autobuild-bsp/latest/stormkeep.pk3\r
- wget -O data/maps/stormkeep.mapinfo https://gitlab.com/xonotic/xonotic-maps.pk3dir/raw/master/maps/stormkeep.mapinfo\r
- wget -O data/maps/stormkeep.waypoints https://gitlab.com/xonotic/xonotic-maps.pk3dir/raw/master/maps/stormkeep.waypoints\r
- wget -O data/maps/stormkeep.waypoints.cache https://gitlab.com/xonotic/xonotic-maps.pk3dir/raw/master/maps/stormkeep.waypoints.cache\r
- - make\r
+\r
- EXPECT=d4060caf37a2e60bab68d1f83bc57368\r
- - HASH=$(${ENGINE} -noconfig -nohome +timestamps 1 +exec serverbench.cfg\r
+ - HASH=$(${ENGINE} +timestamps 1 +exec serverbench.cfg\r
| tee /dev/stderr\r
| sed -e 's,^\[[^]]*\] ,,'\r
| grep '^:'\r
- test "$HASH" == "$EXPECT"\r
- exit $?\r
\r
-test_sv_unit:\r
- stage: test\r
- script:\r
- - git clone --depth=1 --branch=div0-stable https://gitlab.com/xonotic/darkplaces.git darkplaces\r
- - cd darkplaces && make sv-debug -j $(nproc) && export ENGINE="$PWD/darkplaces-dedicated -xonotic"\r
- - cd ..\r
-\r
- - mkdir maps && wget -O maps/gitlab-ci.bsp https://gitlab.com/xonotic/xonotic-maps.pk3dir/raw/master/maps/_init/_init.bsp\r
- - make\r
- - while read line; do\r
- echo $line;\r
- if [[ $line == "All tests OK" ]]; then exit 0; fi;\r
- done < <(${ENGINE} +developer 1 +map gitlab-ci +sv_cmd runtest +exit)\r
- - exit 1\r
\r
# NOTE: The generated docs are incomplete - they don't contain code behind SVQC CSQC MENUQC GAMEQC ifdefs.\r
# With them added to PREDEFINED, it would take over half an hour to generate the docs and even then\r
void antilag_record(entity e, entity store, float t)
{
- if (e.vehicle) {
- if (e.vehicle.vehicle_flags == VHF_PLAYERSLOT) return;
- antilag_record(e.vehicle, e.vehicle, t);
- }
+ if (e.vehicle) {
+ if (e.vehicle.vehicle_flags == VHF_PLAYERSLOT) return;
+ antilag_record(e.vehicle, e.vehicle, t);
+ }
if (time < store.antilag_times[store.antilag_index]) return;
store.antilag_index += 1;
void antilag_takeback(entity e, entity store, float t)
{
if (e.vehicle) {
- if (e.vehicle.vehicle_flags == VHF_PLAYERSLOT) return;
+ if (e.vehicle.vehicle_flags == VHF_PLAYERSLOT) return;
antilag_takeback(e.vehicle, e.vehicle, t);
- }
+ }
if (!store.antilag_takenback)
store.antilag_saved_origin = e.origin;
void antilag_restore(entity e, entity store)
{
if (e.vehicle) {
- if (e.vehicle.vehicle_flags == VHF_PLAYERSLOT) return;
+ if (e.vehicle.vehicle_flags == VHF_PLAYERSLOT) return;
antilag_restore(e.vehicle, e.vehicle);
}
#!/usr/bin/env bash
+[ -z "$QCCFLAGS_WATERMARK" ] && export QCCFLAGS_WATERMARK=$(git describe --tags --dirty='~')
set -eu
cd ${0%/*}
declare -a QCCDEFS=(
-DNDEBUG=1
-DXONOTIC=1
- -DWATERMARK="\"$(git describe --tags --dirty='~')\""
+ -DWATERMARK="\"$QCCFLAGS_WATERMARK\""
-DENABLE_EFFECTINFO=0
-DENABLE_DEBUGDRAW=0
-DENABLE_DEBUGTRACE=0
MODE=${prog}
includes="-include lib/_all.inc"
[ -f ${prog}/_all.qh ] && includes="${includes} -include ${prog}/_all.qh"
- qpp ${file} test.dat \
+ qpp ${file} test-${prog}.dat \
${includes} \
-I. ${QCCIDENT} ${QCCDEFS} > ${WORKDIR}/${prog}.qc
- qcc ${QCCFLAGS} -o ../${WORKDIR}/test.dat ../${WORKDIR}/${prog}.qc >/dev/null
+ qcc ${QCCFLAGS} -o ../${WORKDIR}/test-${prog}.dat ../${WORKDIR}/${prog}.qc >/dev/null
}
function check() {
check menu
else
for var in ${@}; do
+ var=${var#test-}
check ${var}
done
fi