Fail

Short Description
Ports
Metadata
Fail Attributes
Details
See also

The component is located in PaletteJob Control.

Short Description

The Fail component aborts the parent job (jobflow or graph) with a user-specified error message.

ComponentSame input metadataSorted inputsInputsOutputsEach to all outputsJavaCTLAuto-propagated metadata
Fail
no
no
0-10
no
no
yes
no

Ports

Port typeNumberRequiredDescriptionMetadata
Input0
no
Any input token from this port interrupts the jobflow (or graph).Any

Metadata

The input field errorMessage is automatically used for a user-specific error message, which interrupts the job, if it is not otherwise specified in mapping.

Fail Attributes

AttributeReqDescriptionPossible values
Basic
Error messageno

In case the job is interrupted, an exception is thrown with this error message. The error message can be dynamically changed in mapping.

"user abort" (default) | text
Mappingno

Mapping is used for dynamic assembling of an error message, which is thrown in case the job is going to be interrupted. Moreover, dictionary content of interrupted job can be changed as well. See Details.

 

Details

Fail interrupts a parent job (jobflow or graph). The first incoming token to the component throws an exception (org.jetel.exception.UserAbortException) with a user defined error message. The job finishes immediately with a final status ERROR. Moreover, the dictionary content can be changed before the job is interrupted. In general, the component allows to interrupt the job and return some results through the dictionary, at the same time.

The Fail component works even without an input port attached. In this case, the job is interrupted immediately when the phase with the Fail component is started up.

Mapping details

Mapping in the Fail component is generally used for two purposes:

  • Assembling of an error message from an incoming record.

  • Populating dictionary content from an incoming record.

    [Note]Note

    Only output dictionary entries can be changed.

Example of mapping for the Fail component

Figure 59.2. Example of mapping for the Fail component


The error message compiled by the mapping has the highest priority. If the mapping does not set errorMessage, the error message from the component attribute is used instead. If even this attribute is not set, predefined text user abort is used instead.