Adding Defstatus, Autocancel

Adding defstatus

The defstatus sets the default state of a node when the begin or re-queue commands are run.

from ecflow import Defs, Suite, Task, Defstatus, AutoCancel

defs = Defs(
   Suite(
      "s1",
         Task("t1", Defstatus("complete")),
         Task("t2", Defstatus(DState.complete))
   )
)

The following shows alternative styles that produce the same definition:

defs = Defs()
s1 = defs.add_suite("s1")
s1.add_task("t1").add_defstatus(Defstatus("complete"))
s1.add_task("t2").add_defstatus(DState.complete)
defs = Defs().add(
   Suite("s1").add(
      Task("t1").add(Defstatus("complete")),
      Task("t2").add(Defstatus(DState.complete))))
defs = Defs() + (Suite("s1") + Task("t1") + Task("t2"))
defs.s1.t1 += Defstatus("complete")
defs.s1.t2 += Defstatus(DState.complete)

Adding autocancel

from ecflow import Defs, Suite, Task, AutoCancel, TimeSlot

defs = Defs(
   Suite(
      "s1",
      Task("t1", Autocancel(3)),  # delete task after 3 days after completion
      Task(
            "t2", Autocancel(1, 10, True)
      ),  # delete task 1hr 10 min after task completion
      Task(
            "t3", Autocancel(TimeSlot(2, 10), True)
      ),  # delete task 2hr 10 min after task completion
      Task("t4", Autocancel(1)),  # delete task after 1 day after task completion
      Task(
            "t5", Autocancel(18, 10, False)
      ),  # delete task at 6:10pm once it has completed
      Task("t6", Autocancel(2, 10, False)),
   )
)  # delete task at 2:10am once it has completed

The following examples show alternative styles of adding Autocancel which produce the same definition.

defs = Defs()
s1 = defs.add_suite("s1")
s1.add_task("t1").add_autocancel(3)
s1.add_task("t2").add_autocancel(1, 10, True)
s1.add_task("t3").add_autocancel(TimeSlot(2, 10), True)
s1.add_task("t4").add_autocancel(Autocancel(1))
s1.add_task("t5").add_autocancel(Autocancel(18, 10, False))
s1.add_task("t6").add_autocancel(Autocancel(TimeSlot(2, 10), False))
defs = Defs().add(
   Suite("s1").add(
      Task("t1").add(Autocancel(3)),
      Task("t2").add(Autocancel(1, 10, True)),
      Task("t3").add(Autocancel(TimeSlot(2, 10), True)),
      Task("t4").add(Autocancel(1)),
      Task("t5").add(Autocancel(18, 10, False)),
      Task("t6").add(Autocancel(2, 10, False)),
   )
)
defs = Defs() + (Suite("s1") + [Task("t{0}".format(i)) for i in range(1, 7)])
defs.s1.t1 += Autocancel(3)
defs.s1.t2 += Autocancel(1, 10, True)
defs.s1.t3 += Autocancel(TimeSlot(2, 10), True)
defs.s1.t4 += Autocancel(1)
defs.s1.t5 += Autocancel(18, 10, False)
defs.s1.t6 += Autocancel(2, 10, False)

Warning

In the example above we use ‘defs.s1.t1’ to reference a node by name. This is useful in small designs but will produce maintenance issues in large designs if the node names are changed.