Versions Compared

Key

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


Horizontal Navigation Bar


Button Group

Button Hyperlink
titlePrevious
typestandard
urlhttps://confluence.ecmwf.int/display/ECFLOW/Starting+the+suite
Button Hyperlink
titleUp
typestandard
urlhttps://confluence.ecmwf.int/display/ECFLOW/Tutorial
Button Hyperlink
titleNext
typestandard
urlhttps://confluence.ecmwf.int/display/ECFLOW/Using+ecflow_ui


Let us now see how our suite ran, type the following:

...


Code Block
languagebash
 ecflow_client --get_

...

state


This command will retrieve the suite definition from the server, and show the status for each node.
Look at the task t1 if it is complete and the suite is complete then the run was successful.
If this is not the case, and you might see aborted.
Please check the location (directory) of your ecf script before referring to your instructor.
The job file created by the server is located in the same directory as the ecf script, and is named t1.job1.
Compare the files t1.ecf, head.h, tail.h and t1.job1.
The output of the job is located in the same directory as the ecf script, and is named t1.1.

Retrieving the suite definition

  • To retrieve the suite definition in a form that is parse-able, type:


    Code Block
    ecflow_client --get


    This can be done in a python script:

    Code Block
    languagepy
    import ecflow
    try:
        ci = ecflow.Client()                              # create the client, will read ECF_HOST and ECF_PORT from environment
        ci.sync_local()                                   

...

  • # get server definition, by 

...

  • syncing with client 

...

  • defs
       

...

  •  ecflow.PrintStyle.set_style( ecflow.Style.DEFS )  # set printing to 

...

  • show structure
       

...

  •  print(ci.get_defs())                              

...

  • # print the returned suite 

...

  • definition
    

...

  • except RuntimeError as e:
       

...

  •  

...

  • print("Failed:",e)


  • To retrieve the suite definition and show state:


    Code Block
    languagebash
    ecflow_client --get_state   # show state, generated variables, expanded trigger expression, auto added externs
    ecflow_client --migrate     # shows state as comments, used as check point format


    In python this would be:

    Code Block
    languagepy
    import ecflow
    try:
        ci = ecflow.Client()
        ci.sync_local()                                     # retrieve server definition, 

...

  • by sync with client defs
       

...

  •  ecflow.PrintStyle.set_style( ecflow.Style.STATE )   # set printing to show structure and state, expanded trigger expression, generated variables   
        print(ci.get_defs())                               

...

  •  # print the returned suite definition
        ecflow.PrintStyle.set_style( ecflow.Style.MIGRATE ) # set printing to show structure and state, and node history
        print(ci.get_defs())                                # print the returned suite definition
    except RuntimeError as e:
        print("Failed:",  e)


     
  • To list just the node paths and states in python please see: How can I access the path and task states?

What to do

  1. Locate the job file and the output file
  2. Check results by retrieving the suite definition from the server
     
Horizontal Navigation Bar


Button Group

Button Hyperlink
titlePrevious
typestandard
urlhttps://confluence.ecmwf.int/display/ECFLOW/Starting+the+suite
Button Hyperlink
titleUp
typestandard
urlhttps://confluence.ecmwf.int/display/ECFLOW/Tutorial
Button Hyperlink
titleNext
typestandard
urlhttps://confluence.ecmwf.int/display/ECFLOW/Using+ecflow_ui

definition</span> <span class="k">except</span> <span class="ne">RuntimeError</span><span class="p">,</span> <span class="n">e</span><span class="p">:</span> <span class="k">print</span> <span class="s">&quot;failed: &quot;</span> <span class="o">+</span> <span class="nb">str</span><span class="p">(</span><span class="n">e</span><span class="p">);</span> </pre></div> </div> </li> </ul> <p>What to do:</p> <ol class="arabic simple"> <li>Locate the ECF job and the output</li> <li>Check results by retrieving the <a class="reference internal" href="/wiki/display/ECFLOW/Glossary#term-suite-definition"><em class="xref std std-term">suite definition</em></a> from the server</li> </ol> </div> </div>