Skip to content

Instantly share code, notes, and snippets.

@jeffwilcox
Created February 24, 2017 17:20
Show Gist options
  • Save jeffwilcox/5586c219c4e6b7d258c19087fd277dfd to your computer and use it in GitHub Desktop.
Save jeffwilcox/5586c219c4e6b7d258c19087fd277dfd to your computer and use it in GitHub Desktop.
Mail2Bug deployment script for a triggered WebJob deployment
@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