block in else

Add the support of execution of a flow using else tag

Var auto merge applies the same to flow in else branch

Please notice that the values printed out in the else branch

Demo

source

Main task yaml file
    vars:
      a: global_aaa
      b: global_bbb
      c: global_ccc
      goahead: False
    #  goahead: True
    
    tasks:
    - name: task
      task:
      - func: block
        desc: show example the route goes to call goelse for the condition of not if condition
          succeeds
        vars:
          a: local_aaa
          b: local_bbb
        dvars:
        - name: da
          value: local_da
        - name: db
          value: local_db
        do:
        - func: shell
          do:
          - echo "shell step1"
          - echo "shell step2"
        - func: cmd
          vars:
            a: block_layer1_aaa
          do:
          - name: print
            cmd: |
              layer 1
              up_runtime_task_layer_number: {{.up_runtime_task_layer_number}}
              a: {{.a}}
              b: {{.b}}
              c: {{.c}}
              da: {{.da}}
              db: {{.db}}
        - func: shell
          do:
          - echo "shell step3"
          - echo "shell step4"
        - func: block
          desc: test embeded 2nd layer of block
          vars:
            a: local_block_layer2_aaa
            b: local_block_layer2_bbb
          dvars:
          - name: da
            value: local_da_layer2
          - name: db
            value: local_db_layer2
          do:
          - func: cmd
            vars:
              a: block_layer2_aaa
            do:
            - name: print
              cmd: |
                layer 2
                up_runtime_task_layer_number: {{.up_runtime_task_layer_number}}
                a: {{.a}}
                b: {{.b}}
                c: {{.c}}
                da: {{.da}}
                db: {{.db}}
        - func: shell
          do:
          - echo "shell step5"
          - echo "shell step6"
        if: '{{.goahead}}'
        else:
        - func: shell
          do:
          - echo "else step1"
          - echo "else step2"
        - func: cmd
          vars:
            a: block_layer1_aaa_else
          do:
          - name: print
            cmd: |
              layer 1
              up_runtime_task_layer_number: {{.up_runtime_task_layer_number}}
              a: {{.a}}
              b: {{.b}}
              c: {{.c}}
              da: {{.da}}
              db: {{.db}}
    
Main log file
    loading [Config]:  ./tests/functests/upconfig.yml
    Main config:
                 Version -> 1.0.0
                  RefDir -> ./tests/functests
                 WorkDir -> cwd
              AbsWorkDir -> /up_project/up
                TaskFile -> c0130
                 Verbose -> vvv
              ModuleName -> self
               ShellType -> /bin/sh
           MaxCallLayers -> 8
                 Timeout -> 3600000
     MaxModuelCallLayers -> 256
               EntryTask -> task
      ModRepoUsernameRef -> 
      ModRepoPasswordRef -> 
    work dir: /up_project/up
    -exec task: task
    loading [Task]:  ./tests/functests/c0130
    module: [self], instance id: [dev], exec profile: []
    profile -  envVars:
    
    (*core.Cache)({
    })
    
    Task1: [task ==> task:  ]
    -Step1: [: show example the route goes to call goelse for the condition of not if condition succeeds ]
    self: final context exec vars:
    
    (*core.Cache)({
      "db": "local_db",
      "b": "local_bbb",
      "c": "global_ccc",
      "goahead": false,
      "a": "local_aaa",
      "up_runtime_task_layer_number": 0,
      "da": "local_da"
    })
    
    -Step1:
    self: final context exec vars:
    
    (*core.Cache)({
      "goahead": false,
      "a": "local_aaa",
      "b": "local_bbb",
      "c": "global_ccc",
      "up_runtime_task_layer_number": 0,
      "da": "local_da",
      "db": "local_db"
    })
    
    cmd( 1):
    echo "else step1"
    
    -
    else step1
    
    -
     .. ok
    cmd( 2):
    echo "else step2"
    
    -
    else step2
    
    -
     .. ok
    . ok
    -Step2:
    self: final context exec vars:
    
    (*core.Cache)({
      "b": "local_bbb",
      "up_runtime_task_layer_number": 0,
      "da": "local_da",
      "db": "local_db",
      "c": "global_ccc",
      "goahead": false,
      "a": "block_layer1_aaa_else",
      "last_result": (*utils.ExecResult)({
        Cmd: "echo \"else step2\"",
        Code: 0,
        Output: "else step2",
        ErrMsg: ""
      })
    })
    
    ~SubStep1: [print:  ]
    layer 1
    up_runtime_task_layer_number: 0
    a: block_layer1_aaa_else
    b: local_bbb
    c: global_ccc
    da: local_da
    db: local_db
    
    
Logs with different verbose level
Raw logs with different verbose level