taskScope vars in block

This is a test case to show that the taskScope var used in block func could be accessed accross the whole block and the entire task

Demo

source

Main task yaml file
    vars:
      tom: this is tom
    tasks:
    - name: task
      task:
      - func: block
        do:
        - func: cmd
          dvars:
          - name: jerry
            value: this is jerry in task scope
            flags:
            - taskScope
        - func: cmd
          do:
          - name: print
            desc: this should print out the dvar value of jerry
            cmd: '{{.jerry}}'
      - func: cmd
        do:
        - name: print
          desc: this should print out the dvar value of jerry
          cmd: '{{.jerry}}'
      - func: call
        do:
        - subtask1
    - name: subtask1
      task:
      - func: cmd
        do:
        - name: print
          desc: this should print out the dvar value of jerry as it is declared jerry
            is in taskScope
          cmd: '{{.jerry}}'
        - name: trace
          cmd: ===>
      - func: cmd
        vars:
          jerry: jerry is overriden in local scope
        do:
        - name: print
          desc: |
            remember that the caller's vars should override callee's vars
            so jerry's value should the one from caller instead this local value
          cmd: '{{.jerry}}'
        - name: trace
          cmd: <===
    
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 -> c0148
                 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/c0148
    module: [self], instance id: [dev], exec profile: []
    profile -  envVars:
    
    (*core.Cache)({
    })
    
    Task1: [task ==> task:  ]
    -Step1:
    self: final context exec vars:
    
    (*core.Cache)({
      "tom": "this is tom",
      "up_runtime_task_layer_number": 0
    })
    
    -Step1:
    self: final context exec vars:
    
    (*core.Cache)({
      "tom": "this is tom",
      "up_runtime_task_layer_number": 0,
      "jerry": "this is jerry in task scope"
    })
    
     WARN: [cmd] - [Not implemented or void for no action!]
    -Step2:
    self: final context exec vars:
    
    (*core.Cache)({
      "tom": "this is tom",
      "up_runtime_task_layer_number": 0,
      "jerry": "this is jerry in task scope"
    })
    
    ~SubStep1: [print: this should print out the dvar value of jerry ]
    this is jerry in task scope
    -Step2:
    self: final context exec vars:
    
    (*core.Cache)({
      "tom": "this is tom",
      "up_runtime_task_layer_number": 0,
      "jerry": "this is jerry in task scope"
    })
    
    ~SubStep1: [print: this should print out the dvar value of jerry ]
    this is jerry in task scope
    -Step3:
    self: final context exec vars:
    
    (*core.Cache)({
      "tom": "this is tom",
      "up_runtime_task_layer_number": 0,
      "jerry": "this is jerry in task scope"
    })
    
    =Task2: [task ==> subtask1:  ]
    --Step1:
    self: final context exec vars:
    
    (*core.Cache)({
      "jerry": "this is jerry in task scope",
      "tom": "this is tom",
      "up_runtime_task_layer_number": 1
    })
    
    ~~SubStep1: [print: this should print out the dvar value of jerry as it is declared jerry is in taskScope ]
    this is jerry in task scope
    ~~SubStep2: [trace:  ]
    Trace:===>
    --Step2:
    self: final context exec vars:
    
    (*core.Cache)({
      "jerry": "this is jerry in task scope",
      "tom": "this is tom",
      "up_runtime_task_layer_number": 1
    })
    
    ~~SubStep1: [print: remember that the caller's vars should override callee's vars
    so jerry's value should the one from caller instead this local value
     ]
    this is jerry in task scope
    ~~SubStep2: [trace:  ]
    Trace:<===
    
Logs with different verbose level
Raw logs with different verbose level