File: defining-a-new-suite.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 (113 lines) | stat: -rw-r--r-- 4,235 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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
.. index::
   single: Defining a new suite (tutorial)
   single: ECF_HOME (tutorial)
    
.. _tutorial-defining-a-suite:

Defining a new suite
====================

Designing a new workflow encompases two closely tied steps:

    1. Define the :term:`suite`, which will eventually be composed of :term:`tasks <task>`, potentially organized in :term:`families <family>`. The outcome of this step is the :term:`suite definition` file.
    2. Create the :term:`task` scripts, that will eventually become :term:`job file` to be executed.

This section describes how to perform first of these steps.

There are several approaches to defining the :term:`suite definition` - the two most common are:

    1. Using a plain text file, with a specific syntax.
    2. Using the ecFlow Python API.

This tutorial will give examples for both the plain text and Python methods.

.. tabs::

   .. tab:: Text

      A test-based :term:`suite definition` is just a plain file, that uses a specific syntax to define the
      components of a suite (or sets of suites).

      To define a simple :term:`suite`, use a text editor to create a file named :code:`test.def`, with the following contents:

      .. code-block:: shell
         :linenos:
         :caption: $HOME/course/test.def

         # A simple example suite

         suite test
           edit ECF_HOME "{{HOME}}/course"
           task t1
         endsuite

      .. warning::

         Please **replace** :code:`{{HOME}}` so that path :code:`{{HOME}}/course` is correct and exists.

      This file contains the :term:`suite definition` of a :term:`suite` named :code:`test`.
      The suite :code:`test` contains a single :term:`task` called :code:`t1`.
      A line by line explanation of the file above is as follows:

      * Line :code:`1` is a comment line. All characters after the symbol :code:`#` ignored.
      * Line :code:`2` is empty.
      * Line :code:`3` defines a :term:`suite` named :code:`test`.
      * Line :code:`4` defines a :term:`variable` called :code:`ECF_HOME`, which defines the directory
        where all the files that will be used by the :term:`suite` test will reside.
      * Line :code:`5` defines a :term:`task` named :code:`t1`
      * Line :code:`6` indicates the end of the :term:`suite definition`.

      .. important::

         This tutorial will consider the :code:`{{HOME}}/course` path throughout, and all other
         file paths will be relative to this base path.

   .. tab:: Python

      Using the ecFlow Python API allows to automate the creation of the :term:`suite definition` file,
      by leveraing the expressiveness of the Python language to create complex :term:`suites <suite>`.

      .. important::

            Even though the plain text method is the most straightforward, it is also limited.
            The use of the Python API is more powerful and flexible, and is the recommended approach for
            defining complex :term:`suites <suite>`.

      To define a simple :term:`suite`, use a text editor to create a Python script named :code:`test.py`, with the following contents:

      .. literalinclude:: src/defining-a-new_suite.py
         :language: python
         :linenos:
         :caption: $HOME/course/test.py

      And then run the Python script:

      .. code-block:: shell

         cd $HOME/course

         # Either run by explicitly invoking python
         python3 ./test.py

         # Or make the script executable, and run it directly
         chmod +x test.py
         ./test.py

      .. warning::

         Ensure ecFlow Python API module is available by including it in the Python module search path.
         This can be done by setting the :code:`PYTHONPATH` environment variable, e.g.:

         .. code-block:: shell

            export PYTHONPATH=$ECFLOW_ROOT_DIR/lib/pyext3:$PYTHONPATH


      Once finished executing, the script will print the :term:`suite` :code:`test` definition on the console
      and also generate the :code:`$HOME/course/test.def`.


**What to do:**

#. Manually create the text-based :term:`suite definition` file, placing the file at :code:`$HOME/course/test.def`.
#. (Optional) Use the Python-based approach to create :term:`suite definition` file.