(最新のバージョンではそんなことはないかもしれませんが)
その状態で古い履歴を削除する設定をしていると、
ビルド番号の大きい古いビルドが削除されず、ビルド番号の小さな新しいビルドが削除されてしまいます。
これが意外と気づきにくいんですよね。
というわけで自動化しましょう!
不整合の検出
@echo off pushd "%~dp0" if "x%~1" == "x" ( call :target_jenkins_home if errorlevel 1 goto error ) else ( call :target_command_line %* if errorlevel 1 goto error ) SET TARGET_PATH if errorlevel 1 goto error SET ERRORCODE=0 for /D %%d in ( "%TARGET_PATH%\jobs\*" ) do ( @echo %%~nd if exist "%%d\nextBuildNumber" ( for /f %%i in ( %%d\nextBuildNumber ) do ( call :checkbuildnumber %%d %%i if errorlevel 1 ( SET ERRORCODE=1 ) ) ) ) if "%ERRORCODE%" == "1" goto error goto end :checkbuildnumber SET NEXT=%~2 rem @echo next build number %NEXT% SET MAXNUM=0 setlocal enabledelayedexpansion for /D %%d in ( "%~1\builds\*" ) do ( call :getbuildlognumber %%d SET CURNUM=!errorlevel! if !CURNUM! gtr !MAXNUM! ( SET MAXNUM=!CURNUM! ) ) rem @echo !MAXNUM! if %NEXT% lss !MAXNUM! ( @echo "Warning: next build number [%NEXT%] is smaller than the number of the log [!MAXNUM!]." exit /b 1 ) endlocal exit /b 0 :getbuildlognumber if not exist "%~1\build.xml" exit /b 0 for /f "tokens=1,2,3,4* delims=<>" %%a in ( %~1\build.xml ) do ( if "%%b" == "number" ( exit /b %%c ) ) exit /b 0 :target_command_line if not exist "%~1" ( @echo %~1 は存在しません。 exit /b 1 ) SET TARGET_PATH=%~1 exit /b 0 :target_jenkins_home SET JENKINS_HOME >NUL if errorlevle 1 ( @echo JENKINS_HOME が設定されていません。 exit /b 1 ) SET TARGET_PATH=%JENKINS_HOME% exit /b 0 :error popd @echo failed. pause exit /b 1 :end popd exit /b 0
master ノードで実行する必要があります。
第一引数に ${JENKINS_HOME} のパスを指定します。省略した場合、環境変数のパスをそのまま使います。
こんなんでも定期的に実行するようにしたら、効果はきっとあるでしょう。
もう少しスマートに検出する
Groovy post build plugin を使って検出させてみました。import hudson.model.AbstractProject def jenkins = hudson.model.Hudson.instance def projects = jenkins.getAllItems(AbstractProject.class) projects.each { project -> def lastBuild = project.getLastBuild() if( lastBuild != null ) { def lastNumber = lastBuild.getNumber() def nextNumber = project.getNextBuildNumber() if( nextNumber < lastNumber ) { manager.listener.logger.println(project.getName()) manager.listener.logger.println("Warning: next build number [${nextNumber}] is smaller than the number of the log [${lastNumber}].") manager.buildUnstable() } } }
修復
ビルド番号の修正は Jenkins が"停止"しているときにする必要があります(たぶん)。 不整合の検出で使用したバッチファイルを少し変更して、不整合が見つかったら nextBuildNumber を修正します。@echo off pushd "%~dp0" if "x%~1" == "x" ( call :target_jenkins_home if errorlevel 1 goto error ) else ( call :target_command_line %* if errorlevel 1 goto error ) SET TARGET_PATH if errorlevel 1 goto error for /D %%d in ( "%TARGET_PATH%\jobs\*" ) do ( @echo %%~nd if exist "%%d\nextBuildNumber" ( for /f %%i in ( %%d\nextBuildNumber ) do ( call :repairbuildnumber %%d %%i ) ) ) goto end :repairbuildnumber SET NEXT=%~2 rem @echo next build number %NEXT% SET MAXNUM=0 setlocal enabledelayedexpansion for /D %%d in ( "%~1\builds\*" ) do ( call :getbuildlognumber %%d SET CURNUM=!errorlevel! if !CURNUM! gtr !MAXNUM! ( SET MAXNUM=!CURNUM! ) ) rem @echo !MAXNUM! if %NEXT% lss !MAXNUM! ( @echo "Warning: next build number [%NEXT%] is smaller than the number of the log [!MAXNUM!]." SET /a NEWNUM=!MAXNUM!+1 @echo new next build number !NEWNUM! @echo !NEWNUM!| sed 's/\n//g'> "%~1\nextBuildNumber" ) endlocal exit /b 0 :getbuildlognumber if not exist "%~1\build.xml" exit /b 0 for /f "tokens=1,2,3,4* delims=<>" %%a in ( %~1\build.xml ) do ( if "%%b" == "number" ( exit /b %%c ) ) exit /b 0 :target_command_line if not exist "%~1" ( @echo %~1 は存在しません。 exit /b 1 ) SET TARGET_PATH=%~1 exit /b 0 :target_jenkins_home SET JENKINS_HOME >NUL if errorlevle 1 ( @echo JENKINS_HOME が設定されていません。 exit /b 1 ) SET TARGET_PATH=%JENKINS_HOME% exit /b 0 :error popd @echo failed. pause exit /b 1 :end popd pause exit /b 0
0 件のコメント:
コメントを投稿