File: cli_scripting_in_batch.rst

package info (click to toggle)
ecflow 5.15.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 51,868 kB
  • sloc: cpp: 269,341; python: 22,756; sh: 3,609; perl: 770; xml: 333; f90: 204; ansic: 141; makefile: 70
file content (41 lines) | stat: -rw-r--r-- 2,479 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
.. _cli_scripting_in_batch:

Using :code:`ecflow_client` in Tasks
************************************

:code:`ecflow_client` can be used from within Task scripts. This enables some very
powerful tools for controlling suites, and allows to set up dynamic suites
(i.e. suites that manage themselves, by updating/adding removing nodes and attributes).

ecFlow variables can be updated (using the :code:`--alter` options), Tasks and Families can
be set to Complete (using :code:`--force`), and Suites can be dynamically generated.

Dynamic Suite generation can be easily achieved by modifying a Definition file template,
followed by replacing the modified part of the Suite.

.. code-block:: shell
   :caption: Examples of how to use :code:`--alter` command

    ecflow_client --alter=add variable GLOBAL "value" /           # add server variable
    ecflow_client --alter=add variable FRED "value" /path/to/node # add node variable
    ecflow_client --alter=add time "+00:20" /path/to/node
    ecflow_client --alter=add date "01.*.*" /path/to/node
    ecflow_client --alter=add day "sunday"  /path/to/node
    ecflow_client --alter=add label name "label_value" /path/to/node
    ecflow_client --alter=add late "-s 00:01 -a 14:30 -c +00:01" /path/to/node
    ecflow_client --alter=add limit mars "100" /path/to/node
    ecflow_client --alter=add inlimit /path/to/node/withlimit:limit_name "10" /s1
    
    # zombie attributes have the following structure:
        `zombie_type`:(`client_side_action` | `server_side_action`):`child`:`zombie_life_time`
          zombie_type        = "user" | "ecf" | "path" | "ecf_pid" | "ecf_passwd" | "ecf_pid_passwd"
          client_side_action = "fob" | "fail" | "block"
          server_side_action = "adopt" | "delete" | "kill"
          child              = "init" | "event" | "meter" | "label" | "wait" | "abort" | "complete" | "queue"
          zombie_life_time   = unsigned integer default: user(300), ecf(3600), path(900)  minimum is 60
    ecflow_client --alter=add zombie "ecf:fail::" /path/to/node     # ask system zombies to fail
    ecflow_client --alter=add zombie "user:fail::" /path/to/node    # ask user generated zombies to fail
    ecflow_client --alter=add zombie "path:fail::" /path/to/node    # ask path zombies to fail
    
    ecflow_client --alter=delete variable FRED /path/to/node    # delete variable FRED
    ecflow_client --alter=delete variable      /path/to/node    # delete *ALL* variables on the specified node