Post-Build Delivery set to deliver with no errors, but
I have declared a build definition with a post delivery from my integration stream to my release stream. I have specified the policy to be:
<i>Deliver if build has no errors or warnings.</i>
I am using a simple ant build process and have seen the build complete and deliver the code from the integration stream to the release stream.
The problem is :
I have introduced a compile error into one of the files. The code continues to get delivered to the release stream from the integration stream with the compile error.
The build shows up in the dashboard as failed.
<b>team.scm.deliver.triggerPolicy :NO_WARNINGS</b>
I've also set the trigger policy to <b>NO_ERROR</b>
Here is the snippet from the logs which shows the triggerPolicy, and the log showing that the integration code is delivered to the release stream.
<i>Deliver if build has no errors or warnings.</i>
I am using a simple ant build process and have seen the build complete and deliver the code from the integration stream to the release stream.
The problem is :
I have introduced a compile error into one of the files. The code continues to get delivered to the release stream from the integration stream with the compile error.
The build shows up in the dashboard as failed.
<b>team.scm.deliver.triggerPolicy :NO_WARNINGS</b>
I've also set the trigger policy to <b>NO_ERROR</b>
Here is the snippet from the logs which shows the triggerPolicy, and the log showing that the integration code is delivered to the release stream.
[echo] Start Build Process: _3YCgAOMJEeC2ctfjkYpq-w ...
[echo] Echo the post build delivery value of team.scm.deliver.triggerPolicy :NO_WARNINGS
[mkdir] Created dir: /buildRoot/engines/bpmdevinf001_engine5/build/PlayBack/load/componentA/build
[javac] Compiling 6 source files to /buildRoot/engines/bpmdevinf001_engine5/build/PlayBack/load/componentA/build
[javac] /buildRoot/engines/bpmdevinf001_engine5/build/PlayBack/load/componentA/src/com/xxx/B.java:20: cannot find symbol
[javac] symbol : class strung
[javac] location: class com.xxx.B
[javac] strung x = snull;
[javac] ^
[javac] /buildRoot/engines/bpmdevinf001_engine5/build/PlayBack/load/componentA/src/com/xxx/B.java:20: cannot find symbol
[javac] symbol : variable snull
[javac] location: class com.xxx.B
[javac] strung x = snull;
[javac] ^
[javac] 2 errors
BUILD FAILED
/buildRoot/engines/bpmdevinf001_engine5/build/PlayBack/load/componentA/build.xml:11: Compile failed; see the compiler error output for details.
Total time: 42 seconds
Build failed. Exit value was 1.
2011-09-19 17:56:02 [Jazz build engine] Invoking post-build participant "com.ibm.team.build.autoDeliver"
2011-09-19 17:56:10 [Jazz build engine] Delivering components...
2011-09-19 17:56:10 [Jazz build engine] Post-build deliver complete.
Summary of Post-build Deliver:
Build Workspace:
"4000 Integration Stream Build Workspace" (_jO2d0OCQEeC2cNfjkYpq-w)
Deliver Target:
"4000 Release Stream" (_4jgvsOALEeC2b9fjkYpq-w)
Delivered Snapshot:
"PlayBackBuildDef_20110919-1755" (_53mSseMJEeC2ctfjkYpq-w)
Added Components:
<none>
Replaced Components:
"SingleComponent" (_4wTOgOALEeC2b9fjkYpq-w)
Removed Components:
<none>
4 answers
Hi Frank,
The good news is that this issue is fixed and available for RTC 3.0.1.1 (available ~ October). (as per this work item: 175702: 3.0.1.1 Backport: Post-build deliver still proceed even if the build failed
In the meantime, if you post the compile results to the build result it will correctly abort the auto-deliver. You can add the "ECJ Publishing" tab to the build result to do this, or use the "jdtCompileLogPublisher" to publish the compile results. (see this link on the available ant tasks used to publish build results.
The good news is that this issue is fixed and available for RTC 3.0.1.1 (available ~ October). (as per this work item: 175702: 3.0.1.1 Backport: Post-build deliver still proceed even if the build failed
In the meantime, if you post the compile results to the build result it will correctly abort the auto-deliver. You can add the "ECJ Publishing" tab to the build result to do this, or use the "jdtCompileLogPublisher" to publish the compile results. (see this link on the available ant tasks used to publish build results.
David,
I have updated the server:
Change and Configuration Management - Core Libraries 3.0.1.1 (RTC-I20111006-1106)
Jazz Foundation - Core Libraries 3.0.1.1 (RJF-I20111006-0903)
and still see the same problem, auto promote with a build failure:
I have updated the server:
Change and Configuration Management - Core Libraries 3.0.1.1 (RTC-I20111006-1106)
Jazz Foundation - Core Libraries 3.0.1.1 (RJF-I20111006-0903)
and still see the same problem, auto promote with a build failure:
Total time: 5 seconds
Build failed. Exit value was 10.
2011-12-06 03:53:17 [Jazz build engine] Invoking post-build participant "com.ibm.team.build.autoDeliver"
2011-12-06 03:53:27 [Jazz build engine] Delivering components...
2011-12-06 03:53:38 [Jazz build engine] Post-build deliver complete.
Summary of Post-build Deliver:
Build Workspace:
"8000 Build Release Stream Integration Build Workspace" (_fMClIAefEeGWk4mn4Kdi_w)
Deliver Target:
"8000-Release" (_uCcaMPBdEeCki4EwQRsuZw)
Delivered Snapshot:
"8000-Integration-Advanced_20111206-0138" (_8xgoQB_UEeGehsEPNI9jjA)
Added Components:
<none>
Replaced Components:
"XXX" (_Y2gzQPXUEeC9ZZ7RSd-fuQ)
Removed Components:
<none>
Hi Frank,
The good news is that this issue is fixed and available for RTC 3.0.1.1 (available ~ October). (as per this work item: 175702: 3.0.1.1 Backport: Post-build deliver still proceed even if the build failed
In the meantime, if you post the compile results to the build result it will correctly abort the auto-deliver. You can add the "ECJ Publishing" tab to the build result to do this, or use the "jdtCompileLogPublisher" to publish the compile results. (see this link on the available ant tasks used to publish build results.