What exit code is Bamboo expecting from a command to highlight text red in the log?

I have a series of final tasks running in a job because I want them all to execute regardless of pass/fail result. One thing I would like to be able to do is easily differentiate failed results from a command task. What return status from the application is Bamboo expecting to flag the result this way in the log? I've seen it previously for failed results, but have yet to decipher the return status I need to provide to consistently do so.

4 answers

1 accepted

The answer to this question is provided above. All output for which this behavior is desired must be directed to stderr. It will then be marked up in red and output in the error log upon task failure.

0 votes

The last exist status must be >0 in order for Bamboo to flag the task as failing.

Daniel,

The task is returning failing successfully, but I'd like it to also flag the failure in the log component of the job in red. A return status of > 1 does not accomplish this. I may need to return an exception with the failure status to accomplish this result.

I assume that error text must need to be redirected to stderr to flag it. I'm going to test this assumption and see if that is correct.

When using bash script tasks, I always put:

set -o errexit

at the top.

And for "echoing" something to stderr, I have always been using echo "..." 1>&2 for that purpose.

Example: Checking that a variable value was overriden to enforce a custom build run:

#!/bin/sh
set -o errexit

ARTIFACT_VERSION=$1


if [ ! -z "$ARTIFACT_VERSION" -a "$ARTIFACT_VERSION" != " " ]; then

    echo "Provided artifact version: $ARTIFACT_VERSION"
    exit 0
    
else
    echo "Artifact version is missing" 1>&2
    echo "Run a customized Build and override the build variable 'webforms.blueprint.version'." 1>&2
    exit 1 

fi
exit 0

If a user started a build without setting a custom variable, so he will get:


I hope it will help you.

This is exactly what I ended up doing an reaffirm that redirecting to stderr is the answer. The application I initially asked the question about happened to a be a .NET application, so added System.Console.Error.WriteLine("<text>") for the messaging in the log that I wanted redirected to stderr. Worked perfectly. Thanks for your response.

Suggest an answer

Log in or Join to answer
Community showcase
Renan Battaglin
Published May 18, 2017 in Bamboo

FAQ: How to Upgrade Bamboo Server

Bamboo 5.9 will no longer be supported after June 12, 2017. What does this mean? As part of our End of Life policy, Atlassian supports major versions for two years after the first major iteratio...

1,066 views 0 5
Read article

Atlassian User Groups

Connect with like-minded Atlassian users at free events near you!

Find a group

Connect with like-minded Atlassian users at free events near you!

Find my local user group

Unfortunately there are no AUG chapters near you at the moment.

Start an AUG

You're one step closer to meeting fellow Atlassian users at your local meet up. Learn more about AUGs

Groups near you
Atlassian Team Tour

Join us on the Team Tour

We're bringing product updates and pro tips on teamwork to ten cities around the world.

Save your spot