mirror of
https://github.com/go-task/task.git
synced 2024-12-12 10:45:49 +02:00
refactor: taskfile/ast package (#1450)
* refactor: ast package * feat: read -> taskfile * refactor: taskfile.Taskfile -> taskfile.Read * refactor: move merge function back into taskfile package * refactor: rename taskfile.go to read.go
This commit is contained in:
parent
2b67d05b9d
commit
247c2586c2
12
args/args.go
12
args/args.go
@ -3,22 +3,22 @@ package args
|
|||||||
import (
|
import (
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Parse parses command line argument: tasks and global variables
|
// Parse parses command line argument: tasks and global variables
|
||||||
func Parse(args ...string) ([]taskfile.Call, *taskfile.Vars) {
|
func Parse(args ...string) ([]ast.Call, *ast.Vars) {
|
||||||
calls := []taskfile.Call{}
|
calls := []ast.Call{}
|
||||||
globals := &taskfile.Vars{}
|
globals := &ast.Vars{}
|
||||||
|
|
||||||
for _, arg := range args {
|
for _, arg := range args {
|
||||||
if !strings.Contains(arg, "=") {
|
if !strings.Contains(arg, "=") {
|
||||||
calls = append(calls, taskfile.Call{Task: arg, Direct: true})
|
calls = append(calls, ast.Call{Task: arg, Direct: true})
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
name, value := splitVar(arg)
|
name, value := splitVar(arg)
|
||||||
globals.Set(name, taskfile.Var{Value: value})
|
globals.Set(name, ast.Var{Value: value})
|
||||||
}
|
}
|
||||||
|
|
||||||
return calls, globals
|
return calls, globals
|
||||||
|
@ -8,18 +8,18 @@ import (
|
|||||||
|
|
||||||
"github.com/go-task/task/v3/args"
|
"github.com/go-task/task/v3/args"
|
||||||
"github.com/go-task/task/v3/internal/orderedmap"
|
"github.com/go-task/task/v3/internal/orderedmap"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestArgs(t *testing.T) {
|
func TestArgs(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
Args []string
|
Args []string
|
||||||
ExpectedCalls []taskfile.Call
|
ExpectedCalls []ast.Call
|
||||||
ExpectedGlobals *taskfile.Vars
|
ExpectedGlobals *ast.Vars
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
Args: []string{"task-a", "task-b", "task-c"},
|
Args: []string{"task-a", "task-b", "task-c"},
|
||||||
ExpectedCalls: []taskfile.Call{
|
ExpectedCalls: []ast.Call{
|
||||||
{Task: "task-a", Direct: true},
|
{Task: "task-a", Direct: true},
|
||||||
{Task: "task-b", Direct: true},
|
{Task: "task-b", Direct: true},
|
||||||
{Task: "task-c", Direct: true},
|
{Task: "task-c", Direct: true},
|
||||||
@ -27,14 +27,14 @@ func TestArgs(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
Args: []string{"task-a", "FOO=bar", "task-b", "task-c", "BAR=baz", "BAZ=foo"},
|
Args: []string{"task-a", "FOO=bar", "task-b", "task-c", "BAR=baz", "BAZ=foo"},
|
||||||
ExpectedCalls: []taskfile.Call{
|
ExpectedCalls: []ast.Call{
|
||||||
{Task: "task-a", Direct: true},
|
{Task: "task-a", Direct: true},
|
||||||
{Task: "task-b", Direct: true},
|
{Task: "task-b", Direct: true},
|
||||||
{Task: "task-c", Direct: true},
|
{Task: "task-c", Direct: true},
|
||||||
},
|
},
|
||||||
ExpectedGlobals: &taskfile.Vars{
|
ExpectedGlobals: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"FOO": {Value: "bar"},
|
"FOO": {Value: "bar"},
|
||||||
"BAR": {Value: "baz"},
|
"BAR": {Value: "baz"},
|
||||||
"BAZ": {Value: "foo"},
|
"BAZ": {Value: "foo"},
|
||||||
@ -45,12 +45,12 @@ func TestArgs(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
Args: []string{"task-a", "CONTENT=with some spaces"},
|
Args: []string{"task-a", "CONTENT=with some spaces"},
|
||||||
ExpectedCalls: []taskfile.Call{
|
ExpectedCalls: []ast.Call{
|
||||||
{Task: "task-a", Direct: true},
|
{Task: "task-a", Direct: true},
|
||||||
},
|
},
|
||||||
ExpectedGlobals: &taskfile.Vars{
|
ExpectedGlobals: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"CONTENT": {Value: "with some spaces"},
|
"CONTENT": {Value: "with some spaces"},
|
||||||
},
|
},
|
||||||
[]string{"CONTENT"},
|
[]string{"CONTENT"},
|
||||||
@ -59,13 +59,13 @@ func TestArgs(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
Args: []string{"FOO=bar", "task-a", "task-b"},
|
Args: []string{"FOO=bar", "task-a", "task-b"},
|
||||||
ExpectedCalls: []taskfile.Call{
|
ExpectedCalls: []ast.Call{
|
||||||
{Task: "task-a", Direct: true},
|
{Task: "task-a", Direct: true},
|
||||||
{Task: "task-b", Direct: true},
|
{Task: "task-b", Direct: true},
|
||||||
},
|
},
|
||||||
ExpectedGlobals: &taskfile.Vars{
|
ExpectedGlobals: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"FOO": {Value: "bar"},
|
"FOO": {Value: "bar"},
|
||||||
},
|
},
|
||||||
[]string{"FOO"},
|
[]string{"FOO"},
|
||||||
@ -74,18 +74,18 @@ func TestArgs(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
Args: nil,
|
Args: nil,
|
||||||
ExpectedCalls: []taskfile.Call{},
|
ExpectedCalls: []ast.Call{},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Args: []string{},
|
Args: []string{},
|
||||||
ExpectedCalls: []taskfile.Call{},
|
ExpectedCalls: []ast.Call{},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
Args: []string{"FOO=bar", "BAR=baz"},
|
Args: []string{"FOO=bar", "BAR=baz"},
|
||||||
ExpectedCalls: []taskfile.Call{},
|
ExpectedCalls: []ast.Call{},
|
||||||
ExpectedGlobals: &taskfile.Vars{
|
ExpectedGlobals: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"FOO": {Value: "bar"},
|
"FOO": {Value: "bar"},
|
||||||
"BAR": {Value: "baz"},
|
"BAR": {Value: "baz"},
|
||||||
},
|
},
|
||||||
|
@ -19,7 +19,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/internal/sort"
|
"github.com/go-task/task/v3/internal/sort"
|
||||||
ver "github.com/go-task/task/v3/internal/version"
|
ver "github.com/go-task/task/v3/internal/version"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
const usage = `Usage: task [flags...] [task...]
|
const usage = `Usage: task [flags...] [task...]
|
||||||
@ -68,7 +68,7 @@ var flags struct {
|
|||||||
concurrency int
|
concurrency int
|
||||||
dir string
|
dir string
|
||||||
entrypoint string
|
entrypoint string
|
||||||
output taskfile.Output
|
output ast.Output
|
||||||
color bool
|
color bool
|
||||||
interval time.Duration
|
interval time.Duration
|
||||||
global bool
|
global bool
|
||||||
@ -291,8 +291,8 @@ func run() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
calls []taskfile.Call
|
calls []ast.Call
|
||||||
globals *taskfile.Vars
|
globals *ast.Vars
|
||||||
)
|
)
|
||||||
|
|
||||||
tasksAndVars, cliArgs, err := getArgs()
|
tasksAndVars, cliArgs, err := getArgs()
|
||||||
@ -304,11 +304,11 @@ func run() error {
|
|||||||
|
|
||||||
// If there are no calls, run the default task instead
|
// If there are no calls, run the default task instead
|
||||||
if len(calls) == 0 {
|
if len(calls) == 0 {
|
||||||
calls = append(calls, taskfile.Call{Task: "default", Direct: true})
|
calls = append(calls, ast.Call{Task: "default", Direct: true})
|
||||||
}
|
}
|
||||||
|
|
||||||
globals.Set("CLI_ARGS", taskfile.Var{Value: cliArgs})
|
globals.Set("CLI_ARGS", ast.Var{Value: cliArgs})
|
||||||
globals.Set("CLI_FORCE", taskfile.Var{Value: flags.force || flags.forceAll})
|
globals.Set("CLI_FORCE", ast.Var{Value: flags.force || flags.forceAll})
|
||||||
e.Taskfile.Vars.Merge(globals)
|
e.Taskfile.Vars.Merge(globals)
|
||||||
|
|
||||||
if !flags.watch {
|
if !flags.watch {
|
||||||
|
4
hash.go
4
hash.go
@ -4,10 +4,10 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/hash"
|
"github.com/go-task/task/v3/internal/hash"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (e *Executor) GetHash(t *taskfile.Task) (string, error) {
|
func (e *Executor) GetHash(t *ast.Task) (string, error) {
|
||||||
r := t.Run
|
r := t.Run
|
||||||
if r == "" {
|
if r == "" {
|
||||||
r = e.Taskfile.Run
|
r = e.Taskfile.Run
|
||||||
|
6
help.go
6
help.go
@ -16,7 +16,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/fingerprint"
|
"github.com/go-task/task/v3/internal/fingerprint"
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/internal/sort"
|
"github.com/go-task/task/v3/internal/sort"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ListOptions collects list-related options
|
// ListOptions collects list-related options
|
||||||
@ -57,7 +57,7 @@ func (o ListOptions) Validate() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Filters returns the slice of FilterFunc which filters a list
|
// Filters returns the slice of FilterFunc which filters a list
|
||||||
// of taskfile.Task according to the given ListOptions
|
// of ast.Task according to the given ListOptions
|
||||||
func (o ListOptions) Filters() []FilterFunc {
|
func (o ListOptions) Filters() []FilterFunc {
|
||||||
filters := []FilterFunc{FilterOutInternal}
|
filters := []FilterFunc{FilterOutInternal}
|
||||||
|
|
||||||
@ -159,7 +159,7 @@ func (e *Executor) ListTaskNames(allTasks bool) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) ToEditorOutput(tasks []*taskfile.Task, noStatus bool) (*editors.Taskfile, error) {
|
func (e *Executor) ToEditorOutput(tasks []*ast.Task, noStatus bool) (*editors.Taskfile, error) {
|
||||||
o := &editors.Taskfile{
|
o := &editors.Taskfile{
|
||||||
Tasks: make([]editors.Task, len(tasks)),
|
Tasks: make([]editors.Task, len(tasks)),
|
||||||
Location: e.Taskfile.Location,
|
Location: e.Taskfile.Location,
|
||||||
|
@ -12,15 +12,15 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/internal/templater"
|
"github.com/go-task/task/v3/internal/templater"
|
||||||
"github.com/go-task/task/v3/internal/version"
|
"github.com/go-task/task/v3/internal/version"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Compiler struct {
|
type Compiler struct {
|
||||||
Dir string
|
Dir string
|
||||||
UserWorkingDir string
|
UserWorkingDir string
|
||||||
|
|
||||||
TaskfileEnv *taskfile.Vars
|
TaskfileEnv *ast.Vars
|
||||||
TaskfileVars *taskfile.Vars
|
TaskfileVars *ast.Vars
|
||||||
|
|
||||||
Logger *logger.Logger
|
Logger *logger.Logger
|
||||||
|
|
||||||
@ -28,19 +28,19 @@ type Compiler struct {
|
|||||||
muDynamicCache sync.Mutex
|
muDynamicCache sync.Mutex
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) GetTaskfileVariables() (*taskfile.Vars, error) {
|
func (c *Compiler) GetTaskfileVariables() (*ast.Vars, error) {
|
||||||
return c.getVariables(nil, nil, true)
|
return c.getVariables(nil, nil, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) GetVariables(t *taskfile.Task, call taskfile.Call) (*taskfile.Vars, error) {
|
func (c *Compiler) GetVariables(t *ast.Task, call ast.Call) (*ast.Vars, error) {
|
||||||
return c.getVariables(t, &call, true)
|
return c.getVariables(t, &call, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) FastGetVariables(t *taskfile.Task, call taskfile.Call) (*taskfile.Vars, error) {
|
func (c *Compiler) FastGetVariables(t *ast.Task, call ast.Call) (*ast.Vars, error) {
|
||||||
return c.getVariables(t, &call, false)
|
return c.getVariables(t, &call, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) getVariables(t *taskfile.Task, call *taskfile.Call, evaluateShVars bool) (*taskfile.Vars, error) {
|
func (c *Compiler) getVariables(t *ast.Task, call *ast.Call, evaluateShVars bool) (*ast.Vars, error) {
|
||||||
result := GetEnviron()
|
result := GetEnviron()
|
||||||
if t != nil {
|
if t != nil {
|
||||||
specialVars, err := c.getSpecialVars(t)
|
specialVars, err := c.getSpecialVars(t)
|
||||||
@ -48,15 +48,15 @@ func (c *Compiler) getVariables(t *taskfile.Task, call *taskfile.Call, evaluateS
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
for k, v := range specialVars {
|
for k, v := range specialVars {
|
||||||
result.Set(k, taskfile.Var{Value: v})
|
result.Set(k, ast.Var{Value: v})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getRangeFunc := func(dir string) func(k string, v taskfile.Var) error {
|
getRangeFunc := func(dir string) func(k string, v ast.Var) error {
|
||||||
return func(k string, v taskfile.Var) error {
|
return func(k string, v ast.Var) error {
|
||||||
tr := templater.Templater{Vars: result}
|
tr := templater.Templater{Vars: result}
|
||||||
// Replace values
|
// Replace values
|
||||||
newVar := taskfile.Var{}
|
newVar := ast.Var{}
|
||||||
switch value := v.Value.(type) {
|
switch value := v.Value.(type) {
|
||||||
case string:
|
case string:
|
||||||
newVar.Value = tr.Replace(value)
|
newVar.Value = tr.Replace(value)
|
||||||
@ -68,12 +68,12 @@ func (c *Compiler) getVariables(t *taskfile.Task, call *taskfile.Call, evaluateS
|
|||||||
// If the variable should not be evaluated, but is nil, set it to an empty string
|
// If the variable should not be evaluated, but is nil, set it to an empty string
|
||||||
// This stops empty interface errors when using the templater to replace values later
|
// This stops empty interface errors when using the templater to replace values later
|
||||||
if !evaluateShVars && newVar.Value == nil {
|
if !evaluateShVars && newVar.Value == nil {
|
||||||
result.Set(k, taskfile.Var{Value: ""})
|
result.Set(k, ast.Var{Value: ""})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
// If the variable should not be evaluated and it is set, we can set it and return
|
// If the variable should not be evaluated and it is set, we can set it and return
|
||||||
if !evaluateShVars {
|
if !evaluateShVars {
|
||||||
result.Set(k, taskfile.Var{Value: newVar.Value})
|
result.Set(k, ast.Var{Value: newVar.Value})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
// Now we can check for errors since we've handled all the cases when we don't want to evaluate
|
// Now we can check for errors since we've handled all the cases when we don't want to evaluate
|
||||||
@ -82,7 +82,7 @@ func (c *Compiler) getVariables(t *taskfile.Task, call *taskfile.Call, evaluateS
|
|||||||
}
|
}
|
||||||
// If the variable is not dynamic, we can set it and return
|
// If the variable is not dynamic, we can set it and return
|
||||||
if newVar.Value != nil || newVar.Sh == "" {
|
if newVar.Value != nil || newVar.Sh == "" {
|
||||||
result.Set(k, taskfile.Var{Value: newVar.Value})
|
result.Set(k, ast.Var{Value: newVar.Value})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
// If the variable is dynamic, we need to resolve it first
|
// If the variable is dynamic, we need to resolve it first
|
||||||
@ -90,13 +90,13 @@ func (c *Compiler) getVariables(t *taskfile.Task, call *taskfile.Call, evaluateS
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
result.Set(k, taskfile.Var{Value: static})
|
result.Set(k, ast.Var{Value: static})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
rangeFunc := getRangeFunc(c.Dir)
|
rangeFunc := getRangeFunc(c.Dir)
|
||||||
|
|
||||||
var taskRangeFunc func(k string, v taskfile.Var) error
|
var taskRangeFunc func(k string, v ast.Var) error
|
||||||
if t != nil {
|
if t != nil {
|
||||||
// NOTE(@andreynering): We're manually joining these paths here because
|
// NOTE(@andreynering): We're manually joining these paths here because
|
||||||
// this is the raw task, not the compiled one.
|
// this is the raw task, not the compiled one.
|
||||||
@ -138,7 +138,7 @@ func (c *Compiler) getVariables(t *taskfile.Task, call *taskfile.Call, evaluateS
|
|||||||
return result, nil
|
return result, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) HandleDynamicVar(v taskfile.Var, dir string) (string, error) {
|
func (c *Compiler) HandleDynamicVar(v ast.Var, dir string) (string, error) {
|
||||||
c.muDynamicCache.Lock()
|
c.muDynamicCache.Lock()
|
||||||
defer c.muDynamicCache.Unlock()
|
defer c.muDynamicCache.Unlock()
|
||||||
|
|
||||||
@ -184,7 +184,7 @@ func (c *Compiler) ResetCache() {
|
|||||||
c.dynamicCache = nil
|
c.dynamicCache = nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) getSpecialVars(t *taskfile.Task) (map[string]string, error) {
|
func (c *Compiler) getSpecialVars(t *ast.Task) (map[string]string, error) {
|
||||||
taskfileDir, err := c.getTaskfileDir(t)
|
taskfileDir, err := c.getTaskfileDir(t)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -199,7 +199,7 @@ func (c *Compiler) getSpecialVars(t *taskfile.Task) (map[string]string, error) {
|
|||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Compiler) getTaskfileDir(t *taskfile.Task) (string, error) {
|
func (c *Compiler) getTaskfileDir(t *ast.Task) (string, error) {
|
||||||
if t.IncludedTaskfile != nil {
|
if t.IncludedTaskfile != nil {
|
||||||
return t.IncludedTaskfile.FullDirPath()
|
return t.IncludedTaskfile.FullDirPath()
|
||||||
}
|
}
|
||||||
|
@ -4,17 +4,17 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// GetEnviron the all return all environment variables encapsulated on a
|
// GetEnviron the all return all environment variables encapsulated on a
|
||||||
// taskfile.Vars
|
// ast.Vars
|
||||||
func GetEnviron() *taskfile.Vars {
|
func GetEnviron() *ast.Vars {
|
||||||
m := &taskfile.Vars{}
|
m := &ast.Vars{}
|
||||||
for _, e := range os.Environ() {
|
for _, e := range os.Environ() {
|
||||||
keyVal := strings.SplitN(e, "=", 2)
|
keyVal := strings.SplitN(e, "=", 2)
|
||||||
key, val := keyVal[0], keyVal[1]
|
key, val := keyVal[0], keyVal[1]
|
||||||
m.Set(key, taskfile.Var{Value: val})
|
m.Set(key, ast.Var{Value: val})
|
||||||
}
|
}
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
|
4
internal/env/env.go
vendored
4
internal/env/env.go
vendored
@ -4,10 +4,10 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Get(t *taskfile.Task) []string {
|
func Get(t *ast.Task) []string {
|
||||||
if t.Env == nil {
|
if t.Env == nil {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -3,18 +3,18 @@ package fingerprint
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// StatusCheckable defines any type that can check if the status of a task is up-to-date.
|
// StatusCheckable defines any type that can check if the status of a task is up-to-date.
|
||||||
type StatusCheckable interface {
|
type StatusCheckable interface {
|
||||||
IsUpToDate(ctx context.Context, t *taskfile.Task) (bool, error)
|
IsUpToDate(ctx context.Context, t *ast.Task) (bool, error)
|
||||||
}
|
}
|
||||||
|
|
||||||
// SourcesCheckable defines any type that can check if the sources of a task are up-to-date.
|
// SourcesCheckable defines any type that can check if the sources of a task are up-to-date.
|
||||||
type SourcesCheckable interface {
|
type SourcesCheckable interface {
|
||||||
IsUpToDate(t *taskfile.Task) (bool, error)
|
IsUpToDate(t *ast.Task) (bool, error)
|
||||||
Value(t *taskfile.Task) (any, error)
|
Value(t *ast.Task) (any, error)
|
||||||
OnError(t *taskfile.Task) error
|
OnError(t *ast.Task) error
|
||||||
Kind() string
|
Kind() string
|
||||||
}
|
}
|
||||||
|
@ -8,10 +8,10 @@ import (
|
|||||||
|
|
||||||
"github.com/go-task/task/v3/internal/execext"
|
"github.com/go-task/task/v3/internal/execext"
|
||||||
"github.com/go-task/task/v3/internal/filepathext"
|
"github.com/go-task/task/v3/internal/filepathext"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Globs(dir string, globs []*taskfile.Glob) ([]string, error) {
|
func Globs(dir string, globs []*ast.Glob) ([]string, error) {
|
||||||
fileMap := make(map[string]bool)
|
fileMap := make(map[string]bool)
|
||||||
for _, g := range globs {
|
for _, g := range globs {
|
||||||
matches, err := Glob(dir, g.Glob)
|
matches, err := Glob(dir, g.Glob)
|
||||||
|
@ -11,7 +11,7 @@ import (
|
|||||||
"github.com/zeebo/xxh3"
|
"github.com/zeebo/xxh3"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/filepathext"
|
"github.com/go-task/task/v3/internal/filepathext"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ChecksumChecker validates if a task is up to date by calculating its source
|
// ChecksumChecker validates if a task is up to date by calculating its source
|
||||||
@ -28,7 +28,7 @@ func NewChecksumChecker(tempDir string, dry bool) *ChecksumChecker {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (checker *ChecksumChecker) IsUpToDate(t *taskfile.Task) (bool, error) {
|
func (checker *ChecksumChecker) IsUpToDate(t *ast.Task) (bool, error) {
|
||||||
if len(t.Sources) == 0 {
|
if len(t.Sources) == 0 {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
@ -72,11 +72,11 @@ func (checker *ChecksumChecker) IsUpToDate(t *taskfile.Task) (bool, error) {
|
|||||||
return oldHash == newHash, nil
|
return oldHash == newHash, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (checker *ChecksumChecker) Value(t *taskfile.Task) (any, error) {
|
func (checker *ChecksumChecker) Value(t *ast.Task) (any, error) {
|
||||||
return checker.checksum(t)
|
return checker.checksum(t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (checker *ChecksumChecker) OnError(t *taskfile.Task) error {
|
func (checker *ChecksumChecker) OnError(t *ast.Task) error {
|
||||||
if len(t.Sources) == 0 {
|
if len(t.Sources) == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -87,7 +87,7 @@ func (*ChecksumChecker) Kind() string {
|
|||||||
return "checksum"
|
return "checksum"
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ChecksumChecker) checksum(t *taskfile.Task) (string, error) {
|
func (c *ChecksumChecker) checksum(t *ast.Task) (string, error) {
|
||||||
sources, err := Globs(t.Dir, t.Sources)
|
sources, err := Globs(t.Dir, t.Sources)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
@ -114,7 +114,7 @@ func (c *ChecksumChecker) checksum(t *taskfile.Task) (string, error) {
|
|||||||
return fmt.Sprintf("%x%x", hash.Hi, hash.Lo), nil
|
return fmt.Sprintf("%x%x", hash.Hi, hash.Lo), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (checker *ChecksumChecker) checksumFilePath(t *taskfile.Task) string {
|
func (checker *ChecksumChecker) checksumFilePath(t *ast.Task) string {
|
||||||
return filepath.Join(checker.tempDir, "checksum", normalizeFilename(t.Name()))
|
return filepath.Join(checker.tempDir, "checksum", normalizeFilename(t.Name()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
package fingerprint
|
package fingerprint
|
||||||
|
|
||||||
import "github.com/go-task/task/v3/taskfile"
|
import "github.com/go-task/task/v3/taskfile/ast"
|
||||||
|
|
||||||
// NoneChecker is a no-op Checker.
|
// NoneChecker is a no-op Checker.
|
||||||
// It will always report that the task is not up-to-date.
|
// It will always report that the task is not up-to-date.
|
||||||
type NoneChecker struct{}
|
type NoneChecker struct{}
|
||||||
|
|
||||||
func (NoneChecker) IsUpToDate(t *taskfile.Task) (bool, error) {
|
func (NoneChecker) IsUpToDate(t *ast.Task) (bool, error) {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (NoneChecker) Value(t *taskfile.Task) (any, error) {
|
func (NoneChecker) Value(t *ast.Task) (any, error) {
|
||||||
return "", nil
|
return "", nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (NoneChecker) OnError(t *taskfile.Task) error {
|
func (NoneChecker) OnError(t *ast.Task) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@ import (
|
|||||||
"path/filepath"
|
"path/filepath"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TimestampChecker checks if any source change compared with the generated files,
|
// TimestampChecker checks if any source change compared with the generated files,
|
||||||
@ -23,7 +23,7 @@ func NewTimestampChecker(tempDir string, dry bool) *TimestampChecker {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IsUpToDate implements the Checker interface
|
// IsUpToDate implements the Checker interface
|
||||||
func (checker *TimestampChecker) IsUpToDate(t *taskfile.Task) (bool, error) {
|
func (checker *TimestampChecker) IsUpToDate(t *ast.Task) (bool, error) {
|
||||||
if len(t.Sources) == 0 {
|
if len(t.Sources) == 0 {
|
||||||
return false, nil
|
return false, nil
|
||||||
}
|
}
|
||||||
@ -89,7 +89,7 @@ func (checker *TimestampChecker) Kind() string {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Value implements the Checker Interface
|
// Value implements the Checker Interface
|
||||||
func (checker *TimestampChecker) Value(t *taskfile.Task) (any, error) {
|
func (checker *TimestampChecker) Value(t *ast.Task) (any, error) {
|
||||||
sources, err := Globs(t.Dir, t.Sources)
|
sources, err := Globs(t.Dir, t.Sources)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return time.Now(), err
|
return time.Now(), err
|
||||||
@ -142,10 +142,10 @@ func anyFileNewerThan(files []string, givenTime time.Time) (bool, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OnError implements the Checker interface
|
// OnError implements the Checker interface
|
||||||
func (*TimestampChecker) OnError(t *taskfile.Task) error {
|
func (*TimestampChecker) OnError(t *ast.Task) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (checker *TimestampChecker) timestampFilePath(t *taskfile.Task) string {
|
func (checker *TimestampChecker) timestampFilePath(t *ast.Task) string {
|
||||||
return filepath.Join(checker.tempDir, "timestamp", normalizeFilename(t.Task))
|
return filepath.Join(checker.tempDir, "timestamp", normalizeFilename(t.Task))
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/env"
|
"github.com/go-task/task/v3/internal/env"
|
||||||
"github.com/go-task/task/v3/internal/execext"
|
"github.com/go-task/task/v3/internal/execext"
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
type StatusChecker struct {
|
type StatusChecker struct {
|
||||||
@ -19,7 +19,7 @@ func NewStatusChecker(logger *logger.Logger) StatusCheckable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (checker *StatusChecker) IsUpToDate(ctx context.Context, t *taskfile.Task) (bool, error) {
|
func (checker *StatusChecker) IsUpToDate(ctx context.Context, t *ast.Task) (bool, error) {
|
||||||
for _, s := range t.Status {
|
for _, s := range t.Status {
|
||||||
err := execext.RunCommand(ctx, &execext.RunCommandOptions{
|
err := execext.RunCommand(ctx, &execext.RunCommandOptions{
|
||||||
Command: s,
|
Command: s,
|
||||||
|
@ -4,7 +4,7 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
@ -57,7 +57,7 @@ func WithSourcesChecker(checker SourcesCheckable) CheckerOption {
|
|||||||
|
|
||||||
func IsTaskUpToDate(
|
func IsTaskUpToDate(
|
||||||
ctx context.Context,
|
ctx context.Context,
|
||||||
t *taskfile.Task,
|
t *ast.Task,
|
||||||
opts ...CheckerOption,
|
opts ...CheckerOption,
|
||||||
) (bool, error) {
|
) (bool, error) {
|
||||||
var statusUpToDate bool
|
var statusUpToDate bool
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/mocks"
|
"github.com/go-task/task/v3/internal/mocks"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TruthTable
|
// TruthTable
|
||||||
@ -28,14 +28,14 @@ import (
|
|||||||
func TestIsTaskUpToDate(t *testing.T) {
|
func TestIsTaskUpToDate(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
name string
|
name string
|
||||||
task *taskfile.Task
|
task *ast.Task
|
||||||
setupMockStatusChecker func(m *mocks.StatusCheckable)
|
setupMockStatusChecker func(m *mocks.StatusCheckable)
|
||||||
setupMockSourcesChecker func(m *mocks.SourcesCheckable)
|
setupMockSourcesChecker func(m *mocks.SourcesCheckable)
|
||||||
expected bool
|
expected bool
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "expect FALSE when no status or sources are defined",
|
name: "expect FALSE when no status or sources are defined",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: nil,
|
Status: nil,
|
||||||
Sources: nil,
|
Sources: nil,
|
||||||
},
|
},
|
||||||
@ -45,9 +45,9 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect TRUE when no status is defined and sources are up-to-date",
|
name: "expect TRUE when no status is defined and sources are up-to-date",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: nil,
|
Status: nil,
|
||||||
Sources: []*taskfile.Glob{{Glob: "sources"}},
|
Sources: []*ast.Glob{{Glob: "sources"}},
|
||||||
},
|
},
|
||||||
setupMockStatusChecker: nil,
|
setupMockStatusChecker: nil,
|
||||||
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
||||||
@ -57,9 +57,9 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect FALSE when no status is defined and sources are NOT up-to-date",
|
name: "expect FALSE when no status is defined and sources are NOT up-to-date",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: nil,
|
Status: nil,
|
||||||
Sources: []*taskfile.Glob{{Glob: "sources"}},
|
Sources: []*ast.Glob{{Glob: "sources"}},
|
||||||
},
|
},
|
||||||
setupMockStatusChecker: nil,
|
setupMockStatusChecker: nil,
|
||||||
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
||||||
@ -69,7 +69,7 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect TRUE when status is up-to-date and sources are not defined",
|
name: "expect TRUE when status is up-to-date and sources are not defined",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: []string{"status"},
|
Status: []string{"status"},
|
||||||
Sources: nil,
|
Sources: nil,
|
||||||
},
|
},
|
||||||
@ -81,9 +81,9 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect TRUE when status and sources are up-to-date",
|
name: "expect TRUE when status and sources are up-to-date",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: []string{"status"},
|
Status: []string{"status"},
|
||||||
Sources: []*taskfile.Glob{{Glob: "sources"}},
|
Sources: []*ast.Glob{{Glob: "sources"}},
|
||||||
},
|
},
|
||||||
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
||||||
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
||||||
@ -95,9 +95,9 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect FALSE when status is up-to-date, but sources are NOT up-to-date",
|
name: "expect FALSE when status is up-to-date, but sources are NOT up-to-date",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: []string{"status"},
|
Status: []string{"status"},
|
||||||
Sources: []*taskfile.Glob{{Glob: "sources"}},
|
Sources: []*ast.Glob{{Glob: "sources"}},
|
||||||
},
|
},
|
||||||
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
||||||
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
||||||
@ -109,7 +109,7 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect FALSE when status is NOT up-to-date and sources are not defined",
|
name: "expect FALSE when status is NOT up-to-date and sources are not defined",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: []string{"status"},
|
Status: []string{"status"},
|
||||||
Sources: nil,
|
Sources: nil,
|
||||||
},
|
},
|
||||||
@ -121,9 +121,9 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect FALSE when status is NOT up-to-date, but sources are up-to-date",
|
name: "expect FALSE when status is NOT up-to-date, but sources are up-to-date",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: []string{"status"},
|
Status: []string{"status"},
|
||||||
Sources: []*taskfile.Glob{{Glob: "sources"}},
|
Sources: []*ast.Glob{{Glob: "sources"}},
|
||||||
},
|
},
|
||||||
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
||||||
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
||||||
@ -135,9 +135,9 @@ func TestIsTaskUpToDate(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "expect FALSE when status and sources are NOT up-to-date",
|
name: "expect FALSE when status and sources are NOT up-to-date",
|
||||||
task: &taskfile.Task{
|
task: &ast.Task{
|
||||||
Status: []string{"status"},
|
Status: []string{"status"},
|
||||||
Sources: []*taskfile.Glob{{Glob: "sources"}},
|
Sources: []*ast.Glob{{Glob: "sources"}},
|
||||||
},
|
},
|
||||||
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
||||||
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
||||||
|
@ -5,20 +5,20 @@ import (
|
|||||||
|
|
||||||
"github.com/mitchellh/hashstructure/v2"
|
"github.com/mitchellh/hashstructure/v2"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
type HashFunc func(*taskfile.Task) (string, error)
|
type HashFunc func(*ast.Task) (string, error)
|
||||||
|
|
||||||
func Empty(*taskfile.Task) (string, error) {
|
func Empty(*ast.Task) (string, error) {
|
||||||
return "", nil
|
return "", nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func Name(t *taskfile.Task) (string, error) {
|
func Name(t *ast.Task) (string, error) {
|
||||||
return t.Task, nil
|
return t.Task, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func Hash(t *taskfile.Task) (string, error) {
|
func Hash(t *ast.Task) (string, error) {
|
||||||
h, err := hashstructure.Hash(t, hashstructure.FormatV2, nil)
|
h, err := hashstructure.Hash(t, hashstructure.FormatV2, nil)
|
||||||
return fmt.Sprintf("%s:%d", t.Task, h), err
|
return fmt.Sprintf("%s:%d", t.Task, h), err
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,8 @@
|
|||||||
package mocks
|
package mocks
|
||||||
|
|
||||||
import (
|
import (
|
||||||
taskfile "github.com/go-task/task/v3/taskfile"
|
ast "github.com/go-task/task/v3/taskfile/ast"
|
||||||
|
|
||||||
mock "github.com/stretchr/testify/mock"
|
mock "github.com/stretchr/testify/mock"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -21,21 +22,21 @@ func (_m *SourcesCheckable) EXPECT() *SourcesCheckable_Expecter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IsUpToDate provides a mock function with given fields: t
|
// IsUpToDate provides a mock function with given fields: t
|
||||||
func (_m *SourcesCheckable) IsUpToDate(t *taskfile.Task) (bool, error) {
|
func (_m *SourcesCheckable) IsUpToDate(t *ast.Task) (bool, error) {
|
||||||
ret := _m.Called(t)
|
ret := _m.Called(t)
|
||||||
|
|
||||||
var r0 bool
|
var r0 bool
|
||||||
var r1 error
|
var r1 error
|
||||||
if rf, ok := ret.Get(0).(func(*taskfile.Task) (bool, error)); ok {
|
if rf, ok := ret.Get(0).(func(*ast.Task) (bool, error)); ok {
|
||||||
return rf(t)
|
return rf(t)
|
||||||
}
|
}
|
||||||
if rf, ok := ret.Get(0).(func(*taskfile.Task) bool); ok {
|
if rf, ok := ret.Get(0).(func(*ast.Task) bool); ok {
|
||||||
r0 = rf(t)
|
r0 = rf(t)
|
||||||
} else {
|
} else {
|
||||||
r0 = ret.Get(0).(bool)
|
r0 = ret.Get(0).(bool)
|
||||||
}
|
}
|
||||||
|
|
||||||
if rf, ok := ret.Get(1).(func(*taskfile.Task) error); ok {
|
if rf, ok := ret.Get(1).(func(*ast.Task) error); ok {
|
||||||
r1 = rf(t)
|
r1 = rf(t)
|
||||||
} else {
|
} else {
|
||||||
r1 = ret.Error(1)
|
r1 = ret.Error(1)
|
||||||
@ -50,14 +51,14 @@ type SourcesCheckable_IsUpToDate_Call struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IsUpToDate is a helper method to define mock.On call
|
// IsUpToDate is a helper method to define mock.On call
|
||||||
// - t *taskfile.Task
|
// - t *ast.Task
|
||||||
func (_e *SourcesCheckable_Expecter) IsUpToDate(t interface{}) *SourcesCheckable_IsUpToDate_Call {
|
func (_e *SourcesCheckable_Expecter) IsUpToDate(t interface{}) *SourcesCheckable_IsUpToDate_Call {
|
||||||
return &SourcesCheckable_IsUpToDate_Call{Call: _e.mock.On("IsUpToDate", t)}
|
return &SourcesCheckable_IsUpToDate_Call{Call: _e.mock.On("IsUpToDate", t)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *SourcesCheckable_IsUpToDate_Call) Run(run func(t *taskfile.Task)) *SourcesCheckable_IsUpToDate_Call {
|
func (_c *SourcesCheckable_IsUpToDate_Call) Run(run func(t *ast.Task)) *SourcesCheckable_IsUpToDate_Call {
|
||||||
_c.Call.Run(func(args mock.Arguments) {
|
_c.Call.Run(func(args mock.Arguments) {
|
||||||
run(args[0].(*taskfile.Task))
|
run(args[0].(*ast.Task))
|
||||||
})
|
})
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
@ -67,7 +68,7 @@ func (_c *SourcesCheckable_IsUpToDate_Call) Return(_a0 bool, _a1 error) *Sources
|
|||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *SourcesCheckable_IsUpToDate_Call) RunAndReturn(run func(*taskfile.Task) (bool, error)) *SourcesCheckable_IsUpToDate_Call {
|
func (_c *SourcesCheckable_IsUpToDate_Call) RunAndReturn(run func(*ast.Task) (bool, error)) *SourcesCheckable_IsUpToDate_Call {
|
||||||
_c.Call.Return(run)
|
_c.Call.Return(run)
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
@ -114,11 +115,11 @@ func (_c *SourcesCheckable_Kind_Call) RunAndReturn(run func() string) *SourcesCh
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OnError provides a mock function with given fields: t
|
// OnError provides a mock function with given fields: t
|
||||||
func (_m *SourcesCheckable) OnError(t *taskfile.Task) error {
|
func (_m *SourcesCheckable) OnError(t *ast.Task) error {
|
||||||
ret := _m.Called(t)
|
ret := _m.Called(t)
|
||||||
|
|
||||||
var r0 error
|
var r0 error
|
||||||
if rf, ok := ret.Get(0).(func(*taskfile.Task) error); ok {
|
if rf, ok := ret.Get(0).(func(*ast.Task) error); ok {
|
||||||
r0 = rf(t)
|
r0 = rf(t)
|
||||||
} else {
|
} else {
|
||||||
r0 = ret.Error(0)
|
r0 = ret.Error(0)
|
||||||
@ -133,14 +134,14 @@ type SourcesCheckable_OnError_Call struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// OnError is a helper method to define mock.On call
|
// OnError is a helper method to define mock.On call
|
||||||
// - t *taskfile.Task
|
// - t *ast.Task
|
||||||
func (_e *SourcesCheckable_Expecter) OnError(t interface{}) *SourcesCheckable_OnError_Call {
|
func (_e *SourcesCheckable_Expecter) OnError(t interface{}) *SourcesCheckable_OnError_Call {
|
||||||
return &SourcesCheckable_OnError_Call{Call: _e.mock.On("OnError", t)}
|
return &SourcesCheckable_OnError_Call{Call: _e.mock.On("OnError", t)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *SourcesCheckable_OnError_Call) Run(run func(t *taskfile.Task)) *SourcesCheckable_OnError_Call {
|
func (_c *SourcesCheckable_OnError_Call) Run(run func(t *ast.Task)) *SourcesCheckable_OnError_Call {
|
||||||
_c.Call.Run(func(args mock.Arguments) {
|
_c.Call.Run(func(args mock.Arguments) {
|
||||||
run(args[0].(*taskfile.Task))
|
run(args[0].(*ast.Task))
|
||||||
})
|
})
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
@ -150,21 +151,21 @@ func (_c *SourcesCheckable_OnError_Call) Return(_a0 error) *SourcesCheckable_OnE
|
|||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *SourcesCheckable_OnError_Call) RunAndReturn(run func(*taskfile.Task) error) *SourcesCheckable_OnError_Call {
|
func (_c *SourcesCheckable_OnError_Call) RunAndReturn(run func(*ast.Task) error) *SourcesCheckable_OnError_Call {
|
||||||
_c.Call.Return(run)
|
_c.Call.Return(run)
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
|
||||||
// Value provides a mock function with given fields: t
|
// Value provides a mock function with given fields: t
|
||||||
func (_m *SourcesCheckable) Value(t *taskfile.Task) (interface{}, error) {
|
func (_m *SourcesCheckable) Value(t *ast.Task) (interface{}, error) {
|
||||||
ret := _m.Called(t)
|
ret := _m.Called(t)
|
||||||
|
|
||||||
var r0 interface{}
|
var r0 interface{}
|
||||||
var r1 error
|
var r1 error
|
||||||
if rf, ok := ret.Get(0).(func(*taskfile.Task) (interface{}, error)); ok {
|
if rf, ok := ret.Get(0).(func(*ast.Task) (interface{}, error)); ok {
|
||||||
return rf(t)
|
return rf(t)
|
||||||
}
|
}
|
||||||
if rf, ok := ret.Get(0).(func(*taskfile.Task) interface{}); ok {
|
if rf, ok := ret.Get(0).(func(*ast.Task) interface{}); ok {
|
||||||
r0 = rf(t)
|
r0 = rf(t)
|
||||||
} else {
|
} else {
|
||||||
if ret.Get(0) != nil {
|
if ret.Get(0) != nil {
|
||||||
@ -172,7 +173,7 @@ func (_m *SourcesCheckable) Value(t *taskfile.Task) (interface{}, error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if rf, ok := ret.Get(1).(func(*taskfile.Task) error); ok {
|
if rf, ok := ret.Get(1).(func(*ast.Task) error); ok {
|
||||||
r1 = rf(t)
|
r1 = rf(t)
|
||||||
} else {
|
} else {
|
||||||
r1 = ret.Error(1)
|
r1 = ret.Error(1)
|
||||||
@ -187,14 +188,14 @@ type SourcesCheckable_Value_Call struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Value is a helper method to define mock.On call
|
// Value is a helper method to define mock.On call
|
||||||
// - t *taskfile.Task
|
// - t *ast.Task
|
||||||
func (_e *SourcesCheckable_Expecter) Value(t interface{}) *SourcesCheckable_Value_Call {
|
func (_e *SourcesCheckable_Expecter) Value(t interface{}) *SourcesCheckable_Value_Call {
|
||||||
return &SourcesCheckable_Value_Call{Call: _e.mock.On("Value", t)}
|
return &SourcesCheckable_Value_Call{Call: _e.mock.On("Value", t)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *SourcesCheckable_Value_Call) Run(run func(t *taskfile.Task)) *SourcesCheckable_Value_Call {
|
func (_c *SourcesCheckable_Value_Call) Run(run func(t *ast.Task)) *SourcesCheckable_Value_Call {
|
||||||
_c.Call.Run(func(args mock.Arguments) {
|
_c.Call.Run(func(args mock.Arguments) {
|
||||||
run(args[0].(*taskfile.Task))
|
run(args[0].(*ast.Task))
|
||||||
})
|
})
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
@ -204,7 +205,7 @@ func (_c *SourcesCheckable_Value_Call) Return(_a0 interface{}, _a1 error) *Sourc
|
|||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *SourcesCheckable_Value_Call) RunAndReturn(run func(*taskfile.Task) (interface{}, error)) *SourcesCheckable_Value_Call {
|
func (_c *SourcesCheckable_Value_Call) RunAndReturn(run func(*ast.Task) (interface{}, error)) *SourcesCheckable_Value_Call {
|
||||||
_c.Call.Return(run)
|
_c.Call.Return(run)
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
@ -5,9 +5,9 @@ package mocks
|
|||||||
import (
|
import (
|
||||||
context "context"
|
context "context"
|
||||||
|
|
||||||
mock "github.com/stretchr/testify/mock"
|
ast "github.com/go-task/task/v3/taskfile/ast"
|
||||||
|
|
||||||
taskfile "github.com/go-task/task/v3/taskfile"
|
mock "github.com/stretchr/testify/mock"
|
||||||
)
|
)
|
||||||
|
|
||||||
// StatusCheckable is an autogenerated mock type for the StatusCheckable type
|
// StatusCheckable is an autogenerated mock type for the StatusCheckable type
|
||||||
@ -24,21 +24,21 @@ func (_m *StatusCheckable) EXPECT() *StatusCheckable_Expecter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// IsUpToDate provides a mock function with given fields: ctx, t
|
// IsUpToDate provides a mock function with given fields: ctx, t
|
||||||
func (_m *StatusCheckable) IsUpToDate(ctx context.Context, t *taskfile.Task) (bool, error) {
|
func (_m *StatusCheckable) IsUpToDate(ctx context.Context, t *ast.Task) (bool, error) {
|
||||||
ret := _m.Called(ctx, t)
|
ret := _m.Called(ctx, t)
|
||||||
|
|
||||||
var r0 bool
|
var r0 bool
|
||||||
var r1 error
|
var r1 error
|
||||||
if rf, ok := ret.Get(0).(func(context.Context, *taskfile.Task) (bool, error)); ok {
|
if rf, ok := ret.Get(0).(func(context.Context, *ast.Task) (bool, error)); ok {
|
||||||
return rf(ctx, t)
|
return rf(ctx, t)
|
||||||
}
|
}
|
||||||
if rf, ok := ret.Get(0).(func(context.Context, *taskfile.Task) bool); ok {
|
if rf, ok := ret.Get(0).(func(context.Context, *ast.Task) bool); ok {
|
||||||
r0 = rf(ctx, t)
|
r0 = rf(ctx, t)
|
||||||
} else {
|
} else {
|
||||||
r0 = ret.Get(0).(bool)
|
r0 = ret.Get(0).(bool)
|
||||||
}
|
}
|
||||||
|
|
||||||
if rf, ok := ret.Get(1).(func(context.Context, *taskfile.Task) error); ok {
|
if rf, ok := ret.Get(1).(func(context.Context, *ast.Task) error); ok {
|
||||||
r1 = rf(ctx, t)
|
r1 = rf(ctx, t)
|
||||||
} else {
|
} else {
|
||||||
r1 = ret.Error(1)
|
r1 = ret.Error(1)
|
||||||
@ -54,14 +54,14 @@ type StatusCheckable_IsUpToDate_Call struct {
|
|||||||
|
|
||||||
// IsUpToDate is a helper method to define mock.On call
|
// IsUpToDate is a helper method to define mock.On call
|
||||||
// - ctx context.Context
|
// - ctx context.Context
|
||||||
// - t *taskfile.Task
|
// - t *ast.Task
|
||||||
func (_e *StatusCheckable_Expecter) IsUpToDate(ctx interface{}, t interface{}) *StatusCheckable_IsUpToDate_Call {
|
func (_e *StatusCheckable_Expecter) IsUpToDate(ctx interface{}, t interface{}) *StatusCheckable_IsUpToDate_Call {
|
||||||
return &StatusCheckable_IsUpToDate_Call{Call: _e.mock.On("IsUpToDate", ctx, t)}
|
return &StatusCheckable_IsUpToDate_Call{Call: _e.mock.On("IsUpToDate", ctx, t)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *StatusCheckable_IsUpToDate_Call) Run(run func(ctx context.Context, t *taskfile.Task)) *StatusCheckable_IsUpToDate_Call {
|
func (_c *StatusCheckable_IsUpToDate_Call) Run(run func(ctx context.Context, t *ast.Task)) *StatusCheckable_IsUpToDate_Call {
|
||||||
_c.Call.Run(func(args mock.Arguments) {
|
_c.Call.Run(func(args mock.Arguments) {
|
||||||
run(args[0].(context.Context), args[1].(*taskfile.Task))
|
run(args[0].(context.Context), args[1].(*ast.Task))
|
||||||
})
|
})
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
@ -71,7 +71,7 @@ func (_c *StatusCheckable_IsUpToDate_Call) Return(_a0 bool, _a1 error) *StatusCh
|
|||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
|
||||||
func (_c *StatusCheckable_IsUpToDate_Call) RunAndReturn(run func(context.Context, *taskfile.Task) (bool, error)) *StatusCheckable_IsUpToDate_Call {
|
func (_c *StatusCheckable_IsUpToDate_Call) RunAndReturn(run func(context.Context, *ast.Task) (bool, error)) *StatusCheckable_IsUpToDate_Call {
|
||||||
_c.Call.Return(run)
|
_c.Call.Return(run)
|
||||||
return _c
|
return _c
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Templater executes a template engine.
|
// Templater executes a template engine.
|
||||||
@ -20,8 +20,8 @@ type Output interface {
|
|||||||
|
|
||||||
type CloseFunc func(err error) error
|
type CloseFunc func(err error) error
|
||||||
|
|
||||||
// Build the Output for the requested taskfile.Output.
|
// Build the Output for the requested ast.Output.
|
||||||
func BuildFor(o *taskfile.Output) (Output, error) {
|
func BuildFor(o *ast.Output) (Output, error) {
|
||||||
switch o.Name {
|
switch o.Name {
|
||||||
case "interleaved", "":
|
case "interleaved", "":
|
||||||
if err := checkOutputGroupUnset(o); err != nil {
|
if err := checkOutputGroupUnset(o); err != nil {
|
||||||
@ -44,7 +44,7 @@ func BuildFor(o *taskfile.Output) (Output, error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkOutputGroupUnset(o *taskfile.Output) error {
|
func checkOutputGroupUnset(o *ast.Output) error {
|
||||||
if o.Group.IsSet() {
|
if o.Group.IsSet() {
|
||||||
return fmt.Errorf("task: output style %q does not support the group begin/end parameter", o.Name)
|
return fmt.Errorf("task: output style %q does not support the group begin/end parameter", o.Name)
|
||||||
}
|
}
|
||||||
|
@ -13,7 +13,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/orderedmap"
|
"github.com/go-task/task/v3/internal/orderedmap"
|
||||||
"github.com/go-task/task/v3/internal/output"
|
"github.com/go-task/task/v3/internal/output"
|
||||||
"github.com/go-task/task/v3/internal/templater"
|
"github.com/go-task/task/v3/internal/templater"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestInterleaved(t *testing.T) {
|
func TestInterleaved(t *testing.T) {
|
||||||
@ -47,8 +47,8 @@ func TestGroup(t *testing.T) {
|
|||||||
|
|
||||||
func TestGroupWithBeginEnd(t *testing.T) {
|
func TestGroupWithBeginEnd(t *testing.T) {
|
||||||
tmpl := templater.Templater{
|
tmpl := templater.Templater{
|
||||||
Vars: &taskfile.Vars{
|
Vars: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMap(map[string]taskfile.Var{
|
OrderedMap: orderedmap.FromMap(map[string]ast.Var{
|
||||||
"VAR1": {Value: "example-value"},
|
"VAR1": {Value: "example-value"},
|
||||||
}),
|
}),
|
||||||
},
|
},
|
||||||
|
@ -4,22 +4,22 @@ import (
|
|||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
type TaskSorter interface {
|
type TaskSorter interface {
|
||||||
Sort([]*taskfile.Task)
|
Sort([]*ast.Task)
|
||||||
}
|
}
|
||||||
|
|
||||||
type Noop struct{}
|
type Noop struct{}
|
||||||
|
|
||||||
func (s *Noop) Sort(tasks []*taskfile.Task) {}
|
func (s *Noop) Sort(tasks []*ast.Task) {}
|
||||||
|
|
||||||
type AlphaNumeric struct{}
|
type AlphaNumeric struct{}
|
||||||
|
|
||||||
// Tasks that are not namespaced should be listed before tasks that are.
|
// Tasks that are not namespaced should be listed before tasks that are.
|
||||||
// We detect this by searching for a ':' in the task name.
|
// We detect this by searching for a ':' in the task name.
|
||||||
func (s *AlphaNumeric) Sort(tasks []*taskfile.Task) {
|
func (s *AlphaNumeric) Sort(tasks []*ast.Task) {
|
||||||
sort.Slice(tasks, func(i, j int) bool {
|
sort.Slice(tasks, func(i, j int) bool {
|
||||||
return tasks[i].Task < tasks[j].Task
|
return tasks[i].Task < tasks[j].Task
|
||||||
})
|
})
|
||||||
@ -29,7 +29,7 @@ type AlphaNumericWithRootTasksFirst struct{}
|
|||||||
|
|
||||||
// Tasks that are not namespaced should be listed before tasks that are.
|
// Tasks that are not namespaced should be listed before tasks that are.
|
||||||
// We detect this by searching for a ':' in the task name.
|
// We detect this by searching for a ':' in the task name.
|
||||||
func (s *AlphaNumericWithRootTasksFirst) Sort(tasks []*taskfile.Task) {
|
func (s *AlphaNumericWithRootTasksFirst) Sort(tasks []*ast.Task) {
|
||||||
sort.Slice(tasks, func(i, j int) bool {
|
sort.Slice(tasks, func(i, j int) bool {
|
||||||
iContainsColon := strings.Contains(tasks[i].Task, ":")
|
iContainsColon := strings.Contains(tasks[i].Task, ":")
|
||||||
jContainsColon := strings.Contains(tasks[j].Task, ":")
|
jContainsColon := strings.Contains(tasks[j].Task, ":")
|
||||||
|
@ -5,36 +5,36 @@ import (
|
|||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestAlphaNumericWithRootTasksFirst_Sort(t *testing.T) {
|
func TestAlphaNumericWithRootTasksFirst_Sort(t *testing.T) {
|
||||||
task1 := &taskfile.Task{Task: "task1"}
|
task1 := &ast.Task{Task: "task1"}
|
||||||
task2 := &taskfile.Task{Task: "task2"}
|
task2 := &ast.Task{Task: "task2"}
|
||||||
task3 := &taskfile.Task{Task: "ns1:task3"}
|
task3 := &ast.Task{Task: "ns1:task3"}
|
||||||
task4 := &taskfile.Task{Task: "ns2:task4"}
|
task4 := &ast.Task{Task: "ns2:task4"}
|
||||||
task5 := &taskfile.Task{Task: "task5"}
|
task5 := &ast.Task{Task: "task5"}
|
||||||
task6 := &taskfile.Task{Task: "ns3:task6"}
|
task6 := &ast.Task{Task: "ns3:task6"}
|
||||||
|
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
name string
|
name string
|
||||||
tasks []*taskfile.Task
|
tasks []*ast.Task
|
||||||
want []*taskfile.Task
|
want []*ast.Task
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "no namespace tasks sorted alphabetically first",
|
name: "no namespace tasks sorted alphabetically first",
|
||||||
tasks: []*taskfile.Task{task3, task2, task1},
|
tasks: []*ast.Task{task3, task2, task1},
|
||||||
want: []*taskfile.Task{task1, task2, task3},
|
want: []*ast.Task{task1, task2, task3},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "namespace tasks sorted alphabetically after non-namespaced tasks",
|
name: "namespace tasks sorted alphabetically after non-namespaced tasks",
|
||||||
tasks: []*taskfile.Task{task3, task4, task5},
|
tasks: []*ast.Task{task3, task4, task5},
|
||||||
want: []*taskfile.Task{task5, task3, task4},
|
want: []*ast.Task{task5, task3, task4},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: "all tasks sorted alphabetically with root tasks first",
|
name: "all tasks sorted alphabetically with root tasks first",
|
||||||
tasks: []*taskfile.Task{task6, task5, task4, task3, task2, task1},
|
tasks: []*ast.Task{task6, task5, task4, task3, task2, task1},
|
||||||
want: []*taskfile.Task{task1, task2, task5, task3, task4, task6},
|
want: []*ast.Task{task1, task2, task5, task3, task4, task6},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -48,22 +48,22 @@ func TestAlphaNumericWithRootTasksFirst_Sort(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestAlphaNumeric_Sort(t *testing.T) {
|
func TestAlphaNumeric_Sort(t *testing.T) {
|
||||||
task1 := &taskfile.Task{Task: "task1"}
|
task1 := &ast.Task{Task: "task1"}
|
||||||
task2 := &taskfile.Task{Task: "task2"}
|
task2 := &ast.Task{Task: "task2"}
|
||||||
task3 := &taskfile.Task{Task: "ns1:task3"}
|
task3 := &ast.Task{Task: "ns1:task3"}
|
||||||
task4 := &taskfile.Task{Task: "ns2:task4"}
|
task4 := &ast.Task{Task: "ns2:task4"}
|
||||||
task5 := &taskfile.Task{Task: "task5"}
|
task5 := &ast.Task{Task: "task5"}
|
||||||
task6 := &taskfile.Task{Task: "ns3:task6"}
|
task6 := &ast.Task{Task: "ns3:task6"}
|
||||||
|
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
name string
|
name string
|
||||||
tasks []*taskfile.Task
|
tasks []*ast.Task
|
||||||
want []*taskfile.Task
|
want []*ast.Task
|
||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
name: "all tasks sorted alphabetically",
|
name: "all tasks sorted alphabetically",
|
||||||
tasks: []*taskfile.Task{task3, task2, task5, task1, task4, task6},
|
tasks: []*ast.Task{task3, task2, task5, task1, task4, task6},
|
||||||
want: []*taskfile.Task{task3, task4, task6, task1, task2, task5},
|
want: []*ast.Task{task3, task4, task6, task1, task2, task5},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4,10 +4,10 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func PrintTasks(l *logger.Logger, t *taskfile.Taskfile, c []taskfile.Call) {
|
func PrintTasks(l *logger.Logger, t *ast.Taskfile, c []ast.Call) {
|
||||||
for i, call := range c {
|
for i, call := range c {
|
||||||
PrintSpaceBetweenSummaries(l, i)
|
PrintSpaceBetweenSummaries(l, i)
|
||||||
PrintTask(l, t.Tasks.Get(call.Task))
|
PrintTask(l, t.Tasks.Get(call.Task))
|
||||||
@ -24,7 +24,7 @@ func PrintSpaceBetweenSummaries(l *logger.Logger, i int) {
|
|||||||
l.Outf(logger.Default, "\n")
|
l.Outf(logger.Default, "\n")
|
||||||
}
|
}
|
||||||
|
|
||||||
func PrintTask(l *logger.Logger, t *taskfile.Task) {
|
func PrintTask(l *logger.Logger, t *ast.Task) {
|
||||||
printTaskName(l, t)
|
printTaskName(l, t)
|
||||||
printTaskDescribingText(t, l)
|
printTaskDescribingText(t, l)
|
||||||
printTaskDependencies(l, t)
|
printTaskDependencies(l, t)
|
||||||
@ -32,7 +32,7 @@ func PrintTask(l *logger.Logger, t *taskfile.Task) {
|
|||||||
printTaskCommands(l, t)
|
printTaskCommands(l, t)
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskDescribingText(t *taskfile.Task, l *logger.Logger) {
|
func printTaskDescribingText(t *ast.Task, l *logger.Logger) {
|
||||||
if hasSummary(t) {
|
if hasSummary(t) {
|
||||||
printTaskSummary(l, t)
|
printTaskSummary(l, t)
|
||||||
} else if hasDescription(t) {
|
} else if hasDescription(t) {
|
||||||
@ -42,11 +42,11 @@ func printTaskDescribingText(t *taskfile.Task, l *logger.Logger) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func hasSummary(t *taskfile.Task) bool {
|
func hasSummary(t *ast.Task) bool {
|
||||||
return t.Summary != ""
|
return t.Summary != ""
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskSummary(l *logger.Logger, t *taskfile.Task) {
|
func printTaskSummary(l *logger.Logger, t *ast.Task) {
|
||||||
lines := strings.Split(t.Summary, "\n")
|
lines := strings.Split(t.Summary, "\n")
|
||||||
for i, line := range lines {
|
for i, line := range lines {
|
||||||
notLastLine := i+1 < len(lines)
|
notLastLine := i+1 < len(lines)
|
||||||
@ -56,13 +56,13 @@ func printTaskSummary(l *logger.Logger, t *taskfile.Task) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskName(l *logger.Logger, t *taskfile.Task) {
|
func printTaskName(l *logger.Logger, t *ast.Task) {
|
||||||
l.Outf(logger.Default, "task: ")
|
l.Outf(logger.Default, "task: ")
|
||||||
l.Outf(logger.Green, "%s\n", t.Name())
|
l.Outf(logger.Green, "%s\n", t.Name())
|
||||||
l.Outf(logger.Default, "\n")
|
l.Outf(logger.Default, "\n")
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskAliases(l *logger.Logger, t *taskfile.Task) {
|
func printTaskAliases(l *logger.Logger, t *ast.Task) {
|
||||||
if len(t.Aliases) == 0 {
|
if len(t.Aliases) == 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -74,11 +74,11 @@ func printTaskAliases(l *logger.Logger, t *taskfile.Task) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func hasDescription(t *taskfile.Task) bool {
|
func hasDescription(t *ast.Task) bool {
|
||||||
return t.Desc != ""
|
return t.Desc != ""
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskDescription(l *logger.Logger, t *taskfile.Task) {
|
func printTaskDescription(l *logger.Logger, t *ast.Task) {
|
||||||
l.Outf(logger.Default, "%s\n", t.Desc)
|
l.Outf(logger.Default, "%s\n", t.Desc)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -86,7 +86,7 @@ func printNoDescriptionOrSummary(l *logger.Logger) {
|
|||||||
l.Outf(logger.Default, "(task does not have description or summary)\n")
|
l.Outf(logger.Default, "(task does not have description or summary)\n")
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskDependencies(l *logger.Logger, t *taskfile.Task) {
|
func printTaskDependencies(l *logger.Logger, t *ast.Task) {
|
||||||
if len(t.Deps) == 0 {
|
if len(t.Deps) == 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
@ -99,7 +99,7 @@ func printTaskDependencies(l *logger.Logger, t *taskfile.Task) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func printTaskCommands(l *logger.Logger, t *taskfile.Task) {
|
func printTaskCommands(l *logger.Logger, t *ast.Task) {
|
||||||
if len(t.Cmds) == 0 {
|
if len(t.Cmds) == 0 {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -9,13 +9,13 @@ import (
|
|||||||
|
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/internal/summary"
|
"github.com/go-task/task/v3/internal/summary"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestPrintsDependenciesIfPresent(t *testing.T) {
|
func TestPrintsDependenciesIfPresent(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
task := &taskfile.Task{
|
task := &ast.Task{
|
||||||
Deps: []*taskfile.Dep{
|
Deps: []*ast.Dep{
|
||||||
{Task: "dep1"},
|
{Task: "dep1"},
|
||||||
{Task: "dep2"},
|
{Task: "dep2"},
|
||||||
{Task: "dep3"},
|
{Task: "dep3"},
|
||||||
@ -39,8 +39,8 @@ func createDummyLogger() (*bytes.Buffer, logger.Logger) {
|
|||||||
|
|
||||||
func TestDoesNotPrintDependenciesIfMissing(t *testing.T) {
|
func TestDoesNotPrintDependenciesIfMissing(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
task := &taskfile.Task{
|
task := &ast.Task{
|
||||||
Deps: []*taskfile.Dep{},
|
Deps: []*ast.Dep{},
|
||||||
}
|
}
|
||||||
|
|
||||||
summary.PrintTask(&l, task)
|
summary.PrintTask(&l, task)
|
||||||
@ -50,7 +50,7 @@ func TestDoesNotPrintDependenciesIfMissing(t *testing.T) {
|
|||||||
|
|
||||||
func TestPrintTaskName(t *testing.T) {
|
func TestPrintTaskName(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
task := &taskfile.Task{
|
task := &ast.Task{
|
||||||
Task: "my-task-name",
|
Task: "my-task-name",
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,8 +61,8 @@ func TestPrintTaskName(t *testing.T) {
|
|||||||
|
|
||||||
func TestPrintTaskCommandsIfPresent(t *testing.T) {
|
func TestPrintTaskCommandsIfPresent(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
task := &taskfile.Task{
|
task := &ast.Task{
|
||||||
Cmds: []*taskfile.Cmd{
|
Cmds: []*ast.Cmd{
|
||||||
{Cmd: "command-1"},
|
{Cmd: "command-1"},
|
||||||
{Cmd: "command-2"},
|
{Cmd: "command-2"},
|
||||||
{Task: "task-1"},
|
{Task: "task-1"},
|
||||||
@ -79,8 +79,8 @@ func TestPrintTaskCommandsIfPresent(t *testing.T) {
|
|||||||
|
|
||||||
func TestDoesNotPrintCommandIfMissing(t *testing.T) {
|
func TestDoesNotPrintCommandIfMissing(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
task := &taskfile.Task{
|
task := &ast.Task{
|
||||||
Cmds: []*taskfile.Cmd{},
|
Cmds: []*ast.Cmd{},
|
||||||
}
|
}
|
||||||
|
|
||||||
summary.PrintTask(&l, task)
|
summary.PrintTask(&l, task)
|
||||||
@ -90,13 +90,13 @@ func TestDoesNotPrintCommandIfMissing(t *testing.T) {
|
|||||||
|
|
||||||
func TestLayout(t *testing.T) {
|
func TestLayout(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
task := &taskfile.Task{
|
task := &ast.Task{
|
||||||
Task: "sample-task",
|
Task: "sample-task",
|
||||||
Summary: "line1\nline2\nline3\n",
|
Summary: "line1\nline2\nline3\n",
|
||||||
Deps: []*taskfile.Dep{
|
Deps: []*ast.Dep{
|
||||||
{Task: "dependency"},
|
{Task: "dependency"},
|
||||||
},
|
},
|
||||||
Cmds: []*taskfile.Cmd{
|
Cmds: []*ast.Cmd{
|
||||||
{Cmd: "command"},
|
{Cmd: "command"},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
@ -124,15 +124,15 @@ commands:
|
|||||||
|
|
||||||
func TestPrintDescriptionAsFallback(t *testing.T) {
|
func TestPrintDescriptionAsFallback(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
taskWithoutSummary := &taskfile.Task{
|
taskWithoutSummary := &ast.Task{
|
||||||
Desc: "description",
|
Desc: "description",
|
||||||
}
|
}
|
||||||
|
|
||||||
taskWithSummary := &taskfile.Task{
|
taskWithSummary := &ast.Task{
|
||||||
Desc: "description",
|
Desc: "description",
|
||||||
Summary: "summary",
|
Summary: "summary",
|
||||||
}
|
}
|
||||||
taskWithoutSummaryOrDescription := &taskfile.Task{}
|
taskWithoutSummaryOrDescription := &ast.Task{}
|
||||||
|
|
||||||
summary.PrintTask(&l, taskWithoutSummary)
|
summary.PrintTask(&l, taskWithoutSummary)
|
||||||
|
|
||||||
@ -152,18 +152,18 @@ func TestPrintDescriptionAsFallback(t *testing.T) {
|
|||||||
func TestPrintAllWithSpaces(t *testing.T) {
|
func TestPrintAllWithSpaces(t *testing.T) {
|
||||||
buffer, l := createDummyLogger()
|
buffer, l := createDummyLogger()
|
||||||
|
|
||||||
t1 := &taskfile.Task{Task: "t1"}
|
t1 := &ast.Task{Task: "t1"}
|
||||||
t2 := &taskfile.Task{Task: "t2"}
|
t2 := &ast.Task{Task: "t2"}
|
||||||
t3 := &taskfile.Task{Task: "t3"}
|
t3 := &ast.Task{Task: "t3"}
|
||||||
|
|
||||||
tasks := taskfile.Tasks{}
|
tasks := ast.Tasks{}
|
||||||
tasks.Set("t1", t1)
|
tasks.Set("t1", t1)
|
||||||
tasks.Set("t2", t2)
|
tasks.Set("t2", t2)
|
||||||
tasks.Set("t3", t3)
|
tasks.Set("t3", t3)
|
||||||
|
|
||||||
summary.PrintTasks(&l,
|
summary.PrintTasks(&l,
|
||||||
&taskfile.Taskfile{Tasks: tasks},
|
&ast.Taskfile{Tasks: tasks},
|
||||||
[]taskfile.Call{{Task: "t1"}, {Task: "t2"}, {Task: "t3"}})
|
[]ast.Call{{Task: "t1"}, {Task: "t2"}, {Task: "t3"}})
|
||||||
|
|
||||||
assert.True(t, strings.HasPrefix(buffer.String(), "task: t1"))
|
assert.True(t, strings.HasPrefix(buffer.String(), "task: t1"))
|
||||||
assert.Contains(t, buffer.String(), "\n(task does not have description or summary)\n\n\ntask: t2")
|
assert.Contains(t, buffer.String(), "\n(task does not have description or summary)\n\n\ntask: t2")
|
||||||
|
@ -7,7 +7,7 @@ import (
|
|||||||
|
|
||||||
"golang.org/x/exp/maps"
|
"golang.org/x/exp/maps"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Templater is a help struct that allow us to call "replaceX" funcs multiple
|
// Templater is a help struct that allow us to call "replaceX" funcs multiple
|
||||||
@ -15,7 +15,7 @@ import (
|
|||||||
// happen will be assigned to r.err, and consecutive calls to funcs will just
|
// happen will be assigned to r.err, and consecutive calls to funcs will just
|
||||||
// return the zero value.
|
// return the zero value.
|
||||||
type Templater struct {
|
type Templater struct {
|
||||||
Vars *taskfile.Vars
|
Vars *ast.Vars
|
||||||
|
|
||||||
cacheMap map[string]any
|
cacheMap map[string]any
|
||||||
err error
|
err error
|
||||||
@ -76,14 +76,14 @@ func (r *Templater) ReplaceSlice(strs []string) []string {
|
|||||||
return new
|
return new
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Templater) ReplaceGlobs(globs []*taskfile.Glob) []*taskfile.Glob {
|
func (r *Templater) ReplaceGlobs(globs []*ast.Glob) []*ast.Glob {
|
||||||
if r.err != nil || len(globs) == 0 {
|
if r.err != nil || len(globs) == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
new := make([]*taskfile.Glob, len(globs))
|
new := make([]*ast.Glob, len(globs))
|
||||||
for i, g := range globs {
|
for i, g := range globs {
|
||||||
new[i] = &taskfile.Glob{
|
new[i] = &ast.Glob{
|
||||||
Glob: r.Replace(g.Glob),
|
Glob: r.Replace(g.Glob),
|
||||||
Negate: g.Negate,
|
Negate: g.Negate,
|
||||||
}
|
}
|
||||||
@ -91,22 +91,22 @@ func (r *Templater) ReplaceGlobs(globs []*taskfile.Glob) []*taskfile.Glob {
|
|||||||
return new
|
return new
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Templater) ReplaceVars(vars *taskfile.Vars) *taskfile.Vars {
|
func (r *Templater) ReplaceVars(vars *ast.Vars) *ast.Vars {
|
||||||
return r.replaceVars(vars, nil)
|
return r.replaceVars(vars, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Templater) ReplaceVarsWithExtra(vars *taskfile.Vars, extra map[string]any) *taskfile.Vars {
|
func (r *Templater) ReplaceVarsWithExtra(vars *ast.Vars, extra map[string]any) *ast.Vars {
|
||||||
return r.replaceVars(vars, extra)
|
return r.replaceVars(vars, extra)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (r *Templater) replaceVars(vars *taskfile.Vars, extra map[string]any) *taskfile.Vars {
|
func (r *Templater) replaceVars(vars *ast.Vars, extra map[string]any) *ast.Vars {
|
||||||
if r.err != nil || vars.Len() == 0 {
|
if r.err != nil || vars.Len() == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
var newVars taskfile.Vars
|
var newVars ast.Vars
|
||||||
_ = vars.Range(func(k string, v taskfile.Var) error {
|
_ = vars.Range(func(k string, v ast.Var) error {
|
||||||
var newVar taskfile.Var
|
var newVar ast.Var
|
||||||
switch value := v.Value.(type) {
|
switch value := v.Value.(type) {
|
||||||
case string:
|
case string:
|
||||||
newVar.Value = r.ReplaceWithExtra(value, extra)
|
newVar.Value = r.ReplaceWithExtra(value, extra)
|
||||||
|
@ -7,13 +7,13 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/env"
|
"github.com/go-task/task/v3/internal/env"
|
||||||
"github.com/go-task/task/v3/internal/execext"
|
"github.com/go-task/task/v3/internal/execext"
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// ErrPreconditionFailed is returned when a precondition fails
|
// ErrPreconditionFailed is returned when a precondition fails
|
||||||
var ErrPreconditionFailed = errors.New("task: precondition not met")
|
var ErrPreconditionFailed = errors.New("task: precondition not met")
|
||||||
|
|
||||||
func (e *Executor) areTaskPreconditionsMet(ctx context.Context, t *taskfile.Task) (bool, error) {
|
func (e *Executor) areTaskPreconditionsMet(ctx context.Context, t *ast.Task) (bool, error) {
|
||||||
for _, p := range t.Preconditions {
|
for _, p := range t.Preconditions {
|
||||||
err := execext.RunCommand(ctx, &execext.RunCommandOptions{
|
err := execext.RunCommand(ctx, &execext.RunCommandOptions{
|
||||||
Command: p.Sh,
|
Command: p.Sh,
|
||||||
|
@ -4,10 +4,10 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/errors"
|
"github.com/go-task/task/v3/errors"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (e *Executor) areTaskRequiredVarsSet(ctx context.Context, t *taskfile.Task, call taskfile.Call) error {
|
func (e *Executor) areTaskRequiredVarsSet(ctx context.Context, t *ast.Task, call ast.Call) error {
|
||||||
if t.Requires == nil || len(t.Requires.Vars) == 0 {
|
if t.Requires == nil || len(t.Requires.Vars) == 0 {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
18
setup.go
18
setup.go
@ -18,7 +18,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/internal/output"
|
"github.com/go-task/task/v3/internal/output"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile"
|
||||||
"github.com/go-task/task/v3/taskfile/read"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (e *Executor) Setup() error {
|
func (e *Executor) Setup() error {
|
||||||
@ -69,7 +69,7 @@ func (e *Executor) setCurrentDir() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Search for a taskfile
|
// Search for a taskfile
|
||||||
root, err := read.ExistsWalk(e.Dir)
|
root, err := taskfile.ExistsWalk(e.Dir)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -81,11 +81,11 @@ func (e *Executor) setCurrentDir() error {
|
|||||||
|
|
||||||
func (e *Executor) readTaskfile() error {
|
func (e *Executor) readTaskfile() error {
|
||||||
uri := filepath.Join(e.Dir, e.Entrypoint)
|
uri := filepath.Join(e.Dir, e.Entrypoint)
|
||||||
node, err := read.NewNode(uri, e.Insecure)
|
node, err := taskfile.NewNode(uri, e.Insecure)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
e.Taskfile, err = read.Taskfile(
|
e.Taskfile, err = taskfile.Read(
|
||||||
node,
|
node,
|
||||||
e.Insecure,
|
e.Insecure,
|
||||||
e.Download,
|
e.Download,
|
||||||
@ -197,16 +197,16 @@ func (e *Executor) setupCompiler() error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) readDotEnvFiles() error {
|
func (e *Executor) readDotEnvFiles() error {
|
||||||
if e.Taskfile.Version.LessThan(taskfile.V3) {
|
if e.Taskfile.Version.LessThan(ast.V3) {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
env, err := read.Dotenv(e.Compiler, e.Taskfile, e.Dir)
|
env, err := taskfile.Dotenv(e.Compiler, e.Taskfile, e.Dir)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
err = env.Range(func(key string, value taskfile.Var) error {
|
err = env.Range(func(key string, value ast.Var) error {
|
||||||
if ok := e.Taskfile.Env.Exists(key); !ok {
|
if ok := e.Taskfile.Env.Exists(key); !ok {
|
||||||
e.Taskfile.Env.Set(key, value)
|
e.Taskfile.Env.Set(key, value)
|
||||||
}
|
}
|
||||||
@ -244,12 +244,12 @@ func (e *Executor) doVersionChecks() error {
|
|||||||
v := &semver.Version{}
|
v := &semver.Version{}
|
||||||
*v = *e.Taskfile.Version
|
*v = *e.Taskfile.Version
|
||||||
|
|
||||||
if v.LessThan(taskfile.V3) {
|
if v.LessThan(ast.V3) {
|
||||||
return fmt.Errorf(`task: Taskfile schemas prior to v3 are no longer supported`)
|
return fmt.Errorf(`task: Taskfile schemas prior to v3 are no longer supported`)
|
||||||
}
|
}
|
||||||
|
|
||||||
// consider as equal to the greater version if round
|
// consider as equal to the greater version if round
|
||||||
if v.Equal(taskfile.V3) {
|
if v.Equal(ast.V3) {
|
||||||
v = semver.MustParse("3.8")
|
v = semver.MustParse("3.8")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,11 +5,11 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/fingerprint"
|
"github.com/go-task/task/v3/internal/fingerprint"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Status returns an error if any the of given tasks is not up-to-date
|
// Status returns an error if any the of given tasks is not up-to-date
|
||||||
func (e *Executor) Status(ctx context.Context, calls ...taskfile.Call) error {
|
func (e *Executor) Status(ctx context.Context, calls ...ast.Call) error {
|
||||||
for _, call := range calls {
|
for _, call := range calls {
|
||||||
|
|
||||||
// Compile the task
|
// Compile the task
|
||||||
@ -41,7 +41,7 @@ func (e *Executor) Status(ctx context.Context, calls ...taskfile.Call) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) statusOnError(t *taskfile.Task) error {
|
func (e *Executor) statusOnError(t *ast.Task) error {
|
||||||
method := t.Method
|
method := t.Method
|
||||||
if method == "" {
|
if method == "" {
|
||||||
method = e.Taskfile.Method
|
method = e.Taskfile.Method
|
||||||
|
42
task.go
42
task.go
@ -21,7 +21,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/sort"
|
"github.com/go-task/task/v3/internal/sort"
|
||||||
"github.com/go-task/task/v3/internal/summary"
|
"github.com/go-task/task/v3/internal/summary"
|
||||||
"github.com/go-task/task/v3/internal/templater"
|
"github.com/go-task/task/v3/internal/templater"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
|
|
||||||
"github.com/sajari/fuzzy"
|
"github.com/sajari/fuzzy"
|
||||||
"golang.org/x/exp/slices"
|
"golang.org/x/exp/slices"
|
||||||
@ -36,7 +36,7 @@ const (
|
|||||||
|
|
||||||
// Executor executes a Taskfile
|
// Executor executes a Taskfile
|
||||||
type Executor struct {
|
type Executor struct {
|
||||||
Taskfile *taskfile.Taskfile
|
Taskfile *ast.Taskfile
|
||||||
|
|
||||||
Dir string
|
Dir string
|
||||||
TempDir string
|
TempDir string
|
||||||
@ -66,7 +66,7 @@ type Executor struct {
|
|||||||
Logger *logger.Logger
|
Logger *logger.Logger
|
||||||
Compiler *compiler.Compiler
|
Compiler *compiler.Compiler
|
||||||
Output output.Output
|
Output output.Output
|
||||||
OutputStyle taskfile.Output
|
OutputStyle ast.Output
|
||||||
TaskSorter sort.TaskSorter
|
TaskSorter sort.TaskSorter
|
||||||
UserWorkingDir string
|
UserWorkingDir string
|
||||||
|
|
||||||
@ -80,7 +80,7 @@ type Executor struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Run runs Task
|
// Run runs Task
|
||||||
func (e *Executor) Run(ctx context.Context, calls ...taskfile.Call) error {
|
func (e *Executor) Run(ctx context.Context, calls ...ast.Call) error {
|
||||||
// check if given tasks exist
|
// check if given tasks exist
|
||||||
for _, call := range calls {
|
for _, call := range calls {
|
||||||
task, err := e.GetTask(call)
|
task, err := e.GetTask(call)
|
||||||
@ -142,7 +142,7 @@ func (e *Executor) Run(ctx context.Context, calls ...taskfile.Call) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) splitRegularAndWatchCalls(calls ...taskfile.Call) (regularCalls []taskfile.Call, watchCalls []taskfile.Call, err error) {
|
func (e *Executor) splitRegularAndWatchCalls(calls ...ast.Call) (regularCalls []ast.Call, watchCalls []ast.Call, err error) {
|
||||||
for _, c := range calls {
|
for _, c := range calls {
|
||||||
t, err := e.GetTask(c)
|
t, err := e.GetTask(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -159,7 +159,7 @@ func (e *Executor) splitRegularAndWatchCalls(calls ...taskfile.Call) (regularCal
|
|||||||
}
|
}
|
||||||
|
|
||||||
// RunTask runs a task by its name
|
// RunTask runs a task by its name
|
||||||
func (e *Executor) RunTask(ctx context.Context, call taskfile.Call) error {
|
func (e *Executor) RunTask(ctx context.Context, call ast.Call) error {
|
||||||
t, err := e.FastCompiledTask(call)
|
t, err := e.FastCompiledTask(call)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -270,7 +270,7 @@ func (e *Executor) RunTask(ctx context.Context, call taskfile.Call) error {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) mkdir(t *taskfile.Task) error {
|
func (e *Executor) mkdir(t *ast.Task) error {
|
||||||
if t.Dir == "" {
|
if t.Dir == "" {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -287,7 +287,7 @@ func (e *Executor) mkdir(t *taskfile.Task) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) runDeps(ctx context.Context, t *taskfile.Task) error {
|
func (e *Executor) runDeps(ctx context.Context, t *ast.Task) error {
|
||||||
g, ctx := errgroup.WithContext(ctx)
|
g, ctx := errgroup.WithContext(ctx)
|
||||||
|
|
||||||
reacquire := e.releaseConcurrencyLimit()
|
reacquire := e.releaseConcurrencyLimit()
|
||||||
@ -296,7 +296,7 @@ func (e *Executor) runDeps(ctx context.Context, t *taskfile.Task) error {
|
|||||||
for _, d := range t.Deps {
|
for _, d := range t.Deps {
|
||||||
d := d
|
d := d
|
||||||
g.Go(func() error {
|
g.Go(func() error {
|
||||||
err := e.RunTask(ctx, taskfile.Call{Task: d.Task, Vars: d.Vars, Silent: d.Silent})
|
err := e.RunTask(ctx, ast.Call{Task: d.Task, Vars: d.Vars, Silent: d.Silent})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -307,7 +307,7 @@ func (e *Executor) runDeps(ctx context.Context, t *taskfile.Task) error {
|
|||||||
return g.Wait()
|
return g.Wait()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) runDeferred(t *taskfile.Task, call taskfile.Call, i int) {
|
func (e *Executor) runDeferred(t *ast.Task, call ast.Call, i int) {
|
||||||
ctx, cancel := context.WithCancel(context.Background())
|
ctx, cancel := context.WithCancel(context.Background())
|
||||||
defer cancel()
|
defer cancel()
|
||||||
|
|
||||||
@ -316,7 +316,7 @@ func (e *Executor) runDeferred(t *taskfile.Task, call taskfile.Call, i int) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) runCommand(ctx context.Context, t *taskfile.Task, call taskfile.Call, i int) error {
|
func (e *Executor) runCommand(ctx context.Context, t *ast.Task, call ast.Call, i int) error {
|
||||||
cmd := t.Cmds[i]
|
cmd := t.Cmds[i]
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
@ -324,7 +324,7 @@ func (e *Executor) runCommand(ctx context.Context, t *taskfile.Task, call taskfi
|
|||||||
reacquire := e.releaseConcurrencyLimit()
|
reacquire := e.releaseConcurrencyLimit()
|
||||||
defer reacquire()
|
defer reacquire()
|
||||||
|
|
||||||
err := e.RunTask(ctx, taskfile.Call{Task: cmd.Task, Vars: cmd.Vars, Silent: cmd.Silent})
|
err := e.RunTask(ctx, ast.Call{Task: cmd.Task, Vars: cmd.Vars, Silent: cmd.Silent})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -377,7 +377,7 @@ func (e *Executor) runCommand(ctx context.Context, t *taskfile.Task, call taskfi
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) startExecution(ctx context.Context, t *taskfile.Task, execute func(ctx context.Context) error) error {
|
func (e *Executor) startExecution(ctx context.Context, t *ast.Task, execute func(ctx context.Context) error) error {
|
||||||
h, err := e.GetHash(t)
|
h, err := e.GetHash(t)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
@ -413,7 +413,7 @@ func (e *Executor) startExecution(ctx context.Context, t *taskfile.Task, execute
|
|||||||
// GetTask will return the task with the name matching the given call from the taskfile.
|
// GetTask will return the task with the name matching the given call from the taskfile.
|
||||||
// If no task is found, it will search for tasks with a matching alias.
|
// If no task is found, it will search for tasks with a matching alias.
|
||||||
// If multiple tasks contain the same alias or no matches are found an error is returned.
|
// If multiple tasks contain the same alias or no matches are found an error is returned.
|
||||||
func (e *Executor) GetTask(call taskfile.Call) (*taskfile.Task, error) {
|
func (e *Executor) GetTask(call ast.Call) (*ast.Task, error) {
|
||||||
// Search for a matching task
|
// Search for a matching task
|
||||||
matchingTask := e.Taskfile.Tasks.Get(call.Task)
|
matchingTask := e.Taskfile.Tasks.Get(call.Task)
|
||||||
if matchingTask != nil {
|
if matchingTask != nil {
|
||||||
@ -450,10 +450,10 @@ func (e *Executor) GetTask(call taskfile.Call) (*taskfile.Task, error) {
|
|||||||
return matchingTask, nil
|
return matchingTask, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
type FilterFunc func(task *taskfile.Task) bool
|
type FilterFunc func(task *ast.Task) bool
|
||||||
|
|
||||||
func (e *Executor) GetTaskList(filters ...FilterFunc) ([]*taskfile.Task, error) {
|
func (e *Executor) GetTaskList(filters ...FilterFunc) ([]*ast.Task, error) {
|
||||||
tasks := make([]*taskfile.Task, 0, e.Taskfile.Tasks.Len())
|
tasks := make([]*ast.Task, 0, e.Taskfile.Tasks.Len())
|
||||||
|
|
||||||
// Create an error group to wait for each task to be compiled
|
// Create an error group to wait for each task to be compiled
|
||||||
var g errgroup.Group
|
var g errgroup.Group
|
||||||
@ -476,7 +476,7 @@ func (e *Executor) GetTaskList(filters ...FilterFunc) ([]*taskfile.Task, error)
|
|||||||
idx := i
|
idx := i
|
||||||
task := tasks[idx]
|
task := tasks[idx]
|
||||||
g.Go(func() error {
|
g.Go(func() error {
|
||||||
compiledTask, err := e.FastCompiledTask(taskfile.Call{Task: task.Task})
|
compiledTask, err := e.FastCompiledTask(ast.Call{Task: task.Task})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -500,16 +500,16 @@ func (e *Executor) GetTaskList(filters ...FilterFunc) ([]*taskfile.Task, error)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// FilterOutNoDesc removes all tasks that do not contain a description.
|
// FilterOutNoDesc removes all tasks that do not contain a description.
|
||||||
func FilterOutNoDesc(task *taskfile.Task) bool {
|
func FilterOutNoDesc(task *ast.Task) bool {
|
||||||
return task.Desc == ""
|
return task.Desc == ""
|
||||||
}
|
}
|
||||||
|
|
||||||
// FilterOutInternal removes all tasks that are marked as internal.
|
// FilterOutInternal removes all tasks that are marked as internal.
|
||||||
func FilterOutInternal(task *taskfile.Task) bool {
|
func FilterOutInternal(task *ast.Task) bool {
|
||||||
return task.Internal
|
return task.Internal
|
||||||
}
|
}
|
||||||
|
|
||||||
func shouldRunOnCurrentPlatform(platforms []*taskfile.Platform) bool {
|
func shouldRunOnCurrentPlatform(platforms []*ast.Platform) bool {
|
||||||
if len(platforms) == 0 {
|
if len(platforms) == 0 {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
192
task_test.go
192
task_test.go
@ -18,7 +18,7 @@ import (
|
|||||||
"github.com/go-task/task/v3"
|
"github.com/go-task/task/v3"
|
||||||
"github.com/go-task/task/v3/errors"
|
"github.com/go-task/task/v3/errors"
|
||||||
"github.com/go-task/task/v3/internal/filepathext"
|
"github.com/go-task/task/v3/internal/filepathext"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -52,7 +52,7 @@ func (fct fileContentTest) Run(t *testing.T) {
|
|||||||
Stderr: io.Discard,
|
Stderr: io.Discard,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup(), "e.Setup()")
|
require.NoError(t, e.Setup(), "e.Setup()")
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: fct.Target}), "e.Run(target)")
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: fct.Target}), "e.Run(target)")
|
||||||
|
|
||||||
for name, expectContent := range fct.Files {
|
for name, expectContent := range fct.Files {
|
||||||
t.Run(fct.name(name), func(t *testing.T) {
|
t.Run(fct.name(name), func(t *testing.T) {
|
||||||
@ -75,7 +75,7 @@ func TestEmptyTask(t *testing.T) {
|
|||||||
Stderr: io.Discard,
|
Stderr: io.Discard,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup(), "e.Setup()")
|
require.NoError(t, e.Setup(), "e.Setup()")
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestEnv(t *testing.T) {
|
func TestEnv(t *testing.T) {
|
||||||
@ -118,7 +118,7 @@ func TestSpecialVars(t *testing.T) {
|
|||||||
Silent: true,
|
Silent: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: target}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: target}))
|
||||||
|
|
||||||
toAbs := func(rel string) string {
|
toAbs := func(rel string) string {
|
||||||
abs, err := filepath.Abs(rel)
|
abs, err := filepath.Abs(rel)
|
||||||
@ -154,7 +154,7 @@ func TestConcurrency(t *testing.T) {
|
|||||||
Concurrency: 1,
|
Concurrency: 1,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup(), "e.Setup()")
|
require.NoError(t, e.Setup(), "e.Setup()")
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: target}), "e.Run(target)")
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: target}), "e.Run(target)")
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestParams(t *testing.T) {
|
func TestParams(t *testing.T) {
|
||||||
@ -206,7 +206,7 @@ func TestDeps(t *testing.T) {
|
|||||||
Stderr: io.Discard,
|
Stderr: io.Discard,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
|
|
||||||
for _, f := range files {
|
for _, f := range files {
|
||||||
f = filepathext.SmartJoin(dir, f)
|
f = filepathext.SmartJoin(dir, f)
|
||||||
@ -243,15 +243,15 @@ func TestStatus(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
// gen-foo creates foo.txt, and will always fail it's status check.
|
// gen-foo creates foo.txt, and will always fail it's status check.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-foo"}))
|
||||||
// gen-foo creates bar.txt, and will pass its status-check the 3. time it
|
// gen-foo creates bar.txt, and will pass its status-check the 3. time it
|
||||||
// is run. It creates bar.txt, but also lists it as its source. So, the checksum
|
// is run. It creates bar.txt, but also lists it as its source. So, the checksum
|
||||||
// for the file won't match before after the second run as we the file
|
// for the file won't match before after the second run as we the file
|
||||||
// only exists after the first run.
|
// only exists after the first run.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-bar"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-bar"}))
|
||||||
// gen-silent-baz is marked as being silent, and should only produce output
|
// gen-silent-baz is marked as being silent, and should only produce output
|
||||||
// if e.Verbose is set to true.
|
// if e.Verbose is set to true.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-silent-baz"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-silent-baz"}))
|
||||||
|
|
||||||
for _, f := range files {
|
for _, f := range files {
|
||||||
if _, err := os.Stat(filepathext.SmartJoin(dir, f)); err != nil {
|
if _, err := os.Stat(filepathext.SmartJoin(dir, f)); err != nil {
|
||||||
@ -260,10 +260,10 @@ func TestStatus(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Run gen-bar a second time to produce a checksum file that matches bar.txt
|
// Run gen-bar a second time to produce a checksum file that matches bar.txt
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-bar"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-bar"}))
|
||||||
|
|
||||||
// Run gen-bar a third time, to make sure we've triggered the status check.
|
// Run gen-bar a third time, to make sure we've triggered the status check.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-bar"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-bar"}))
|
||||||
|
|
||||||
// We're silent, so no output should have been produced.
|
// We're silent, so no output should have been produced.
|
||||||
assert.Empty(t, buff.String())
|
assert.Empty(t, buff.String())
|
||||||
@ -272,7 +272,7 @@ func TestStatus(t *testing.T) {
|
|||||||
// for the next test.
|
// for the next test.
|
||||||
err := os.Remove(filepathext.SmartJoin(dir, "bar.txt"))
|
err := os.Remove(filepathext.SmartJoin(dir, "bar.txt"))
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-bar"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-bar"}))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// Global silence switched of, so we should see output unless the task itself
|
// Global silence switched of, so we should see output unless the task itself
|
||||||
@ -280,34 +280,34 @@ func TestStatus(t *testing.T) {
|
|||||||
e.Silent = false
|
e.Silent = false
|
||||||
|
|
||||||
// all: not up-to-date
|
// all: not up-to-date
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-foo"}))
|
||||||
assert.Equal(t, "task: [gen-foo] touch foo.txt", strings.TrimSpace(buff.String()))
|
assert.Equal(t, "task: [gen-foo] touch foo.txt", strings.TrimSpace(buff.String()))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
// status: not up-to-date
|
// status: not up-to-date
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-foo"}))
|
||||||
assert.Equal(t, "task: [gen-foo] touch foo.txt", strings.TrimSpace(buff.String()))
|
assert.Equal(t, "task: [gen-foo] touch foo.txt", strings.TrimSpace(buff.String()))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// sources: not up-to-date
|
// sources: not up-to-date
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-bar"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-bar"}))
|
||||||
assert.Equal(t, "task: [gen-bar] touch bar.txt", strings.TrimSpace(buff.String()))
|
assert.Equal(t, "task: [gen-bar] touch bar.txt", strings.TrimSpace(buff.String()))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
// all: up-to-date
|
// all: up-to-date
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-bar"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-bar"}))
|
||||||
assert.Equal(t, `task: Task "gen-bar" is up to date`, strings.TrimSpace(buff.String()))
|
assert.Equal(t, `task: Task "gen-bar" is up to date`, strings.TrimSpace(buff.String()))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// sources: not up-to-date, no output produced.
|
// sources: not up-to-date, no output produced.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-silent-baz"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-silent-baz"}))
|
||||||
assert.Empty(t, buff.String())
|
assert.Empty(t, buff.String())
|
||||||
|
|
||||||
// up-to-date, no output produced
|
// up-to-date, no output produced
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-silent-baz"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-silent-baz"}))
|
||||||
assert.Empty(t, buff.String())
|
assert.Empty(t, buff.String())
|
||||||
|
|
||||||
e.Verbose = true
|
e.Verbose = true
|
||||||
// up-to-date, output produced due to Verbose mode.
|
// up-to-date, output produced due to Verbose mode.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "gen-silent-baz"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "gen-silent-baz"}))
|
||||||
assert.Equal(t, `task: Task "gen-silent-baz" is up to date`, strings.TrimSpace(buff.String()))
|
assert.Equal(t, `task: Task "gen-silent-baz" is up to date`, strings.TrimSpace(buff.String()))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
}
|
}
|
||||||
@ -324,13 +324,13 @@ func TestPrecondition(t *testing.T) {
|
|||||||
|
|
||||||
// A precondition that has been met
|
// A precondition that has been met
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "foo"}))
|
||||||
if buff.String() != "" {
|
if buff.String() != "" {
|
||||||
t.Errorf("Got Output when none was expected: %s", buff.String())
|
t.Errorf("Got Output when none was expected: %s", buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
// A precondition that was not met
|
// A precondition that was not met
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "impossible"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "impossible"}))
|
||||||
|
|
||||||
if buff.String() != "task: 1 != 0 obviously!\n" {
|
if buff.String() != "task: 1 != 0 obviously!\n" {
|
||||||
t.Errorf("Wrong output message: %s", buff.String())
|
t.Errorf("Wrong output message: %s", buff.String())
|
||||||
@ -338,7 +338,7 @@ func TestPrecondition(t *testing.T) {
|
|||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// Calling a task with a precondition in a dependency fails the task
|
// Calling a task with a precondition in a dependency fails the task
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "depends_on_impossible"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "depends_on_impossible"}))
|
||||||
|
|
||||||
if buff.String() != "task: 1 != 0 obviously!\n" {
|
if buff.String() != "task: 1 != 0 obviously!\n" {
|
||||||
t.Errorf("Wrong output message: %s", buff.String())
|
t.Errorf("Wrong output message: %s", buff.String())
|
||||||
@ -346,7 +346,7 @@ func TestPrecondition(t *testing.T) {
|
|||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// Calling a task with a precondition in a cmd fails the task
|
// Calling a task with a precondition in a cmd fails the task
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "executes_failing_task_as_cmd"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "executes_failing_task_as_cmd"}))
|
||||||
if buff.String() != "task: 1 != 0 obviously!\n" {
|
if buff.String() != "task: 1 != 0 obviously!\n" {
|
||||||
t.Errorf("Wrong output message: %s", buff.String())
|
t.Errorf("Wrong output message: %s", buff.String())
|
||||||
}
|
}
|
||||||
@ -387,7 +387,7 @@ func TestGenerates(t *testing.T) {
|
|||||||
fmt.Sprintf("task: Task \"%s\" is up to date\n", theTask)
|
fmt.Sprintf("task: Task \"%s\" is up to date\n", theTask)
|
||||||
|
|
||||||
// Run task for the first time.
|
// Run task for the first time.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: theTask}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: theTask}))
|
||||||
|
|
||||||
if _, err := os.Stat(srcFile); err != nil {
|
if _, err := os.Stat(srcFile); err != nil {
|
||||||
t.Errorf("File should exist: %v", err)
|
t.Errorf("File should exist: %v", err)
|
||||||
@ -402,7 +402,7 @@ func TestGenerates(t *testing.T) {
|
|||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// Re-run task to ensure it's now found to be up-to-date.
|
// Re-run task to ensure it's now found to be up-to-date.
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: theTask}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: theTask}))
|
||||||
if buff.String() != upToDate {
|
if buff.String() != upToDate {
|
||||||
t.Errorf("Wrong output message: %s", buff.String())
|
t.Errorf("Wrong output message: %s", buff.String())
|
||||||
}
|
}
|
||||||
@ -440,7 +440,7 @@ func TestStatusChecksum(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: test.task}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: test.task}))
|
||||||
for _, f := range test.files {
|
for _, f := range test.files {
|
||||||
_, err := os.Stat(filepathext.SmartJoin(dir, f))
|
_, err := os.Stat(filepathext.SmartJoin(dir, f))
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
@ -453,7 +453,7 @@ func TestStatusChecksum(t *testing.T) {
|
|||||||
time := s.ModTime()
|
time := s.ModTime()
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: test.task}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: test.task}))
|
||||||
assert.Equal(t, `task: Task "`+test.task+`" is up to date`+"\n", buff.String())
|
assert.Equal(t, `task: Task "`+test.task+`" is up to date`+"\n", buff.String())
|
||||||
|
|
||||||
s, err = os.Stat(filepathext.SmartJoin(tempdir, "checksum/"+test.task))
|
s, err = os.Stat(filepathext.SmartJoin(tempdir, "checksum/"+test.task))
|
||||||
@ -476,7 +476,7 @@ func TestAlias(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "f"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "f"}))
|
||||||
assert.Equal(t, string(data), buff.String())
|
assert.Equal(t, string(data), buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -490,7 +490,7 @@ func TestDuplicateAlias(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "x"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "x"}))
|
||||||
assert.Equal(t, "", buff.String())
|
assert.Equal(t, "", buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -508,7 +508,7 @@ func TestAliasSummary(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "f"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "f"}))
|
||||||
assert.Equal(t, string(data), buff.String())
|
assert.Equal(t, string(data), buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -522,7 +522,7 @@ func TestLabelUpToDate(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "foo"}))
|
||||||
assert.Contains(t, buff.String(), "foobar")
|
assert.Contains(t, buff.String(), "foobar")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -537,7 +537,7 @@ func TestLabelSummary(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "foo"}))
|
||||||
assert.Contains(t, buff.String(), "foobar")
|
assert.Contains(t, buff.String(), "foobar")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -548,7 +548,7 @@ func TestLabelInStatus(t *testing.T) {
|
|||||||
Dir: dir,
|
Dir: dir,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
err := e.Status(context.Background(), taskfile.Call{Task: "foo"})
|
err := e.Status(context.Background(), ast.Call{Task: "foo"})
|
||||||
assert.ErrorContains(t, err, "foobar")
|
assert.ErrorContains(t, err, "foobar")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -562,7 +562,7 @@ func TestLabelWithVariableExpansion(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "foo"}))
|
||||||
assert.Contains(t, buff.String(), "foobaz")
|
assert.Contains(t, buff.String(), "foobaz")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -576,7 +576,7 @@ func TestLabelInSummary(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "foo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "foo"}))
|
||||||
assert.Contains(t, buff.String(), "foobar")
|
assert.Contains(t, buff.String(), "foobar")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -612,7 +612,7 @@ func TestPromptInSummary(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "foo"})
|
err := e.Run(context.Background(), ast.Call{Task: "foo"})
|
||||||
|
|
||||||
if test.wantError {
|
if test.wantError {
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
@ -640,7 +640,7 @@ func TestPromptWithIndirectTask(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "bar"})
|
err := e.Run(context.Background(), ast.Call{Task: "bar"})
|
||||||
assert.Contains(t, outBuff.String(), "show-prompt")
|
assert.Contains(t, outBuff.String(), "show-prompt")
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
}
|
}
|
||||||
@ -673,7 +673,7 @@ func TestPromptAssumeYes(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "foo"})
|
err := e.Run(context.Background(), ast.Call{Task: "foo"})
|
||||||
|
|
||||||
if !test.assumeYes {
|
if !test.assumeYes {
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
@ -785,7 +785,7 @@ func TestStatusVariables(t *testing.T) {
|
|||||||
Verbose: true,
|
Verbose: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "build"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "build"}))
|
||||||
|
|
||||||
assert.Contains(t, buff.String(), "3e464c4b03f4b65d740e1e130d4d108a")
|
assert.Contains(t, buff.String(), "3e464c4b03f4b65d740e1e130d4d108a")
|
||||||
|
|
||||||
@ -826,7 +826,7 @@ func TestCyclicDep(t *testing.T) {
|
|||||||
Stderr: io.Discard,
|
Stderr: io.Discard,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
assert.IsType(t, &errors.TaskCalledTooManyTimesError{}, e.Run(context.Background(), taskfile.Call{Task: "task-1"}))
|
assert.IsType(t, &errors.TaskCalledTooManyTimesError{}, e.Run(context.Background(), ast.Call{Task: "task-1"}))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestTaskVersion(t *testing.T) {
|
func TestTaskVersion(t *testing.T) {
|
||||||
@ -869,10 +869,10 @@ func TestTaskIgnoreErrors(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "task-should-pass"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "task-should-pass"}))
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "task-should-fail"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "task-should-fail"}))
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "cmd-should-pass"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "cmd-should-pass"}))
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "cmd-should-fail"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "cmd-should-fail"}))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestExpand(t *testing.T) {
|
func TestExpand(t *testing.T) {
|
||||||
@ -890,7 +890,7 @@ func TestExpand(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "pwd"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "pwd"}))
|
||||||
assert.Equal(t, home, strings.TrimSpace(buff.String()))
|
assert.Equal(t, home, strings.TrimSpace(buff.String()))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -909,7 +909,7 @@ func TestDry(t *testing.T) {
|
|||||||
Dry: true,
|
Dry: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "build"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "build"}))
|
||||||
|
|
||||||
assert.Equal(t, "task: [build] touch file.txt", strings.TrimSpace(buff.String()))
|
assert.Equal(t, "task: [build] touch file.txt", strings.TrimSpace(buff.String()))
|
||||||
if _, err := os.Stat(file); err == nil {
|
if _, err := os.Stat(file); err == nil {
|
||||||
@ -933,13 +933,13 @@ func TestDryChecksum(t *testing.T) {
|
|||||||
Dry: true,
|
Dry: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
|
|
||||||
_, err := os.Stat(checksumFile)
|
_, err := os.Stat(checksumFile)
|
||||||
require.Error(t, err, "checksum file should not exist")
|
require.Error(t, err, "checksum file should not exist")
|
||||||
|
|
||||||
e.Dry = false
|
e.Dry = false
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
_, err = os.Stat(checksumFile)
|
_, err = os.Stat(checksumFile)
|
||||||
require.NoError(t, err, "checksum file should exist")
|
require.NoError(t, err, "checksum file should exist")
|
||||||
}
|
}
|
||||||
@ -1121,11 +1121,11 @@ func TestIncludesRelativePath(t *testing.T) {
|
|||||||
|
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "common:pwd"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "common:pwd"}))
|
||||||
assert.Contains(t, buff.String(), "testdata/includes_rel_path/common")
|
assert.Contains(t, buff.String(), "testdata/includes_rel_path/common")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "included:common:pwd"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "included:common:pwd"}))
|
||||||
assert.Contains(t, buff.String(), "testdata/includes_rel_path/common")
|
assert.Contains(t, buff.String(), "testdata/includes_rel_path/common")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1153,7 +1153,7 @@ func TestIncludesInternal(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: test.task})
|
err := e.Run(context.Background(), ast.Call{Task: test.task})
|
||||||
if test.expectedErr {
|
if test.expectedErr {
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
} else {
|
} else {
|
||||||
@ -1187,7 +1187,7 @@ func TestIncludesInterpolation(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: test.task})
|
err := e.Run(context.Background(), ast.Call{Task: test.task})
|
||||||
if test.expectedErr {
|
if test.expectedErr {
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
} else {
|
} else {
|
||||||
@ -1222,7 +1222,7 @@ func TestInternalTask(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: test.task})
|
err := e.Run(context.Background(), ast.Call{Task: test.task})
|
||||||
if test.expectedErr {
|
if test.expectedErr {
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
} else {
|
} else {
|
||||||
@ -1291,7 +1291,7 @@ func TestSummary(t *testing.T) {
|
|||||||
Silent: true,
|
Silent: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "task-with-summary"}, taskfile.Call{Task: "other-task-with-summary"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "task-with-summary"}, ast.Call{Task: "other-task-with-summary"}))
|
||||||
|
|
||||||
data, err := os.ReadFile(filepathext.SmartJoin(dir, "task-with-summary.txt"))
|
data, err := os.ReadFile(filepathext.SmartJoin(dir, "task-with-summary.txt"))
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
@ -1315,7 +1315,7 @@ func TestWhenNoDirAttributeItRunsInSameDirAsTaskfile(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "whereami"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "whereami"}))
|
||||||
|
|
||||||
// got should be the "dir" part of "testdata/dir"
|
// got should be the "dir" part of "testdata/dir"
|
||||||
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
||||||
@ -1333,7 +1333,7 @@ func TestWhenDirAttributeAndDirExistsItRunsInThatDir(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "whereami"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "whereami"}))
|
||||||
|
|
||||||
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
||||||
assert.Equal(t, expected, got, "Mismatch in the working directory")
|
assert.Equal(t, expected, got, "Mismatch in the working directory")
|
||||||
@ -1357,7 +1357,7 @@ func TestWhenDirAttributeItCreatesMissingAndRunsInThatDir(t *testing.T) {
|
|||||||
t.Errorf("Directory should not exist: %v", err)
|
t.Errorf("Directory should not exist: %v", err)
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: target}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: target}))
|
||||||
|
|
||||||
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
||||||
assert.Equal(t, expected, got, "Mismatch in the working directory")
|
assert.Equal(t, expected, got, "Mismatch in the working directory")
|
||||||
@ -1384,7 +1384,7 @@ func TestDynamicVariablesRunOnTheNewCreatedDir(t *testing.T) {
|
|||||||
t.Errorf("Directory should not exist: %v", err)
|
t.Errorf("Directory should not exist: %v", err)
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: target}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: target}))
|
||||||
|
|
||||||
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
got := strings.TrimSuffix(filepath.Base(out.String()), "\n")
|
||||||
assert.Equal(t, expected, got, "Mismatch in the working directory")
|
assert.Equal(t, expected, got, "Mismatch in the working directory")
|
||||||
@ -1442,7 +1442,7 @@ func TestShortTaskNotation(t *testing.T) {
|
|||||||
Silent: true,
|
Silent: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
assert.Equal(t, "string-slice-1\nstring-slice-2\nstring\n", buff.String())
|
assert.Equal(t, "string-slice-1\nstring-slice-2\nstring\n", buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1586,7 +1586,7 @@ func TestExitImmediately(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
assert.Contains(t, buff.String(), `"this_should_fail": executable file not found in $PATH`)
|
assert.Contains(t, buff.String(), `"this_should_fail": executable file not found in $PATH`)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1622,7 +1622,7 @@ echo ran
|
|||||||
task: [task-1] echo 'task-1 ran successfully'
|
task: [task-1] echo 'task-1 ran successfully'
|
||||||
task-1 ran successfully
|
task-1 ran successfully
|
||||||
`)
|
`)
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "task-2"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "task-2"}))
|
||||||
assert.Contains(t, buff.String(), expectedOutputOrder)
|
assert.Contains(t, buff.String(), expectedOutputOrder)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1647,7 +1647,7 @@ func TestIgnoreNilElements(t *testing.T) {
|
|||||||
Silent: true,
|
Silent: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
assert.Equal(t, "string-slice-1\n", buff.String())
|
assert.Equal(t, "string-slice-1\n", buff.String())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -1673,7 +1673,7 @@ task: [bye] echo 'Bye!'
|
|||||||
Bye!
|
Bye!
|
||||||
::endgroup::
|
::endgroup::
|
||||||
`)
|
`)
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "bye"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "bye"}))
|
||||||
t.Log(buff.String())
|
t.Log(buff.String())
|
||||||
assert.Equal(t, strings.TrimSpace(buff.String()), expectedOutputOrder)
|
assert.Equal(t, strings.TrimSpace(buff.String()), expectedOutputOrder)
|
||||||
}
|
}
|
||||||
@ -1688,7 +1688,7 @@ func TestOutputGroupErrorOnlySwallowsOutputOnSuccess(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "passing"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "passing"}))
|
||||||
t.Log(buff.String())
|
t.Log(buff.String())
|
||||||
assert.Empty(t, buff.String())
|
assert.Empty(t, buff.String())
|
||||||
}
|
}
|
||||||
@ -1703,7 +1703,7 @@ func TestOutputGroupErrorOnlyShowsOutputOnFailure(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
require.Error(t, e.Run(context.Background(), taskfile.Call{Task: "failing"}))
|
require.Error(t, e.Run(context.Background(), ast.Call{Task: "failing"}))
|
||||||
t.Log(buff.String())
|
t.Log(buff.String())
|
||||||
assert.Contains(t, "failing-output", strings.TrimSpace(buff.String()))
|
assert.Contains(t, "failing-output", strings.TrimSpace(buff.String()))
|
||||||
assert.NotContains(t, "passing", strings.TrimSpace(buff.String()))
|
assert.NotContains(t, "passing", strings.TrimSpace(buff.String()))
|
||||||
@ -1733,7 +1733,7 @@ VAR_1 is included-default-var1
|
|||||||
task: [included3:task1] echo "VAR_2 is included-default-var2"
|
task: [included3:task1] echo "VAR_2 is included-default-var2"
|
||||||
VAR_2 is included-default-var2
|
VAR_2 is included-default-var2
|
||||||
`)
|
`)
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "task1"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "task1"}))
|
||||||
t.Log(buff.String())
|
t.Log(buff.String())
|
||||||
assert.Equal(t, strings.TrimSpace(buff.String()), expectedOutputOrder)
|
assert.Equal(t, strings.TrimSpace(buff.String()), expectedOutputOrder)
|
||||||
}
|
}
|
||||||
@ -1756,7 +1756,7 @@ Hello foo
|
|||||||
task: [bar:lib:greet] echo 'Hello bar'
|
task: [bar:lib:greet] echo 'Hello bar'
|
||||||
Hello bar
|
Hello bar
|
||||||
`)
|
`)
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
t.Log(buff.String())
|
t.Log(buff.String())
|
||||||
assert.Equal(t, strings.TrimSpace(buff.String()), expectedOutputOrder)
|
assert.Equal(t, strings.TrimSpace(buff.String()), expectedOutputOrder)
|
||||||
}
|
}
|
||||||
@ -1789,7 +1789,7 @@ func TestErrorCode(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: test.task, Direct: true})
|
err := e.Run(context.Background(), ast.Call{Task: test.task, Direct: true})
|
||||||
require.Error(t, err)
|
require.Error(t, err)
|
||||||
taskRunErr, ok := err.(*errors.TaskRunError)
|
taskRunErr, ok := err.(*errors.TaskRunError)
|
||||||
assert.True(t, ok, "cannot cast returned error to *task.TaskRunError")
|
assert.True(t, ok, "cannot cast returned error to *task.TaskRunError")
|
||||||
@ -1841,7 +1841,7 @@ func TestEvaluateSymlinksInPaths(t *testing.T) {
|
|||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
t.Run(test.name, func(t *testing.T) {
|
t.Run(test.name, func(t *testing.T) {
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: test.task})
|
err := e.Run(context.Background(), ast.Call{Task: test.task})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, test.expected, strings.TrimSpace(buff.String()))
|
assert.Equal(t, test.expected, strings.TrimSpace(buff.String()))
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
@ -1880,7 +1880,7 @@ func TestTaskfileWalk(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
assert.Equal(t, test.expected, buff.String())
|
assert.Equal(t, test.expected, buff.String())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -1896,7 +1896,7 @@ func TestUserWorkingDirectory(t *testing.T) {
|
|||||||
wd, err := os.Getwd()
|
wd, err := os.Getwd()
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "default"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "default"}))
|
||||||
assert.Equal(t, fmt.Sprintf("%s\n", wd), buff.String())
|
assert.Equal(t, fmt.Sprintf("%s\n", wd), buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1916,7 +1916,7 @@ func TestUserWorkingDirectoryWithIncluded(t *testing.T) {
|
|||||||
|
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "included:echo"}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "included:echo"}))
|
||||||
assert.Equal(t, fmt.Sprintf("%s\n", wd), buff.String())
|
assert.Equal(t, fmt.Sprintf("%s\n", wd), buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1928,7 +1928,7 @@ func TestPlatforms(t *testing.T) {
|
|||||||
Stderr: &buff,
|
Stderr: &buff,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "build-" + runtime.GOOS}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "build-" + runtime.GOOS}))
|
||||||
assert.Equal(t, fmt.Sprintf("task: [build-%s] echo 'Running task on %s'\nRunning task on %s\n", runtime.GOOS, runtime.GOOS, runtime.GOOS), buff.String())
|
assert.Equal(t, fmt.Sprintf("task: [build-%s] echo 'Running task on %s'\nRunning task on %s\n", runtime.GOOS, runtime.GOOS, runtime.GOOS), buff.String())
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1941,7 +1941,7 @@ func TestPOSIXShellOptsGlobalLevel(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "pipefail"})
|
err := e.Run(context.Background(), ast.Call{Task: "pipefail"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "pipefail\ton\n", buff.String())
|
assert.Equal(t, "pipefail\ton\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -1955,7 +1955,7 @@ func TestPOSIXShellOptsTaskLevel(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "pipefail"})
|
err := e.Run(context.Background(), ast.Call{Task: "pipefail"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "pipefail\ton\n", buff.String())
|
assert.Equal(t, "pipefail\ton\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -1969,7 +1969,7 @@ func TestPOSIXShellOptsCommandLevel(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "pipefail"})
|
err := e.Run(context.Background(), ast.Call{Task: "pipefail"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "pipefail\ton\n", buff.String())
|
assert.Equal(t, "pipefail\ton\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -1983,7 +1983,7 @@ func TestBashShellOptsGlobalLevel(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "globstar"})
|
err := e.Run(context.Background(), ast.Call{Task: "globstar"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "globstar\ton\n", buff.String())
|
assert.Equal(t, "globstar\ton\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -1997,7 +1997,7 @@ func TestBashShellOptsTaskLevel(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "globstar"})
|
err := e.Run(context.Background(), ast.Call{Task: "globstar"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "globstar\ton\n", buff.String())
|
assert.Equal(t, "globstar\ton\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -2011,7 +2011,7 @@ func TestBashShellOptsCommandLevel(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "globstar"})
|
err := e.Run(context.Background(), ast.Call{Task: "globstar"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "globstar\ton\n", buff.String())
|
assert.Equal(t, "globstar\ton\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -2026,10 +2026,10 @@ func TestSplitArgs(t *testing.T) {
|
|||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
vars := &taskfile.Vars{}
|
vars := &ast.Vars{}
|
||||||
vars.Set("CLI_ARGS", taskfile.Var{Value: "foo bar 'foo bar baz'"})
|
vars.Set("CLI_ARGS", ast.Var{Value: "foo bar 'foo bar baz'"})
|
||||||
|
|
||||||
err := e.Run(context.Background(), taskfile.Call{Task: "default", Vars: vars})
|
err := e.Run(context.Background(), ast.Call{Task: "default", Vars: vars})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
assert.Equal(t, "3\n", buff.String())
|
assert.Equal(t, "3\n", buff.String())
|
||||||
}
|
}
|
||||||
@ -2057,20 +2057,20 @@ func TestSilence(t *testing.T) {
|
|||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
|
|
||||||
// First verify that the silent flag is in place.
|
// First verify that the silent flag is in place.
|
||||||
task, err := e.GetTask(taskfile.Call{Task: "task-test-silent-calls-chatty-silenced"})
|
task, err := e.GetTask(ast.Call{Task: "task-test-silent-calls-chatty-silenced"})
|
||||||
require.NoError(t, err, "Unable to look up task task-test-silent-calls-chatty-silenced")
|
require.NoError(t, err, "Unable to look up task task-test-silent-calls-chatty-silenced")
|
||||||
require.True(t, task.Cmds[0].Silent, "The task task-test-silent-calls-chatty-silenced should have a silent call to chatty")
|
require.True(t, task.Cmds[0].Silent, "The task task-test-silent-calls-chatty-silenced should have a silent call to chatty")
|
||||||
|
|
||||||
// Then test the two basic cases where the task is silent or not.
|
// Then test the two basic cases where the task is silent or not.
|
||||||
// A silenced task.
|
// A silenced task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "silent"})
|
err = e.Run(context.Background(), ast.Call{Task: "silent"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, buff.String(), "siWhile running lent: Expected not see output, because the task is silent")
|
require.Empty(t, buff.String(), "siWhile running lent: Expected not see output, because the task is silent")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A chatty (not silent) task.
|
// A chatty (not silent) task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "chatty"})
|
err = e.Run(context.Background(), ast.Call{Task: "chatty"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NotEmpty(t, buff.String(), "chWhile running atty: Expected to see output, because the task is not silent")
|
require.NotEmpty(t, buff.String(), "chWhile running atty: Expected to see output, because the task is not silent")
|
||||||
|
|
||||||
@ -2078,42 +2078,42 @@ func TestSilence(t *testing.T) {
|
|||||||
|
|
||||||
// Then test invoking the two task from other tasks.
|
// Then test invoking the two task from other tasks.
|
||||||
// A silenced task that calls a chatty task.
|
// A silenced task that calls a chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-silent-calls-chatty-non-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-silent-calls-chatty-non-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NotEmpty(t, buff.String(), "While running task-test-silent-calls-chatty-non-silenced: Expected to see output. The task is silenced, but the called task is not. Silence does not propagate to called tasks.")
|
require.NotEmpty(t, buff.String(), "While running task-test-silent-calls-chatty-non-silenced: Expected to see output. The task is silenced, but the called task is not. Silence does not propagate to called tasks.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A silent task that does a silent call to a chatty task.
|
// A silent task that does a silent call to a chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-silent-calls-chatty-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-silent-calls-chatty-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, buff.String(), "While running task-test-silent-calls-chatty-silenced: Expected not to see output. The task calls chatty task, but the call is silenced.")
|
require.Empty(t, buff.String(), "While running task-test-silent-calls-chatty-silenced: Expected not to see output. The task calls chatty task, but the call is silenced.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A chatty task that does a call to a chatty task.
|
// A chatty task that does a call to a chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-chatty-calls-chatty-non-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-chatty-calls-chatty-non-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NotEmpty(t, buff.String(), "While running task-test-chatty-calls-chatty-non-silenced: Expected to see output. Both caller and callee are chatty and not silenced.")
|
require.NotEmpty(t, buff.String(), "While running task-test-chatty-calls-chatty-non-silenced: Expected to see output. Both caller and callee are chatty and not silenced.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A chatty task that does a silenced call to a chatty task.
|
// A chatty task that does a silenced call to a chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-chatty-calls-chatty-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-chatty-calls-chatty-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NotEmpty(t, buff.String(), "While running task-test-chatty-calls-chatty-silenced: Expected to see output. Call to a chatty task is silenced, but the parent task is not.")
|
require.NotEmpty(t, buff.String(), "While running task-test-chatty-calls-chatty-silenced: Expected to see output. Call to a chatty task is silenced, but the parent task is not.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A chatty task with no cmd's of its own that does a silenced call to a chatty task.
|
// A chatty task with no cmd's of its own that does a silenced call to a chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-no-cmds-calls-chatty-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-no-cmds-calls-chatty-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, buff.String(), "While running task-test-no-cmds-calls-chatty-silenced: Expected not to see output. While the task itself is not silenced, it does not have any cmds and only does an invocation of a silenced task.")
|
require.Empty(t, buff.String(), "While running task-test-no-cmds-calls-chatty-silenced: Expected not to see output. While the task itself is not silenced, it does not have any cmds and only does an invocation of a silenced task.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A chatty task that does a silenced invocation of a task.
|
// A chatty task that does a silenced invocation of a task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-chatty-calls-silenced-cmd"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-chatty-calls-silenced-cmd"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, buff.String(), "While running task-test-chatty-calls-silenced-cmd: Expected not to see output. While the task itself is not silenced, its call to the chatty task is silent.")
|
require.Empty(t, buff.String(), "While running task-test-chatty-calls-silenced-cmd: Expected not to see output. While the task itself is not silenced, its call to the chatty task is silent.")
|
||||||
|
|
||||||
@ -2121,21 +2121,21 @@ func TestSilence(t *testing.T) {
|
|||||||
|
|
||||||
// Then test calls via dependencies.
|
// Then test calls via dependencies.
|
||||||
// A silent task that depends on a chatty task.
|
// A silent task that depends on a chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-is-silent-depends-on-chatty-non-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-is-silent-depends-on-chatty-non-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.NotEmpty(t, buff.String(), "While running task-test-is-silent-depends-on-chatty-non-silenced: Expected to see output. The task is silent and depends on a chatty task. Dependencies does not inherit silence.")
|
require.NotEmpty(t, buff.String(), "While running task-test-is-silent-depends-on-chatty-non-silenced: Expected to see output. The task is silent and depends on a chatty task. Dependencies does not inherit silence.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A silent task that depends on a silenced chatty task.
|
// A silent task that depends on a silenced chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-is-silent-depends-on-chatty-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-is-silent-depends-on-chatty-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, buff.String(), "While running task-test-is-silent-depends-on-chatty-silenced: Expected not to see output. The task is silent and has a silenced dependency on a chatty task.")
|
require.Empty(t, buff.String(), "While running task-test-is-silent-depends-on-chatty-silenced: Expected not to see output. The task is silent and has a silenced dependency on a chatty task.")
|
||||||
|
|
||||||
buff.Reset()
|
buff.Reset()
|
||||||
|
|
||||||
// A chatty task that, depends on a silenced chatty task.
|
// A chatty task that, depends on a silenced chatty task.
|
||||||
err = e.Run(context.Background(), taskfile.Call{Task: "task-test-is-chatty-depends-on-chatty-silenced"})
|
err = e.Run(context.Background(), ast.Call{Task: "task-test-is-chatty-depends-on-chatty-silenced"})
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
require.Empty(t, buff.String(), "While running task-test-is-chatty-depends-on-chatty-silenced: Expected not to see output. The task is chatty but does not have commands and has a silenced dependency on a chatty task.")
|
require.Empty(t, buff.String(), "While running task-test-is-chatty-depends-on-chatty-silenced: Expected not to see output. The task is chatty but does not have commands and has a silenced dependency on a chatty task.")
|
||||||
|
|
||||||
@ -2183,7 +2183,7 @@ func TestForce(t *testing.T) {
|
|||||||
ForceAll: tt.forceAll,
|
ForceAll: tt.forceAll,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: "task-with-dep", Direct: true}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: "task-with-dep", Direct: true}))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2238,7 +2238,7 @@ func TestFor(t *testing.T) {
|
|||||||
Force: true,
|
Force: true,
|
||||||
}
|
}
|
||||||
require.NoError(t, e.Setup())
|
require.NoError(t, e.Setup())
|
||||||
require.NoError(t, e.Run(context.Background(), taskfile.Call{Task: test.name, Direct: true}))
|
require.NoError(t, e.Run(context.Background(), ast.Call{Task: test.name, Direct: true}))
|
||||||
assert.Equal(t, test.expectedOutput, buff.String())
|
assert.Equal(t, test.expectedOutput, buff.String())
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
// Call is the parameters to a task call
|
// Call is the parameters to a task call
|
||||||
type Call struct {
|
type Call struct {
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
type Location struct {
|
type Location struct {
|
||||||
Line int
|
Line int
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile_test
|
package ast_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
@ -7,7 +7,7 @@ import (
|
|||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
"gopkg.in/yaml.v3"
|
"gopkg.in/yaml.v3"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestPreconditionParse(t *testing.T) {
|
func TestPreconditionParse(t *testing.T) {
|
||||||
@ -18,29 +18,29 @@ func TestPreconditionParse(t *testing.T) {
|
|||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
"test -f foo.txt",
|
"test -f foo.txt",
|
||||||
&taskfile.Precondition{},
|
&ast.Precondition{},
|
||||||
&taskfile.Precondition{Sh: `test -f foo.txt`, Msg: "`test -f foo.txt` failed"},
|
&ast.Precondition{Sh: `test -f foo.txt`, Msg: "`test -f foo.txt` failed"},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"sh: '[ 1 = 0 ]'",
|
"sh: '[ 1 = 0 ]'",
|
||||||
&taskfile.Precondition{},
|
&ast.Precondition{},
|
||||||
&taskfile.Precondition{Sh: "[ 1 = 0 ]", Msg: "[ 1 = 0 ] failed"},
|
&ast.Precondition{Sh: "[ 1 = 0 ]", Msg: "[ 1 = 0 ] failed"},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`
|
`
|
||||||
sh: "[ 1 = 2 ]"
|
sh: "[ 1 = 2 ]"
|
||||||
msg: "1 is not 2"
|
msg: "1 is not 2"
|
||||||
`,
|
`,
|
||||||
&taskfile.Precondition{},
|
&ast.Precondition{},
|
||||||
&taskfile.Precondition{Sh: "[ 1 = 2 ]", Msg: "1 is not 2"},
|
&ast.Precondition{Sh: "[ 1 = 2 ]", Msg: "1 is not 2"},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
`
|
`
|
||||||
sh: "[ 1 = 2 ]"
|
sh: "[ 1 = 2 ]"
|
||||||
msg: "1 is not 2"
|
msg: "1 is not 2"
|
||||||
`,
|
`,
|
||||||
&taskfile.Precondition{},
|
&ast.Precondition{},
|
||||||
&taskfile.Precondition{Sh: "[ 1 = 2 ]", Msg: "1 is not 2"},
|
&ast.Precondition{Sh: "[ 1 = 2 ]", Msg: "1 is not 2"},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import "github.com/go-task/task/v3/internal/deepcopy"
|
import "github.com/go-task/task/v3/internal/deepcopy"
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
@ -12,7 +12,7 @@ import (
|
|||||||
|
|
||||||
var V3 = semver.MustParse("3")
|
var V3 = semver.MustParse("3")
|
||||||
|
|
||||||
// Taskfile represents a Taskfile.yml
|
// Taskfile is the abstract syntax tree for a Taskfile
|
||||||
type Taskfile struct {
|
type Taskfile struct {
|
||||||
Location string
|
Location string
|
||||||
Version *semver.Version
|
Version *semver.Version
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile_test
|
package ast_test
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
@ -8,7 +8,7 @@ import (
|
|||||||
"gopkg.in/yaml.v3"
|
"gopkg.in/yaml.v3"
|
||||||
|
|
||||||
"github.com/go-task/task/v3/internal/orderedmap"
|
"github.com/go-task/task/v3/internal/orderedmap"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestCmdParse(t *testing.T) {
|
func TestCmdParse(t *testing.T) {
|
||||||
@ -31,16 +31,16 @@ vars:
|
|||||||
}{
|
}{
|
||||||
{
|
{
|
||||||
yamlCmd,
|
yamlCmd,
|
||||||
&taskfile.Cmd{},
|
&ast.Cmd{},
|
||||||
&taskfile.Cmd{Cmd: `echo "a string command"`},
|
&ast.Cmd{Cmd: `echo "a string command"`},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
yamlTaskCall,
|
yamlTaskCall,
|
||||||
&taskfile.Cmd{},
|
&ast.Cmd{},
|
||||||
&taskfile.Cmd{
|
&ast.Cmd{
|
||||||
Task: "another-task", Vars: &taskfile.Vars{
|
Task: "another-task", Vars: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"PARAM1": {Value: "VALUE1"},
|
"PARAM1": {Value: "VALUE1"},
|
||||||
"PARAM2": {Value: "VALUE2"},
|
"PARAM2": {Value: "VALUE2"},
|
||||||
},
|
},
|
||||||
@ -51,16 +51,16 @@ vars:
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
yamlDeferredCmd,
|
yamlDeferredCmd,
|
||||||
&taskfile.Cmd{},
|
&ast.Cmd{},
|
||||||
&taskfile.Cmd{Cmd: "echo 'test'", Defer: true},
|
&ast.Cmd{Cmd: "echo 'test'", Defer: true},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
yamlDeferredCall,
|
yamlDeferredCall,
|
||||||
&taskfile.Cmd{},
|
&ast.Cmd{},
|
||||||
&taskfile.Cmd{
|
&ast.Cmd{
|
||||||
Task: "some_task", Vars: &taskfile.Vars{
|
Task: "some_task", Vars: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"PARAM1": {Value: "var"},
|
"PARAM1": {Value: "var"},
|
||||||
},
|
},
|
||||||
[]string{"PARAM1"},
|
[]string{"PARAM1"},
|
||||||
@ -71,16 +71,16 @@ vars:
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
yamlDep,
|
yamlDep,
|
||||||
&taskfile.Dep{},
|
&ast.Dep{},
|
||||||
&taskfile.Dep{Task: "task-name"},
|
&ast.Dep{Task: "task-name"},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
yamlTaskCall,
|
yamlTaskCall,
|
||||||
&taskfile.Dep{},
|
&ast.Dep{},
|
||||||
&taskfile.Dep{
|
&ast.Dep{
|
||||||
Task: "another-task", Vars: &taskfile.Vars{
|
Task: "another-task", Vars: &ast.Vars{
|
||||||
OrderedMap: orderedmap.FromMapWithOrder(
|
OrderedMap: orderedmap.FromMapWithOrder(
|
||||||
map[string]taskfile.Var{
|
map[string]ast.Var{
|
||||||
"PARAM1": {Value: "VALUE1"},
|
"PARAM1": {Value: "VALUE1"},
|
||||||
"PARAM2": {Value: "VALUE2"},
|
"PARAM2": {Value: "VALUE2"},
|
||||||
},
|
},
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package taskfile
|
package ast
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/sha256"
|
"crypto/sha256"
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
@ -8,10 +8,10 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/compiler"
|
"github.com/go-task/task/v3/internal/compiler"
|
||||||
"github.com/go-task/task/v3/internal/filepathext"
|
"github.com/go-task/task/v3/internal/filepathext"
|
||||||
"github.com/go-task/task/v3/internal/templater"
|
"github.com/go-task/task/v3/internal/templater"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Dotenv(c *compiler.Compiler, tf *taskfile.Taskfile, dir string) (*taskfile.Vars, error) {
|
func Dotenv(c *compiler.Compiler, tf *ast.Taskfile, dir string) (*ast.Vars, error) {
|
||||||
if len(tf.Dotenv) == 0 {
|
if len(tf.Dotenv) == 0 {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
@ -21,7 +21,7 @@ func Dotenv(c *compiler.Compiler, tf *taskfile.Taskfile, dir string) (*taskfile.
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
env := &taskfile.Vars{}
|
env := &ast.Vars{}
|
||||||
|
|
||||||
tr := templater.Templater{Vars: vars}
|
tr := templater.Templater{Vars: vars}
|
||||||
|
|
||||||
@ -42,7 +42,7 @@ func Dotenv(c *compiler.Compiler, tf *taskfile.Taskfile, dir string) (*taskfile.
|
|||||||
}
|
}
|
||||||
for key, value := range envs {
|
for key, value := range envs {
|
||||||
if ok := env.Exists(key); !ok {
|
if ok := env.Exists(key); !ok {
|
||||||
env.Set(key, taskfile.Var{Value: value})
|
env.Set(key, ast.Var{Value: value})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -3,13 +3,15 @@ package taskfile
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// NamespaceSeparator contains the character that separates namespaces
|
// NamespaceSeparator contains the character that separates namespaces
|
||||||
const NamespaceSeparator = ":"
|
const NamespaceSeparator = ":"
|
||||||
|
|
||||||
// Merge merges the second Taskfile into the first
|
// Merge merges the second Taskfile into the first
|
||||||
func Merge(t1, t2 *Taskfile, includedTaskfile *IncludedTaskfile, namespaces ...string) error {
|
func Merge(t1, t2 *ast.Taskfile, includedTaskfile *ast.IncludedTaskfile, namespaces ...string) error {
|
||||||
if !t1.Version.Equal(t2.Version) {
|
if !t1.Version.Equal(t2.Version) {
|
||||||
return fmt.Errorf(`task: Taskfiles versions should match. First is "%s" but second is "%s"`, t1.Version, t2.Version)
|
return fmt.Errorf(`task: Taskfiles versions should match. First is "%s" but second is "%s"`, t1.Version, t2.Version)
|
||||||
}
|
}
|
||||||
@ -18,15 +20,15 @@ func Merge(t1, t2 *Taskfile, includedTaskfile *IncludedTaskfile, namespaces ...s
|
|||||||
}
|
}
|
||||||
|
|
||||||
if t1.Vars == nil {
|
if t1.Vars == nil {
|
||||||
t1.Vars = &Vars{}
|
t1.Vars = &ast.Vars{}
|
||||||
}
|
}
|
||||||
if t1.Env == nil {
|
if t1.Env == nil {
|
||||||
t1.Env = &Vars{}
|
t1.Env = &ast.Vars{}
|
||||||
}
|
}
|
||||||
t1.Vars.Merge(t2.Vars)
|
t1.Vars.Merge(t2.Vars)
|
||||||
t1.Env.Merge(t2.Env)
|
t1.Env.Merge(t2.Env)
|
||||||
|
|
||||||
return t2.Tasks.Range(func(k string, v *Task) error {
|
return t2.Tasks.Range(func(k string, v *ast.Task) error {
|
||||||
// We do a deep copy of the task struct here to ensure that no data can
|
// We do a deep copy of the task struct here to ensure that no data can
|
||||||
// be changed elsewhere once the taskfile is merged.
|
// be changed elsewhere once the taskfile is merged.
|
||||||
task := v.DeepCopy()
|
task := v.DeepCopy()
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
@ -31,7 +31,7 @@ func NewNode(
|
|||||||
node, err = NewFileNode(uri, opts...)
|
node, err = NewFileNode(uri, opts...)
|
||||||
}
|
}
|
||||||
if node.Remote() && !experiments.RemoteTaskfiles {
|
if node.Remote() && !experiments.RemoteTaskfiles {
|
||||||
return nil, errors.New("task: Remote taskfiles are not enabled. You can read more about this experiment and how to enable it at https://taskfile.dev/experiments/remote-taskfiles")
|
return nil, errors.New("task: Remote taskfiles are not enabled. You can read more about this experiment and how to enable it at https://ast.dev/experiments/remote-taskfiles")
|
||||||
}
|
}
|
||||||
return node, err
|
return node, err
|
||||||
}
|
}
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
type (
|
type (
|
||||||
NodeOption func(*BaseNode)
|
NodeOption func(*BaseNode)
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
@ -1,4 +1,4 @@
|
|||||||
package read
|
package taskfile
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
@ -14,7 +14,7 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/internal/sysinfo"
|
"github.com/go-task/task/v3/internal/sysinfo"
|
||||||
"github.com/go-task/task/v3/internal/templater"
|
"github.com/go-task/task/v3/internal/templater"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -40,7 +40,7 @@ func readTaskfile(
|
|||||||
timeout time.Duration,
|
timeout time.Duration,
|
||||||
tempDir string,
|
tempDir string,
|
||||||
l *logger.Logger,
|
l *logger.Logger,
|
||||||
) (*taskfile.Taskfile, error) {
|
) (*ast.Taskfile, error) {
|
||||||
var b []byte
|
var b []byte
|
||||||
var err error
|
var err error
|
||||||
var cache *Cache
|
var cache *Cache
|
||||||
@ -127,7 +127,7 @@ func readTaskfile(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var t taskfile.Taskfile
|
var t ast.Taskfile
|
||||||
if err := yaml.Unmarshal(b, &t); err != nil {
|
if err := yaml.Unmarshal(b, &t); err != nil {
|
||||||
return nil, &errors.TaskfileInvalidError{URI: filepathext.TryAbsToRel(node.Location()), Err: err}
|
return nil, &errors.TaskfileInvalidError{URI: filepathext.TryAbsToRel(node.Location()), Err: err}
|
||||||
}
|
}
|
||||||
@ -136,10 +136,10 @@ func readTaskfile(
|
|||||||
return &t, nil
|
return &t, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Taskfile reads a Taskfile for a given directory
|
// Read reads a Read for a given directory
|
||||||
// Uses current dir when dir is left empty. Uses Taskfile.yml
|
// Uses current dir when dir is left empty. Uses Read.yml
|
||||||
// or Taskfile.yaml when entrypoint is left empty
|
// or Read.yaml when entrypoint is left empty
|
||||||
func Taskfile(
|
func Read(
|
||||||
node Node,
|
node Node,
|
||||||
insecure bool,
|
insecure bool,
|
||||||
download bool,
|
download bool,
|
||||||
@ -147,9 +147,9 @@ func Taskfile(
|
|||||||
timeout time.Duration,
|
timeout time.Duration,
|
||||||
tempDir string,
|
tempDir string,
|
||||||
l *logger.Logger,
|
l *logger.Logger,
|
||||||
) (*taskfile.Taskfile, error) {
|
) (*ast.Taskfile, error) {
|
||||||
var _taskfile func(Node) (*taskfile.Taskfile, error)
|
var _taskfile func(Node) (*ast.Taskfile, error)
|
||||||
_taskfile = func(node Node) (*taskfile.Taskfile, error) {
|
_taskfile = func(node Node) (*ast.Taskfile, error) {
|
||||||
t, err := readTaskfile(node, download, offline, timeout, tempDir, l)
|
t, err := readTaskfile(node, download, offline, timeout, tempDir, l)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -162,7 +162,7 @@ func Taskfile(
|
|||||||
|
|
||||||
// Annotate any included Taskfile reference with a base directory for resolving relative paths
|
// Annotate any included Taskfile reference with a base directory for resolving relative paths
|
||||||
if node, isFileNode := node.(*FileNode); isFileNode {
|
if node, isFileNode := node.(*FileNode); isFileNode {
|
||||||
_ = t.Includes.Range(func(key string, includedFile taskfile.IncludedTaskfile) error {
|
_ = t.Includes.Range(func(key string, includedFile ast.IncludedTaskfile) error {
|
||||||
// Set the base directory for resolving relative paths, but only if not already set
|
// Set the base directory for resolving relative paths, but only if not already set
|
||||||
if includedFile.BaseDir == "" {
|
if includedFile.BaseDir == "" {
|
||||||
includedFile.BaseDir = node.Dir
|
includedFile.BaseDir = node.Dir
|
||||||
@ -172,9 +172,9 @@ func Taskfile(
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
err = t.Includes.Range(func(namespace string, includedTask taskfile.IncludedTaskfile) error {
|
err = t.Includes.Range(func(namespace string, includedTask ast.IncludedTaskfile) error {
|
||||||
tr := templater.Templater{Vars: t.Vars}
|
tr := templater.Templater{Vars: t.Vars}
|
||||||
includedTask = taskfile.IncludedTaskfile{
|
includedTask = ast.IncludedTaskfile{
|
||||||
Taskfile: tr.Replace(includedTask.Taskfile),
|
Taskfile: tr.Replace(includedTask.Taskfile),
|
||||||
Dir: tr.Replace(includedTask.Dir),
|
Dir: tr.Replace(includedTask.Dir),
|
||||||
Optional: includedTask.Optional,
|
Optional: includedTask.Optional,
|
||||||
@ -227,14 +227,14 @@ func Taskfile(
|
|||||||
}
|
}
|
||||||
|
|
||||||
// nolint: errcheck
|
// nolint: errcheck
|
||||||
includedTaskfile.Vars.Range(func(k string, v taskfile.Var) error {
|
includedTaskfile.Vars.Range(func(k string, v ast.Var) error {
|
||||||
o := v
|
o := v
|
||||||
o.Dir = dir
|
o.Dir = dir
|
||||||
includedTaskfile.Vars.Set(k, o)
|
includedTaskfile.Vars.Set(k, o)
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
// nolint: errcheck
|
// nolint: errcheck
|
||||||
includedTaskfile.Env.Range(func(k string, v taskfile.Var) error {
|
includedTaskfile.Env.Range(func(k string, v ast.Var) error {
|
||||||
o := v
|
o := v
|
||||||
o.Dir = dir
|
o.Dir = dir
|
||||||
includedTaskfile.Env.Set(k, o)
|
includedTaskfile.Env.Set(k, o)
|
||||||
@ -244,7 +244,7 @@ func Taskfile(
|
|||||||
for _, task := range includedTaskfile.Tasks.Values() {
|
for _, task := range includedTaskfile.Tasks.Values() {
|
||||||
task.Dir = filepathext.SmartJoin(dir, task.Dir)
|
task.Dir = filepathext.SmartJoin(dir, task.Dir)
|
||||||
if task.IncludeVars == nil {
|
if task.IncludeVars == nil {
|
||||||
task.IncludeVars = &taskfile.Vars{}
|
task.IncludeVars = &ast.Vars{}
|
||||||
}
|
}
|
||||||
task.IncludeVars.Merge(includedTask.Vars)
|
task.IncludeVars.Merge(includedTask.Vars)
|
||||||
task.IncludedTaskfileVars = includedTaskfile.Vars
|
task.IncludedTaskfileVars = includedTaskfile.Vars
|
||||||
@ -252,7 +252,7 @@ func Taskfile(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if err = taskfile.Merge(t, includedTaskfile, &includedTask, namespace); err != nil {
|
if err = Merge(t, includedTaskfile, &includedTask, namespace); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -273,7 +273,7 @@ func Taskfile(
|
|||||||
for _, task := range t.Tasks.Values() {
|
for _, task := range t.Tasks.Values() {
|
||||||
// If the task is not defined, create a new one
|
// If the task is not defined, create a new one
|
||||||
if task == nil {
|
if task == nil {
|
||||||
task = &taskfile.Task{}
|
task = &ast.Task{}
|
||||||
}
|
}
|
||||||
// Set the location of the taskfile for each task
|
// Set the location of the taskfile for each task
|
||||||
if task.Location.Taskfile == "" {
|
if task.Location.Taskfile == "" {
|
40
variables.go
40
variables.go
@ -12,27 +12,27 @@ import (
|
|||||||
"github.com/go-task/task/v3/internal/filepathext"
|
"github.com/go-task/task/v3/internal/filepathext"
|
||||||
"github.com/go-task/task/v3/internal/fingerprint"
|
"github.com/go-task/task/v3/internal/fingerprint"
|
||||||
"github.com/go-task/task/v3/internal/templater"
|
"github.com/go-task/task/v3/internal/templater"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
// CompiledTask returns a copy of a task, but replacing variables in almost all
|
// CompiledTask returns a copy of a task, but replacing variables in almost all
|
||||||
// properties using the Go template package.
|
// properties using the Go template package.
|
||||||
func (e *Executor) CompiledTask(call taskfile.Call) (*taskfile.Task, error) {
|
func (e *Executor) CompiledTask(call ast.Call) (*ast.Task, error) {
|
||||||
return e.compiledTask(call, true)
|
return e.compiledTask(call, true)
|
||||||
}
|
}
|
||||||
|
|
||||||
// FastCompiledTask is like CompiledTask, but it skippes dynamic variables.
|
// FastCompiledTask is like CompiledTask, but it skippes dynamic variables.
|
||||||
func (e *Executor) FastCompiledTask(call taskfile.Call) (*taskfile.Task, error) {
|
func (e *Executor) FastCompiledTask(call ast.Call) (*ast.Task, error) {
|
||||||
return e.compiledTask(call, false)
|
return e.compiledTask(call, false)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskfile.Task, error) {
|
func (e *Executor) compiledTask(call ast.Call, evaluateShVars bool) (*ast.Task, error) {
|
||||||
origTask, err := e.GetTask(call)
|
origTask, err := e.GetTask(call)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
var vars *taskfile.Vars
|
var vars *ast.Vars
|
||||||
if evaluateShVars {
|
if evaluateShVars {
|
||||||
vars, err = e.Compiler.GetVariables(origTask, call)
|
vars, err = e.Compiler.GetVariables(origTask, call)
|
||||||
} else {
|
} else {
|
||||||
@ -44,7 +44,7 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
|
|
||||||
r := templater.Templater{Vars: vars}
|
r := templater.Templater{Vars: vars}
|
||||||
|
|
||||||
new := taskfile.Task{
|
new := ast.Task{
|
||||||
Task: origTask.Task,
|
Task: origTask.Task,
|
||||||
Label: r.Replace(origTask.Label),
|
Label: r.Replace(origTask.Label),
|
||||||
Desc: r.Replace(origTask.Desc),
|
Desc: r.Replace(origTask.Desc),
|
||||||
@ -84,7 +84,7 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
new.Prefix = new.Task
|
new.Prefix = new.Task
|
||||||
}
|
}
|
||||||
|
|
||||||
dotenvEnvs := &taskfile.Vars{}
|
dotenvEnvs := &ast.Vars{}
|
||||||
if len(new.Dotenv) > 0 {
|
if len(new.Dotenv) > 0 {
|
||||||
for _, dotEnvPath := range new.Dotenv {
|
for _, dotEnvPath := range new.Dotenv {
|
||||||
dotEnvPath = filepathext.SmartJoin(new.Dir, dotEnvPath)
|
dotEnvPath = filepathext.SmartJoin(new.Dir, dotEnvPath)
|
||||||
@ -97,28 +97,28 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
}
|
}
|
||||||
for key, value := range envs {
|
for key, value := range envs {
|
||||||
if ok := dotenvEnvs.Exists(key); !ok {
|
if ok := dotenvEnvs.Exists(key); !ok {
|
||||||
dotenvEnvs.Set(key, taskfile.Var{Value: value})
|
dotenvEnvs.Set(key, ast.Var{Value: value})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
new.Env = &taskfile.Vars{}
|
new.Env = &ast.Vars{}
|
||||||
new.Env.Merge(r.ReplaceVars(e.Taskfile.Env))
|
new.Env.Merge(r.ReplaceVars(e.Taskfile.Env))
|
||||||
new.Env.Merge(r.ReplaceVars(dotenvEnvs))
|
new.Env.Merge(r.ReplaceVars(dotenvEnvs))
|
||||||
new.Env.Merge(r.ReplaceVars(origTask.Env))
|
new.Env.Merge(r.ReplaceVars(origTask.Env))
|
||||||
if evaluateShVars {
|
if evaluateShVars {
|
||||||
err = new.Env.Range(func(k string, v taskfile.Var) error {
|
err = new.Env.Range(func(k string, v ast.Var) error {
|
||||||
// If the variable is not dynamic, we can set it and return
|
// If the variable is not dynamic, we can set it and return
|
||||||
if v.Value != nil || v.Sh == "" {
|
if v.Value != nil || v.Sh == "" {
|
||||||
new.Env.Set(k, taskfile.Var{Value: v.Value})
|
new.Env.Set(k, ast.Var{Value: v.Value})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
static, err := e.Compiler.HandleDynamicVar(v, new.Dir)
|
static, err := e.Compiler.HandleDynamicVar(v, new.Dir)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
new.Env.Set(k, taskfile.Var{Value: static})
|
new.Env.Set(k, ast.Var{Value: static})
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -127,7 +127,7 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
}
|
}
|
||||||
|
|
||||||
if len(origTask.Cmds) > 0 {
|
if len(origTask.Cmds) > 0 {
|
||||||
new.Cmds = make([]*taskfile.Cmd, 0, len(origTask.Cmds))
|
new.Cmds = make([]*ast.Cmd, 0, len(origTask.Cmds))
|
||||||
for _, cmd := range origTask.Cmds {
|
for _, cmd := range origTask.Cmds {
|
||||||
if cmd == nil {
|
if cmd == nil {
|
||||||
continue
|
continue
|
||||||
@ -199,7 +199,7 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
if len(keys) > 0 {
|
if len(keys) > 0 {
|
||||||
extra["KEY"] = keys[i]
|
extra["KEY"] = keys[i]
|
||||||
}
|
}
|
||||||
new.Cmds = append(new.Cmds, &taskfile.Cmd{
|
new.Cmds = append(new.Cmds, &ast.Cmd{
|
||||||
Cmd: r.ReplaceWithExtra(cmd.Cmd, extra),
|
Cmd: r.ReplaceWithExtra(cmd.Cmd, extra),
|
||||||
Task: r.ReplaceWithExtra(cmd.Task, extra),
|
Task: r.ReplaceWithExtra(cmd.Task, extra),
|
||||||
Silent: cmd.Silent,
|
Silent: cmd.Silent,
|
||||||
@ -213,7 +213,7 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
}
|
}
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
new.Cmds = append(new.Cmds, &taskfile.Cmd{
|
new.Cmds = append(new.Cmds, &ast.Cmd{
|
||||||
Cmd: r.Replace(cmd.Cmd),
|
Cmd: r.Replace(cmd.Cmd),
|
||||||
Task: r.Replace(cmd.Task),
|
Task: r.Replace(cmd.Task),
|
||||||
Silent: cmd.Silent,
|
Silent: cmd.Silent,
|
||||||
@ -227,12 +227,12 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if len(origTask.Deps) > 0 {
|
if len(origTask.Deps) > 0 {
|
||||||
new.Deps = make([]*taskfile.Dep, 0, len(origTask.Deps))
|
new.Deps = make([]*ast.Dep, 0, len(origTask.Deps))
|
||||||
for _, dep := range origTask.Deps {
|
for _, dep := range origTask.Deps {
|
||||||
if dep == nil {
|
if dep == nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
new.Deps = append(new.Deps, &taskfile.Dep{
|
new.Deps = append(new.Deps, &ast.Dep{
|
||||||
Task: r.Replace(dep.Task),
|
Task: r.Replace(dep.Task),
|
||||||
Vars: r.ReplaceVars(dep.Vars),
|
Vars: r.ReplaceVars(dep.Vars),
|
||||||
Silent: dep.Silent,
|
Silent: dep.Silent,
|
||||||
@ -241,12 +241,12 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
}
|
}
|
||||||
|
|
||||||
if len(origTask.Preconditions) > 0 {
|
if len(origTask.Preconditions) > 0 {
|
||||||
new.Preconditions = make([]*taskfile.Precondition, 0, len(origTask.Preconditions))
|
new.Preconditions = make([]*ast.Precondition, 0, len(origTask.Preconditions))
|
||||||
for _, precond := range origTask.Preconditions {
|
for _, precond := range origTask.Preconditions {
|
||||||
if precond == nil {
|
if precond == nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
new.Preconditions = append(new.Preconditions, &taskfile.Precondition{
|
new.Preconditions = append(new.Preconditions, &ast.Precondition{
|
||||||
Sh: r.Replace(precond.Sh),
|
Sh: r.Replace(precond.Sh),
|
||||||
Msg: r.Replace(precond.Msg),
|
Msg: r.Replace(precond.Msg),
|
||||||
})
|
})
|
||||||
@ -262,7 +262,7 @@ func (e *Executor) compiledTask(call taskfile.Call, evaluateShVars bool) (*taskf
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
vars.Set(strings.ToUpper(checker.Kind()), taskfile.Var{Live: value})
|
vars.Set(strings.ToUpper(checker.Kind()), ast.Var{Live: value})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Adding new variables, requires us to refresh the templaters
|
// Adding new variables, requires us to refresh the templaters
|
||||||
|
14
watch.go
14
watch.go
@ -15,13 +15,13 @@ import (
|
|||||||
"github.com/go-task/task/v3/errors"
|
"github.com/go-task/task/v3/errors"
|
||||||
"github.com/go-task/task/v3/internal/fingerprint"
|
"github.com/go-task/task/v3/internal/fingerprint"
|
||||||
"github.com/go-task/task/v3/internal/logger"
|
"github.com/go-task/task/v3/internal/logger"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
const defaultWatchInterval = 5 * time.Second
|
const defaultWatchInterval = 5 * time.Second
|
||||||
|
|
||||||
// watchTasks start watching the given tasks
|
// watchTasks start watching the given tasks
|
||||||
func (e *Executor) watchTasks(calls ...taskfile.Call) error {
|
func (e *Executor) watchTasks(calls ...ast.Call) error {
|
||||||
tasks := make([]string, len(calls))
|
tasks := make([]string, len(calls))
|
||||||
for i, c := range calls {
|
for i, c := range calls {
|
||||||
tasks[i] = c.Task
|
tasks[i] = c.Task
|
||||||
@ -119,24 +119,24 @@ func closeOnInterrupt(w *watcher.Watcher) {
|
|||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (e *Executor) registerWatchedFiles(w *watcher.Watcher, calls ...taskfile.Call) error {
|
func (e *Executor) registerWatchedFiles(w *watcher.Watcher, calls ...ast.Call) error {
|
||||||
watchedFiles := w.WatchedFiles()
|
watchedFiles := w.WatchedFiles()
|
||||||
|
|
||||||
var registerTaskFiles func(taskfile.Call) error
|
var registerTaskFiles func(ast.Call) error
|
||||||
registerTaskFiles = func(c taskfile.Call) error {
|
registerTaskFiles = func(c ast.Call) error {
|
||||||
task, err := e.CompiledTask(c)
|
task, err := e.CompiledTask(c)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, d := range task.Deps {
|
for _, d := range task.Deps {
|
||||||
if err := registerTaskFiles(taskfile.Call{Task: d.Task, Vars: d.Vars}); err != nil {
|
if err := registerTaskFiles(ast.Call{Task: d.Task, Vars: d.Vars}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for _, c := range task.Cmds {
|
for _, c := range task.Cmds {
|
||||||
if c.Task != "" {
|
if c.Task != "" {
|
||||||
if err := registerTaskFiles(taskfile.Call{Task: c.Task, Vars: c.Vars}); err != nil {
|
if err := registerTaskFiles(ast.Call{Task: c.Task, Vars: c.Vars}); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,7 @@ import (
|
|||||||
|
|
||||||
"github.com/go-task/task/v3"
|
"github.com/go-task/task/v3"
|
||||||
"github.com/go-task/task/v3/internal/filepathext"
|
"github.com/go-task/task/v3/internal/filepathext"
|
||||||
"github.com/go-task/task/v3/taskfile"
|
"github.com/go-task/task/v3/taskfile/ast"
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestFileWatcherInterval(t *testing.T) {
|
func TestFileWatcherInterval(t *testing.T) {
|
||||||
@ -58,7 +58,7 @@ Hello, World!
|
|||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
return
|
return
|
||||||
default:
|
default:
|
||||||
err := e.Run(ctx, taskfile.Call{Task: "default"})
|
err := e.Run(ctx, ast.Task: "default"})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user