4
mirror of git://git.acid.vegas/unrealircd.git synced 2025-01-06 05:26:43 +00:00
unrealircd/extras/build-tests/windows/build.bat

111 lines
3.8 KiB
Batchfile
Raw Normal View History

2020-03-29 09:16:53 +00:00
echo on
rem Temporarily hardcoded:
set TARGET=Visual Studio 2019
set SHORTNAME=vs2019
rem Initialize Visual Studio variables
if "%TARGET%" == "Visual Studio 2017" call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars64.bat"
if "%TARGET%" == "Visual Studio 2019" call "C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Auxiliary\Build\vcvars64.bat"
rem Installing tools
rem only for appveyor:
rem cinst unrar -y
rem cinst unzip -y
rem cinst innosetup -y
rem Installing UnrealIRCd dependencies
cd \projects
2022-01-15 05:16:34 +00:00
mkdir unrealircd-6-libs
cd unrealircd-6-libs
curl -fsS -o unrealircd-libraries-6-devel.zip https://www.unrealircd.org/files/dev/win/libs/unrealircd-libraries-6-devel.zip
unzip unrealircd-libraries-6-devel.zip
copy dlltool.exe \users\user\worker\unreal6-w10\build /y
2020-03-29 09:16:53 +00:00
2022-01-15 05:16:34 +00:00
rem for appveyor, use: cd \projects\unrealircd
cd \users\user\worker\unreal6-w10\build
2020-03-29 09:16:53 +00:00
2022-01-15 05:16:34 +00:00
rem Install 'unrealircd-tests'
cd ..
rd /q/s unrealircd-tests
git clone -q --branch unreal60 https://github.com/unrealircd/unrealircd-tests.git unrealircd-tests
if %ERRORLEVEL% NEQ 0 EXIT /B 1
cd build
2020-03-29 09:16:53 +00:00
2022-01-15 05:16:34 +00:00
rem Now the actual build
rem - First this, otherwise JOM will fail
IF NOT EXIST src\version.c nmake -f Makefile.windows CONF
rem - Then build most of UnrealIRCd.exe etc
2022-04-03 15:09:29 +00:00
call extras\build-tests\windows\compilecmd\%SHORTNAME%.bat UNREALSVC.EXE UnrealIRCd.exe unrealircdctl.exe
2022-01-15 05:16:34 +00:00
rem - It will fail due to missing symbolfile, which we create here..
2020-03-29 09:16:53 +00:00
nmake -f makefile.windows SYMBOLFILE
2022-01-15 05:16:34 +00:00
rem - Then we finalize building UnrealIRCd.exe: should be no error
2022-04-03 15:09:29 +00:00
call extras\build-tests\windows\compilecmd\%SHORTNAME%.bat UNREALSVC.EXE UnrealIRCd.exe unrealircdctl.exe
2022-01-15 05:16:34 +00:00
if %ERRORLEVEL% NEQ 0 EXIT /B 1
rem - Build all the modules (DLL files): should be no error
call extras\build-tests\windows\compilecmd\%SHORTNAME%.bat MODULES
2020-03-29 09:16:53 +00:00
if %ERRORLEVEL% NEQ 0 EXIT /B 1
2021-01-08 23:15:08 +00:00
rem Compile dependencies for unrealircd-tests -- this doesn't belong here though..
2022-01-15 05:16:34 +00:00
copy ..\unrealircd-tests\serverconfig\unrealircd\modules\fakereputation.c src\modules\third /Y
2021-01-08 23:15:08 +00:00
call extras\build-tests\windows\compilecmd\%SHORTNAME%.bat CUSTOMMODULE MODULEFILE=fakereputation
if %ERRORLEVEL% NEQ 0 EXIT /B 1
2022-01-15 05:16:34 +00:00
rem Convert c:\dev to c:\projects\unrealircd-6-libs
2020-03-29 09:16:53 +00:00
rem TODO: should use environment variable in innosetup script?
2022-01-15 05:16:34 +00:00
sed -i "s/c:\\dev\\unrealircd-6-libs/c:\\projects\\unrealircd-6-libs/gi" src\windows\unrealinst.iss
2020-03-29 09:16:53 +00:00
rem Build installer file
"c:\Program Files (x86)\Inno Setup 5\iscc.exe" /Q- src\windows\unrealinst.iss
if %ERRORLEVEL% NEQ 0 EXIT /B 1
rem Show some proof
ren mysetup.exe unrealircd-dev-build.exe
dir unrealircd-dev-build.exe
sha256sum unrealircd-dev-build.exe
rem Kill any old instances, just to be sure
taskkill -im unrealircd.exe -f
sleep 2
rem Just a safety measure so we don't end up testing
rem some old version...
2022-01-15 05:16:34 +00:00
del "C:\Program Files\UnrealIRCd 6\bin\unrealircd.exe"
2020-03-29 09:16:53 +00:00
echo Running installer...
start /WAIT unrealircd-dev-build.exe /VERYSILENT /LOG=setup.log
if %ERRORLEVEL% NEQ 0 goto installerfailed
rem Upload artifact
rem appveyor PushArtifact unrealircd-dev-build.exe
rem if %ERRORLEVEL% NEQ 0 EXIT /B 1
2022-01-15 05:16:34 +00:00
cd ..\unrealircd-tests
2020-03-29 09:16:53 +00:00
dir
2021-06-19 15:52:51 +00:00
rem All tests except db:
2020-03-29 09:16:53 +00:00
"C:\Program Files\Git\bin\bash.exe" ./runwin
if %ERRORLEVEL% NEQ 0 EXIT /B 1
2021-06-19 15:52:51 +00:00
rem Test unencrypted db's:
"C:\Program Files\Git\bin\bash.exe" ./runwin -boot tests/db/writing/*
if %ERRORLEVEL% NEQ 0 EXIT /B 1
"C:\Program Files\Git\bin\bash.exe" ./runwin -keepdbs -boot tests/db/reading/*
if %ERRORLEVEL% NEQ 0 EXIT /B 1
rem Test encrypted db's:
"C:\Program Files\Git\bin\bash.exe" ./runwin -include db_crypted.conf -boot tests/db/writing/*
if %ERRORLEVEL% NEQ 0 EXIT /B 1
"C:\Program Files\Git\bin\bash.exe" ./runwin -include db_crypted.conf -keepdbs -boot tests/db/reading/*
if %ERRORLEVEL% NEQ 0 EXIT /B 1
2020-03-29 09:16:53 +00:00
goto end
2021-06-19 15:52:51 +00:00
2020-03-29 09:16:53 +00:00
:installerfailed
type setup.log
echo INSTALLATION FAILED
EXIT /B 1
:end