2019-05-17 13:13:47 -07:00
|
|
|
package task
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
|
2023-03-10 18:27:30 +00:00
|
|
|
"github.com/go-task/task/v3/internal/env"
|
2020-08-16 15:48:19 -03:00
|
|
|
"github.com/go-task/task/v3/internal/execext"
|
|
|
|
"github.com/go-task/task/v3/internal/logger"
|
2023-12-29 20:32:03 +00:00
|
|
|
"github.com/go-task/task/v3/taskfile/ast"
|
2019-05-17 13:13:47 -07:00
|
|
|
)
|
|
|
|
|
2023-03-31 19:13:29 +00:00
|
|
|
// ErrPreconditionFailed is returned when a precondition fails
|
|
|
|
var ErrPreconditionFailed = errors.New("task: precondition not met")
|
2019-05-17 13:13:47 -07:00
|
|
|
|
2023-12-29 20:32:03 +00:00
|
|
|
func (e *Executor) areTaskPreconditionsMet(ctx context.Context, t *ast.Task) (bool, error) {
|
2019-05-28 13:02:59 -07:00
|
|
|
for _, p := range t.Preconditions {
|
2019-05-17 13:13:47 -07:00
|
|
|
err := execext.RunCommand(ctx, &execext.RunCommandOptions{
|
|
|
|
Command: p.Sh,
|
|
|
|
Dir: t.Dir,
|
2023-03-10 18:27:30 +00:00
|
|
|
Env: env.Get(t),
|
2019-05-17 13:13:47 -07:00
|
|
|
})
|
|
|
|
if err != nil {
|
2023-10-07 15:01:57 -07:00
|
|
|
if !errors.Is(err, context.Canceled) {
|
|
|
|
e.Logger.Errf(logger.Magenta, "task: %s\n", p.Msg)
|
|
|
|
}
|
2019-05-28 13:02:59 -07:00
|
|
|
return false, ErrPreconditionFailed
|
2019-05-17 13:13:47 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true, nil
|
|
|
|
}
|