2023-03-10 18:27:30 +00:00
|
|
|
package fingerprint
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2023-04-15 21:27:14 +01:00
|
|
|
"github.com/stretchr/testify/mock"
|
2023-03-10 18:27:30 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2023-04-15 21:27:14 +01:00
|
|
|
"github.com/go-task/task/v3/internal/mocks"
|
2023-03-10 18:27:30 +00:00
|
|
|
"github.com/go-task/task/v3/taskfile"
|
|
|
|
)
|
|
|
|
|
|
|
|
// TruthTable
|
|
|
|
//
|
|
|
|
// | Status up-to-date | Sources up-to-date | Task is up-to-date |
|
|
|
|
// | ----------------- | ------------------ | ------------------ |
|
|
|
|
// | not set | not set | false |
|
|
|
|
// | not set | true | true |
|
|
|
|
// | not set | false | false |
|
|
|
|
// | true | not set | true |
|
|
|
|
// | true | true | true |
|
|
|
|
// | true | false | false |
|
|
|
|
// | false | not set | false |
|
|
|
|
// | false | true | false |
|
|
|
|
// | false | false | false |
|
|
|
|
func TestIsTaskUpToDate(t *testing.T) {
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
task *taskfile.Task
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker func(m *mocks.StatusCheckable)
|
|
|
|
setupMockSourcesChecker func(m *mocks.SourcesCheckable)
|
2023-03-10 18:27:30 +00:00
|
|
|
expected bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "expect FALSE when no status or sources are defined",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: nil,
|
|
|
|
Sources: nil,
|
|
|
|
},
|
|
|
|
setupMockStatusChecker: nil,
|
|
|
|
setupMockSourcesChecker: nil,
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect TRUE when no status is defined and sources are up-to-date",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: nil,
|
|
|
|
Sources: []string{"sources"},
|
|
|
|
},
|
|
|
|
setupMockStatusChecker: nil,
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything).Return(true, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
expected: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect FALSE when no status is defined and sources are NOT up-to-date",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: nil,
|
|
|
|
Sources: []string{"sources"},
|
|
|
|
},
|
|
|
|
setupMockStatusChecker: nil,
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything).Return(false, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect TRUE when status is up-to-date and sources are not defined",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: []string{"status"},
|
|
|
|
Sources: nil,
|
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
setupMockSourcesChecker: nil,
|
|
|
|
expected: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect TRUE when status and sources are up-to-date",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: []string{"status"},
|
|
|
|
Sources: []string{"sources"},
|
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything).Return(true, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
expected: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect FALSE when status is up-to-date, but sources are NOT up-to-date",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: []string{"status"},
|
|
|
|
Sources: []string{"sources"},
|
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(true, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything).Return(false, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect FALSE when status is NOT up-to-date and sources are not defined",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: []string{"status"},
|
|
|
|
Sources: nil,
|
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
setupMockSourcesChecker: nil,
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect FALSE when status is NOT up-to-date, but sources are up-to-date",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: []string{"status"},
|
|
|
|
Sources: []string{"sources"},
|
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything).Return(true, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "expect FALSE when status and sources are NOT up-to-date",
|
|
|
|
task: &taskfile.Task{
|
|
|
|
Status: []string{"status"},
|
|
|
|
Sources: []string{"sources"},
|
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockStatusChecker: func(m *mocks.StatusCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything, mock.Anything).Return(false, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
2023-04-15 21:27:14 +01:00
|
|
|
setupMockSourcesChecker: func(m *mocks.SourcesCheckable) {
|
|
|
|
m.EXPECT().IsUpToDate(mock.Anything).Return(false, nil)
|
2023-03-10 18:27:30 +00:00
|
|
|
},
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2023-04-15 21:27:14 +01:00
|
|
|
mockStatusChecker := mocks.NewStatusCheckable(t)
|
2023-03-10 18:27:30 +00:00
|
|
|
if tt.setupMockStatusChecker != nil {
|
|
|
|
tt.setupMockStatusChecker(mockStatusChecker)
|
|
|
|
}
|
|
|
|
|
2023-04-15 21:27:14 +01:00
|
|
|
mockSourcesChecker := mocks.NewSourcesCheckable(t)
|
2023-03-10 18:27:30 +00:00
|
|
|
if tt.setupMockSourcesChecker != nil {
|
|
|
|
tt.setupMockSourcesChecker(mockSourcesChecker)
|
|
|
|
}
|
|
|
|
|
|
|
|
result, err := IsTaskUpToDate(
|
|
|
|
context.Background(),
|
|
|
|
tt.task,
|
|
|
|
WithStatusChecker(mockStatusChecker),
|
|
|
|
WithSourcesChecker(mockSourcesChecker),
|
|
|
|
)
|
|
|
|
require.NoError(t, err)
|
|
|
|
assert.Equal(t, tt.expected, result)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|