The When Automation Tool Logo

Contents:

  • The When Documentation
  • Installation
  • Tutorial
  • Command Line Interface (CLI)
  • Main Configuration Form
  • System Tray Resident Application
  • Native Tasks Editors
  • Extra Tasks: Session Related
  • Condition Editors
  • Time Related Conditions
  • Action Related Conditions
    • Command
    • Lua Script
    • See Also
  • Event Conditions
  • Extra Conditions
  • Native Events Editors
  • Specific Events
  • History Box
  • Localization
  • Application Data Directory
  • Generated Configuration File
  • Some Considerations on Lua
  • Credits
  • History
  • License
The When Automation Tool
  • Action Related Conditions
  • View page source

Action Related Conditions

The condition items described in this section detrmine the outcome of the related tests as the result of a particular action, which can be either a command executed at the OS level, or the execution of a Lua script using the embedded interpreter. Since these tests might possibily be resource intensive, it is possible (and recommended) to specify an additional delay between consecutive checks by specifying an appropriate amount of time (in seconds, minutes, or hours) in the Additional Delay field.

Also, common to this type of conditions there is another flag available, that is Ignore Persistent Successful Checks: if set, the condition will be verified only as soon as the check is successful for the first time, and subsequent positive checks will be ignored until at least one check fails. This effectively “debounces” successful tests resulting in checks that focus on status changes.

For the same reason, the tests related to these types of condition might be performed at a random instant between two scheduler ticks if the corresponding global scheduler option is set.

Command

Command conditions execute a command at the OS level which can be any kind of executable, that is, both scripts and binaries are accepted command. The command, along with its arguments and startup folder, must be provided by the user. The outcome of the condition is determined by either checking the exit code or scanning the output provided by the command.

WhenCondCommand

The definition of the related command and of the tests that are performed to determine its outcome is very similar to the corresponding task definition.

The following entries must be specified:

  • Command: must either be the full path to an executable, or a command that can be found in the current execution PATH

  • Arguments: the arguments, if any, to be passed to the command

  • Working Folder: the directory where the command is started by the OS.

If the working folder is not important for command execution, a simple dot (.) can be entered to specify the “current folder”: the field can not be empty.

The environment variables deserve special consideration:

  • by checking Preserve Existing Environment (default, recommended) the command starts with all the already defined variables, otherwise a fresh, empty environment is created

  • the Set… flag, if checked, adds one more variable, that is WHENEVER_CONDITION, containing the name of the condition

  • more environment variables can be defined for the specific command: for this, it is sufficient to enter the variable name and the value in the respective fields, and click the Update button; to remove a variable it is sufficient to enter its name in the Variable Name field (or double click the entry in the list) and then click the Remove button. Clicking Update by providing a new value for an existing variable will update its value in the list.

Variables provided in the list will add up to the existing ones, or overwrite the ones that share the same name.

The Checks section allows to test the outcome of commands by examining their output (either stdout or stderr) or the exit code. When selecting Success in the Check for drop down list, meeting the criteria provided on the right will be considered a success. Selecting Failure will cause the same event to be considered a failure. In the same section, the flags below change the way the provided result is compared against the selected output (stdout or stderr only: ignored when the exit code is considered): Exact Match indicates that the output is matched against the provided string in its entirety (by default it is sufficient to find the provided string as a substring), Case Sensitive obviously considers uppercase and lowercase letters differently, while Regular Expression considers the provided string as a regular expression to match against the command output, either in its entirety or just partially depending on whether Exact Match is respectively checked or unchecked.

The Timeout parameter can be set to a specified number of seconds in order to force a command which can hang or take a long time to complete to stop after the provided time. In terms of outcome, a timeout terminated command is always considered as failed. The provided value must be a positive integer, to avoid timeout checking field must be left empty.

Lua Script

As a lightweight alternative to OS level commands, it is possible to run Lua scripts: since the Lua interpreter is embedded in the scheduler executable, execution of simple Lua scripts may have less impact on computational resources than equivalent tests that require commands. The interpreter is provided with its full library, and although the script has to be specified in the scheduler configuration, it is possible to use the require() and dofile() functions to call external scripts.

WhenCondLua

Success and failure of Lua based tests are determined by the correspondence of the values held by some variables after the script execution. The variables to be checked are provided by the user by entering the variable name and the expected value respectively in the Variable Name and New Value fields, and clicking the Update button: the behavior of the list, the aforementioned fields and the Update and Remove buttons are similar to the ones seen for the environment variables in command based conditions. Checking the Match ALL Results box will cause the test to be successful only when all listed variables hold the expected values, while by default just one match among the listed ones is sufficient for success.

Caution

Lua script based condition checks will always fail if there is an error in the provided script.

See Also

  • Command Based Tasks

  • Lua Script Based Tasks

◀ Conditions

Previous Next

© Copyright 2015-2025, Francesco Garosi.

Built with Sphinx using a theme provided by Read the Docs.