Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Python

To delete the suite definition, reload and begin using the Client Server API: First update test.py to add task t2

#!/usr/bin/env python2.7
import os
import ecflow

print "Creating suite definition"   
defs = ecflow.Defs()
suite = defs.add_suite("test")
suite.add_variable("ECF_HOME", os.path.join(os.getenv("HOME"),  "course"))
suite.add_task("t1")
suite.add_task("t2")
print defs

print "Checking job creation: .ecf -> .job0"   
print defs.check_job_creation()

print "Saving definition to file 'test.def'"
defs.save_as_defs("test.def")

 

To delete all suites in the server and reload modified test.def, we could update client.py

#!/usr/bin/env python2.7
import ecflow 
   
print "Client -> Server: delete, then load a new definition"   
try:
    ci = ecflow.Client()
    ci.delete_all()           # clear out the server
    ci.load("test.def")       # load the definition into the server
    ci.begin_suite("test")    # start the suite
except RuntimeError as e:
    print "Failed:",   e 
    
Rather than deleting, loading and beginning the suite every time you can replace
all or part of the suite. (i.e. to replace the whole suite see below)
Additionally we do not want the suite to start straight away. This can be done
by suspending the suite in  ecflow_ui before reloading.
However we will need to remember to do this, each time. To get round this we will
suspend the suite use the Client Server API:
Modify client.py with:
#!/usr/bin/env python2.7
import ecflow 
   
print "Client -> Server: replacing suite '/test' in the server, with a new definition"   
try:
    ci = ecflow.Client()
    ci.suspend("/test")              # so that we can resume manually in ecflowviewecflow_ui
    ci.replace("/test", "test.def")
except RuntimeError as e:
    print "Failed:",   e 
    

 

Note
For brevity the examples that follow, will not show the loading of the suite.

 

What to do

  1. Suspend the suite using ecflow_ui or via python using ecflow.Client.suspend
  2. Create the new task
  3. Create t2.ecf by copying from t1.ecf
  4. Update python scripts test.py and client.py or test.def
  5. Replace the suite
  6. Resume the the suite using ecflow_ui
  7. In ecflow_ui watch the two task running. They should run at the same time
       

...