Horizontal Navigation Bar |
---|
Button Group |
---|
Button Hyperlink |
---|
title | Previous |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Add+an+event |
---|
|
Button Hyperlink |
---|
title | Up |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Going+Further |
---|
|
Button Hyperlink |
---|
title | Next |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Add+a+meter |
---|
|
|
|
Sometimes a task should not be run Sometimes you do not want to run a task when a certain condition is met.
The condition can be signalled by an event. For example, event t2:b
might indicate that task t2 did not manage to produce the expected result, so
we do not need to run task t4.
This has a similar syntax to the
trigger keyword but sets a
taskcomplete expression evaluation takes precedence over the trigger.
Completes can be between tasks, between families, or both.
It can be used in conjunction with a
trigger. For example:
Text
Code Block |
---|
# 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 f1
edit SLEEP 20
task t1
task t2
trigger t1 eq complete # task t2 will only start when task t1 is complete
event a # task t2 will set an event a
event b # task t2 will set an event b
task t3
trigger t2:a # task t3 will start when event a is set in task t2
task t4
trigger t2 eq complete # task t4 will start when task t2 is complete
complete t2:b # task t4 will complete if event b is set in task t2
endfamily
endsuite |
Python
#!/usr/bin/env python2.7
Code Block |
---|
language | py |
---|
title | $HOME/course/test.py |
---|
|
import os
|
importfrom ecflow import Defs,Suite,Family,Task,Edit,Trigger,Complete,Event
def create_family_f1():
|
f1= ecflow.)f1.add_variable("SLEEP",f1.add_taskt2 = f1.add_task)
t2.add_triggereq
t2.add_eventt2.add_eventf1.add_task).add_trigger
t4=f1.add_task)t4.add_triggereq
t4.add_complete returnf1
("Creating suite definition") |
defsecflow.Defs()
suite = defs.add_suite("test")
suite.add_variable("ECF_INCLUDE", os.path.join(os.getenv("HOME") |
+/suite.add_variable("ECF_HOME", os.getenv("HOME") + "/course")
suite.add_family(defs = Defs(
Suite("test",
Edit(ECF_INCLUDE=home,ECF_HOME=home),
create_family_f1() |
defs ("Checking job creation: .ecf -> .job0" |
(defs.check_job_creation())
print |
"Checking trigger expressions"
print defs.check)
print "Saving definition to file 'test.def'")
defs.save_as_defs("test.def") |
What to do
- Update test.def or test.py to add a complete expression to task t4
- Replace the suite
python: python3 test.py; python3 client.py
text: ecflow_client --suspend=/test ; ecflow_client --replace=/test test.def - Observe the tasks in ecflowview ecflow_ui
- See the triggers by selecting t4 and clicking on the Image Removed icon
- See the trigger relation by clicking on the arrow
- See the triggers in the tree, using the Show menu
- Note the icon indicating that the task has not run
- You can To check the triggers modify task t2 to check that so that event b is not triggered; task t4 will run when the event is not set
- should run when t2 completes.
Horizontal Navigation Bar |
---|
Button Group |
---|
Button Hyperlink |
---|
title | Previous |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Add+an+event |
---|
|
Button Hyperlink |
---|
title | Up |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Going+Further |
---|
|
Button Hyperlink |
---|
title | Next |
---|
type | standard |
---|
url | https://confluence.ecmwf.int/display/ECFLOW/Add+a+meter |
---|
|
|
|
...