Created
February 24, 2017 17:20
-
-
Save jeffwilcox/5586c219c4e6b7d258c19087fd277dfd to your computer and use it in GitHub Desktop.
Mail2Bug deployment script for a triggered WebJob deployment
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
@if "%SCM_TRACE_LEVEL%" NEQ "4" @echo off | |
:: ---------------------- | |
:: KUDU Deployment Script | |
:: Version: 1.0.7 | |
:: ---------------------- | |
:: Prerequisites | |
:: ------------- | |
:: Verify node.js installed | |
where node 2>nul >nul | |
IF %ERRORLEVEL% NEQ 0 ( | |
echo Missing node.js executable, please install node.js, if already installed make sure it can be reached from current environment. | |
goto error | |
) | |
:: Setup | |
:: ----- | |
setlocal enabledelayedexpansion | |
SET ARTIFACTS=%~dp0%..\artifacts | |
IF NOT DEFINED DEPLOYMENT_SOURCE ( | |
SET DEPLOYMENT_SOURCE=%~dp0%. | |
) | |
IF NOT DEFINED DEPLOYMENT_TARGET ( | |
SET DEPLOYMENT_TARGET=%ARTIFACTS%\wwwroot | |
) | |
IF NOT DEFINED NEXT_MANIFEST_PATH ( | |
SET NEXT_MANIFEST_PATH=%ARTIFACTS%\manifest | |
IF NOT DEFINED PREVIOUS_MANIFEST_PATH ( | |
SET PREVIOUS_MANIFEST_PATH=%ARTIFACTS%\manifest | |
) | |
) | |
IF NOT DEFINED KUDU_SYNC_CMD ( | |
:: Install kudu sync | |
echo Installing Kudu Sync | |
call npm install kudusync -g --silent | |
IF !ERRORLEVEL! NEQ 0 goto error | |
:: Locally just running "kuduSync" would also work | |
SET KUDU_SYNC_CMD=%appdata%\npm\kuduSync.cmd | |
) | |
IF NOT DEFINED DEPLOYMENT_TEMP ( | |
SET DEPLOYMENT_TEMP=%temp%\___deployTemp%random% | |
SET CLEAN_LOCAL_DEPLOYMENT_TEMP=true | |
) | |
IF DEFINED CLEAN_LOCAL_DEPLOYMENT_TEMP ( | |
ECHO Nuking... | |
IF EXIST "%DEPLOYMENT_TEMP%" rd /s /q "%DEPLOYMENT_TEMP%" | |
mkdir "%DEPLOYMENT_TEMP%" | |
) | |
IF DEFINED MSBUILD_PATH goto MsbuildPathDefined | |
SET MSBUILD_PATH=%ProgramFiles(x86)%\MSBuild\14.0\Bin\MSBuild.exe | |
:MsbuildPathDefined | |
:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: | |
:: Deployment | |
:: ---------- | |
echo Building mail2bug... | |
:: 1. Restore NuGet packages | |
IF /I "mail2bug\Mail2Bug.sln" NEQ "" ( | |
call :ExecuteCmd nuget restore "%DEPLOYMENT_SOURCE%\mail2bug\Mail2Bug.sln" | |
IF !ERRORLEVEL! NEQ 0 goto error | |
) | |
:: 2. Build to the temporary path | |
SET MAIL2BUG_JOB_NAME=email | |
echo WebJob staging location: %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME% | |
call :ExecuteCmd "%MSBUILD_PATH%" "%DEPLOYMENT_SOURCE%\mail2bug\Mail2Bug\Mail2Bug.csproj" /nologo /verbosity:m /t:Build /p:Configuration=Release;OutputPath="%DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%";UseSharedCompilation=false /p:SolutionDir="%DEPLOYMENT_SOURCE%\mail2bug\\" %SCM_BUILD_ARGS% | |
IF !ERRORLEVEL! NEQ 0 goto error | |
:: 2.b. Copy configuration files into the right place | |
echo ROBOCOPY /s %DEPLOYMENT_SOURCE%\configuration\ %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\configuration | |
ROBOCOPY /s %DEPLOYMENT_SOURCE%\configuration\ %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\configuration | |
echo copy %DEPLOYMENT_SOURCE%\settings.job %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\ | |
copy %DEPLOYMENT_SOURCE%\settings.job %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\ | |
ECHO dir %DEPLOYMENT_SOURCE%\settings.job %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\ | |
dir %DEPLOYMENT_SOURCE%\settings.job %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\ | |
ECHO dir %DEPLOYMENT_SOURCE%\settings.job %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\configuration\ | |
dir %DEPLOYMENT_SOURCE%\settings.job %DEPLOYMENT_TEMP%\app_data\jobs\triggered\%MAIL2BUG_JOB_NAME%\configuration\ | |
:: 3. Run web job deploy script | |
IF DEFINED WEBJOBS_DEPLOY_CMD ( | |
echo Running WebJob deployment... | |
call :ExecuteCmd "%WEBJOBS_DEPLOY_CMD%" | |
) | |
:: 4. KuduSync | |
call :ExecuteCmd "%KUDU_SYNC_CMD%" -v 50 -f "%DEPLOYMENT_TEMP%" -t "%DEPLOYMENT_TARGET%" -n "%NEXT_MANIFEST_PATH%" -p "%PREVIOUS_MANIFEST_PATH%" -i ".git;.hg;.deployment;deploy.cmd" | |
IF !ERRORLEVEL! NEQ 0 goto error | |
:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: | |
goto end | |
:: Execute command routine that will echo out when error | |
:ExecuteCmd | |
setlocal | |
set _CMD_=%* | |
call %_CMD_% | |
if "%ERRORLEVEL%" NEQ "0" echo Failed exitCode=%ERRORLEVEL%, command=%_CMD_% | |
exit /b %ERRORLEVEL% | |
:error | |
endlocal | |
echo An error has occurred during web site deployment. | |
call :exitSetErrorLevel | |
call :exitFromFunction 2>nul | |
:exitSetErrorLevel | |
exit /b 1 | |
:exitFromFunction | |
() | |
:end | |
endlocal | |
echo Finished successfully. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment