mirror of
https://github.com/wesnoth/wesnoth
synced 2025-05-04 00:59:49 +00:00
41 lines
1.3 KiB
Batchfile
41 lines
1.3 KiB
Batchfile
:: WML_tests.cmd : Run the WML unit tests specified in wml_test_schedule
|
|
|
|
:: preamble: don't spam stdout with commands, don't expand ERRORLEVEL to 0
|
|
@echo off
|
|
setlocal enabledelayedexpansion
|
|
|
|
:: save file paths and command line arguments
|
|
set LoadFile=%~p0..\..\wml_test_schedule
|
|
set binary=wesnoth.exe
|
|
set opt=--log-strict=warning
|
|
:: OutDir is necessary for VC debug configuration, defaults to wesnoth\
|
|
if "%1"=="" ( set "OutDir=..\..\") else ( set "OutDir=%~p1")
|
|
|
|
cd %OutDir%
|
|
echo running WML tests:
|
|
|
|
:: ignore lines beginning with #
|
|
:: %%G contains whether the test should pass (0), timeout (2) or fail (1,4)
|
|
:: %%H is the name of the WML unit test to be executed
|
|
for /f "eol=# tokens=1,2 delims= " %%G in (%LoadFile%) do (
|
|
:: WindowsTimeout is more reliable than the --timeout option
|
|
WindowsTimeout.exe "%binary% %opt% -u %%H" 20000
|
|
if !ERRORLEVEL! neq %%G (
|
|
if !ERRORLEVEL! equ 2 (
|
|
echo(
|
|
echo WML_tests.cmd: Warning WML2: Test '%%H' timed out, expected return value %%G
|
|
) else (
|
|
echo(
|
|
echo WML_tests.cmd: Error WML1: Test '%%H' returned !ERRORLEVEL!, expected %%G
|
|
)
|
|
)
|
|
:: minimalistic progress bar
|
|
<nul (set/p progress=.)
|
|
)
|
|
echo(
|
|
echo WML tests completed
|
|
|
|
:: restore the state before execution
|
|
cd %~p0
|
|
echo on
|