File: late-attribute.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 (86 lines) | stat: -rw-r--r-- 3,415 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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
.. index::
   single: late attribute (tutorial)

.. _tutorial-late-attribute:

Late
====

Sometimes tasks do not complete in an expected time constrait, and the user needs to be notificatied.
This notification can be performed by using :term:`late` attribute.

Each node can only have **one** :term:`late` attribute, and :term:`late` attributes **only** apply to tasks.
When a :term:`late` attribute is defined on a :term:`suite` or :term:`family`, it will be inherited;
and, any :term:`late` attribute defined lower down the hierarchy will override the aspect (submitted, active, complete)
defined higher up.

A :term:`late` attribute defines time constraints for a task to be: :term:`submitted`, :term:`active` or :term:`complete`.

* :code:`-s` submitted: The amount of time the node can stay submitted (format :code:`[+]hh:mm`). The time value is always relative, so :code:`+` is simply ignored, if present. The late flag is set if the node stays submitted longer than the specified amount of time.
* :code:`-a` active: The time of day the node must have become active (format :code:`hh:mm`). The late flag is set if the node is still queued or submitted after the specified time.
* :code:`-c` complete: The amount of time node can take to become complete (format :code:`[+]hh:mm`). If relative, the amount of time that the node can take to complete since becoming active; otherwise, the node must be complete by the specified time.

.. code-block:: shell
   :caption: :code:`late` example

   task t1
      late -s +00:15 -a 20:00 -c +02:00

The :code:`late` in the example above is interpreted as:

* the node can stay submitted for a maximum of 15 minutes
* *and* it must become active by 20:00
* *and* the runtime must not exceed 2 hours.

For the purposes of this tutorial, the late attribute will apply a contraint to the runtime only.

Suite Definition
----------------

.. tabs::

    .. tab:: Text

        Modify the :term:`suite definition` file, as follows:

        .. code-block:: shell

           # Definition of the suite test.
           suite test
             edit ECF_INCLUDE "$HOME/course"    # replace $HOME with the path to your home directory
             edit ECF_HOME    "$HOME/course"

             family f6
                  edit SLEEP 120
                  task t1
                       late -c +00:01 # set late flag if task take longer than a minute
             endfamily
           endsuite

    .. tab:: Python

        .. literalinclude:: src/late-attribute.py
           :language: python
           :caption: $HOME/course/test.py

Task Script
-----------

Create new :term:`task script <ecf script>` file :code:`$HOME/course/test/f6/t1.ecf`, related to the new task.

.. code-block:: bash
   :caption: $HOME/course/test/f6/t1.ecf

   %include <head.h>
   echo "I will now sleep for %SLEEP% seconds"
   sleep %SLEEP%
   %include <tail.h>


**What to do**

#. Apply the changes to :term:`suite definition`.
#. Create the new :term:`task script <ecf script>` file as shown above.
#. In the :term:`ecflow_ui`, run the suite and observer the late flag being set
#. When the job completes, requeue the family :code:`f6` or task :code:`t1`, and observe that this clears the late flag.
#. In the :term:`ecflow_ui`, the late flag can also be cleared manually, by selecting task :code:`t1`, and then in the Right Mouse Button context menu, select *Special*, and *Clear late flag*.