Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

MSBuild exec task, exit code empty

I have the following exec task, performing checkin of assemblyinfo.cs files. I'm trying to return the exit code, but for some reason it is always empty.

<!--Checkin if all succeeded-->
<Exec Condition=" '$(LocalCompilationSuccess)' != 'Failed' and '$(LocalTestSuccess)' != 'Failed' " ContinueOnError="True"
              Command='&quot;$(TfCommand)&quot; checkin /recursive /comment:"$(NoCICheckInComment) $(BuildDefinitionName): build succeeded, checkin changes." /override:"TeamBuild $(BuildDefinitionName)" $/SomeProject/Trnk' WorkingDirectory="$(SolutionRoot)"  >
  <Output TaskParameter="ExitCode" PropertyName="ErrorCode"/>
</Exec>

I've tried to read the exit code in 2 ways:

'%(ErrorCode.Identity)'
'$(ErrorCode)'

Both are empty. Any suggestions?

like image 813
jaspernygaard Avatar asked Jun 19 '12 07:06

jaspernygaard


1 Answers

In general it works as you have shown.

For reference, here is a more "selfcontained" example:

<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003" ToolsVersion="4.0">
  <Target Name="help">
    <Exec ContinueOnError="True" Command='cmd.exe /c dir'>
       <Output TaskParameter="ExitCode" PropertyName="ErrorCode"/>
    </Exec>
    <Message Importance="high" Text="$(ErrorCode)"/>
  </Target>
</Project>

A couple of things you may want to consider however:

  • Make sure your Exec even executes, that is Condition evaluates to True.

  • Output the ErrorCode property using the Message-Task, to see if it is actually set (to the value you expect). However, make sure MSBuild will show the output, by either using Importance='high' or by running msbuild.exe /v:d to enable detailed messages.

like image 110
Christian.K Avatar answered Oct 05 '22 06:10

Christian.K