robocorp-actions

module robocorp.actions

Functions


action

Decorator for actions (entry points) which can be executed by robocorp.actions.

i.e.:

If a file such as actions.py has the contents below:

from robocorp.actions import action @action def enter_user() -> str: ...

It'll be executable by robocorp actions as:

python -m robocorp.actions run actions.py -a enter_user

Args:

  • func: A function which is a action to robocorp.actions.
  • is_consequential: Whether the action is consequential or not. This will add x-openai-isConsequential: true to the action metadata and shown in OpenApi spec.

Link to source

action(*args, **kwargs)

action_cache

Provides decorator which caches return and clears it automatically when the current action has been run.

A decorator which automatically cache the result of the given function and will return it on any new invocation until robocorp-actions finishes running the current action.

The function may be either a generator with a single yield (so, the first yielded value will be returned and when the cache is released the generator will be resumed) or a function returning some value.

Args:

  • func: wrapped function.

Link to source

action_cache(func)

get_current_action

Provides the action which is being currently run or None if not currently running an action.

Link to source

get_current_action() → Optional[IAction]

get_output_dir

Provide the output directory being used for the run or None if there's no output dir configured.

Link to source

get_output_dir() → Optional[Path]

session_cache

Provides decorator which caches return and clears automatically when all actions have been run.

A decorator which automatically cache the result of the given function and will return it on any new invocation until robocorp-actions finishes running all actions.

The function may be either a generator with a single yield (so, the first yielded value will be returned and when the cache is released the generator will be resumed) or a function returning some value.

Args:

  • func: wrapped function.

Link to source

session_cache(func)

setup

Run code before any actions start, or before each separate action.

Receives as an argument the action or actions that will be run.

Can be used as a decorator without arguments:

from robocorp.actions import setup @setup def my_fixture(action): print(f"Before action: {action.name}")

Alternatively, can be called with a scope argument to decide when the fixture is run:

from robocorp.actions import setup @setup(scope="action") def before_each(action): print(f"Running action '{action.name}'") @setup(scope="session") def before_all(actions): print(f"Running {len(actions)} action(s)")

By default, runs setups in action scope.

The setup fixture also allows running code after the execution, if it yields the execution to the action(s):

import time from robocorp.actions import setup @setup def measure_time(action): start = time.time() yield # Action executes here duration = time.time() - start print(f"Action took {duration} seconds") @action def my_long_action(): ...

Note: If fixtures are defined in another file, they need to be imported in the main actions file to be taken into use

Link to source

setup( *args, **kwargs ) → Union[Callable[[IAction], Any], Callable[[Callable[[IAction], Any]], Callable[[IAction], Any]], Callable[[Callable[[Sequence[IAction]], Any]], Callable[[Sequence[IAction]], Any]]]

teardown

Run code after actions have been run, or after each separate action.

Receives as an argument the action or actions that were executed, which contain (among other things) the resulting status and possible error message.

Can be used as a decorator without arguments:

from robocorp.actions import teardown @teardown def my_fixture(action): print(f"After action: {action.name})

Alternatively, can be called with a scope argument to decide when the fixture is run:

from robocorp.actions import teardown @teardown(scope="action") def after_each(action): print(f"Action '{action.name}' status is '{action.status}'") @teardown(scope="session") def after_all(actions): print(f"Executed {len(actions)} action(s)")

By default, runs teardowns in action scope.

Note: If fixtures are defined in another file, they need to be imported in the main actions file to be taken into use

Link to source

teardown( *args, **kwargs ) → Union[Callable[[IAction], Any], Callable[[Callable[[IAction], Any]], Callable[[IAction], Any]], Callable[[Callable[[Sequence[IAction]], Any]], Callable[[Sequence[IAction]], Any]]]

Class IAction

Properties

  • failed

Returns true if the task failed. (in which case usually exc_info is not None).

  • input_schema

The input schema from the function signature.

Example:

{ "properties": { "value": { "type": "integer", "description": "Some value.", "title": "Value", "default": 0 } }, "type": "object" }
  • lineno

The line where the task is declared.

  • managed_params_schema

The schema for the managed parameters.

Example:

{ "my_password": { "type": "Secret" }, "request": { "type": "Request" } }
  • name

The name of the task.

  • output_schema

The output schema based on the function signature.

Example:

{ "type": "string", "description": "" }

Class Request

Contains the information exposed in a request (such as headers and cookies).

May be extended in the future to provide more information.

Properties

  • cookies

Provides the cookies received in the request.

  • headers

Provides the headers received in the request (excluding cookies which are available in cookies).

Methods


model_validate

Link to source

model_validate(dct: dict) → Request

Class Secret

This class should be used to receive secrets.

The way to use it is by declaring a variable with the 'Secret' type in the @action.

Example:

from robocorp.actions import action, Secret @action def my_action(password: Secret): login(password.value)

Note: this class is abstract and is not meant to be instanced by clients. An instance can be created from one of the factory methods (model_validateor from_action_context).

Properties

  • value

Methods


from_action_context

Creates a secret given the action context (which may be encrypted in memory until the actual secret value is requested).

Args:

  • action_context: The action context which has the secret.

  • path: The path inside of the action context for the secret datarequested (Example: 'secrets/my_secret_name').

Return: A Secret instance collected from the passed action context.

Link to source

from_action_context(action_context: 'ActionContext', path: str) → Secret

model_validate

Creates a secret given a string (expected when the user is passing the arguments using a json input).

Args:

  • value: The raw-text value to be used in the secret.

Return: A Secret instance with the given value.

Note: the model_validate method is used for compatibility with the pydantic API.

Link to source

model_validate(value: str) → Secret

Enums


Status

Task state

Values

  • NOT_RUN = NOT_RUN
  • PASS = PASS
  • FAIL = FAIL