mirror of
https://github.com/go-task/task.git
synced 2025-06-17 00:17:51 +02:00
Merge pull request #831 from ilewin/check_path_for_symlinks_issue_826
Attempt to fix Task not following symlinks
This commit is contained in:
@ -32,7 +32,7 @@ func Glob(dir string, g string) ([]string, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
fs, err := zglob.Glob(g)
|
fs, err := zglob.GlobFollowSymlinks(g)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
33
task_test.go
33
task_test.go
@ -1338,3 +1338,36 @@ func TestErrorCode(t *testing.T) {
|
|||||||
assert.True(t, ok, "cannot cast returned error to *task.TaskRunError")
|
assert.True(t, ok, "cannot cast returned error to *task.TaskRunError")
|
||||||
assert.Equal(t, 42, casted.ExitCode(), "unexpected exit code from task")
|
assert.Equal(t, 42, casted.ExitCode(), "unexpected exit code from task")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestEvaluateSymlinksInPaths(t *testing.T) {
|
||||||
|
const dir = "testdata/evaluate_symlinks_in_paths"
|
||||||
|
var buff bytes.Buffer
|
||||||
|
e := &task.Executor{
|
||||||
|
Dir: dir,
|
||||||
|
Stdout: &buff,
|
||||||
|
Stderr: &buff,
|
||||||
|
Silent: false,
|
||||||
|
}
|
||||||
|
assert.NoError(t, e.Setup())
|
||||||
|
err := e.Run(context.Background(), taskfile.Call{Task: "default"})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.NotEqual(t, `task: Task "default" is up to date`, strings.TrimSpace(buff.String()))
|
||||||
|
buff.Reset()
|
||||||
|
err = e.Run(context.Background(), taskfile.Call{Task: "test-sym"})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.NotEqual(t, `task: Task "test-sym" is up to date`, strings.TrimSpace(buff.String()))
|
||||||
|
buff.Reset()
|
||||||
|
err = e.Run(context.Background(), taskfile.Call{Task: "default"})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.NotEqual(t, `task: Task "default" is up to date`, strings.TrimSpace(buff.String()))
|
||||||
|
buff.Reset()
|
||||||
|
err = e.Run(context.Background(), taskfile.Call{Task: "default"})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
assert.Equal(t, `task: Task "default" is up to date`, strings.TrimSpace(buff.String()))
|
||||||
|
buff.Reset()
|
||||||
|
err = e.Run(context.Background(), taskfile.Call{Task: "reset"})
|
||||||
|
assert.NoError(t, err)
|
||||||
|
buff.Reset()
|
||||||
|
err = os.RemoveAll(dir + "/.task")
|
||||||
|
assert.NoError(t, err)
|
||||||
|
}
|
||||||
|
14
testdata/evaluate_symlinks_in_paths/Taskfile.yaml
vendored
Normal file
14
testdata/evaluate_symlinks_in_paths/Taskfile.yaml
vendored
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
version: '3'
|
||||||
|
tasks:
|
||||||
|
default:
|
||||||
|
sources:
|
||||||
|
- src/**/*
|
||||||
|
cmds:
|
||||||
|
- echo "some job"
|
||||||
|
test-sym:
|
||||||
|
cmds:
|
||||||
|
- echo "shared file source changed" > src/shared/b
|
||||||
|
reset:
|
||||||
|
cmds:
|
||||||
|
- echo "shared file source" > src/shared/b
|
||||||
|
- echo "file source" > src/a
|
1
testdata/evaluate_symlinks_in_paths/shared/b
vendored
Normal file
1
testdata/evaluate_symlinks_in_paths/shared/b
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
shared file source
|
1
testdata/evaluate_symlinks_in_paths/shared/inner_shared/c
vendored
Normal file
1
testdata/evaluate_symlinks_in_paths/shared/inner_shared/c
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
inner shared file source
|
1
testdata/evaluate_symlinks_in_paths/src/a
vendored
Normal file
1
testdata/evaluate_symlinks_in_paths/src/a
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
file source
|
1
testdata/evaluate_symlinks_in_paths/src/shared
vendored
Symbolic link
1
testdata/evaluate_symlinks_in_paths/src/shared
vendored
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
../shared
|
Reference in New Issue
Block a user