2022-02-08 11:22:41 -06:00
|
|
|
package runner
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/nektos/act/pkg/common"
|
|
|
|
"github.com/nektos/act/pkg/model"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/mock"
|
|
|
|
)
|
|
|
|
|
|
|
|
type jobInfoMock struct {
|
|
|
|
mock.Mock
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) matrix() map[string]interface{} {
|
|
|
|
args := jpm.Called()
|
|
|
|
return args.Get(0).(map[string]interface{})
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) steps() []*model.Step {
|
|
|
|
args := jpm.Called()
|
|
|
|
|
|
|
|
return args.Get(0).([]*model.Step)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) startContainer() common.Executor {
|
|
|
|
args := jpm.Called()
|
|
|
|
|
|
|
|
return args.Get(0).(func(context.Context) error)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) stopContainer() common.Executor {
|
|
|
|
args := jpm.Called()
|
|
|
|
|
|
|
|
return args.Get(0).(func(context.Context) error)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) closeContainer() common.Executor {
|
|
|
|
args := jpm.Called()
|
|
|
|
|
|
|
|
return args.Get(0).(func(context.Context) error)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) newStepExecutor(step *model.Step) common.Executor {
|
|
|
|
args := jpm.Called(step)
|
|
|
|
|
|
|
|
return args.Get(0).(func(context.Context) error)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) interpolateOutputs() common.Executor {
|
|
|
|
args := jpm.Called()
|
|
|
|
|
|
|
|
return args.Get(0).(func(context.Context) error)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (jpm *jobInfoMock) result(result string) {
|
|
|
|
jpm.Called(result)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewJobExecutor(t *testing.T) {
|
|
|
|
table := []struct {
|
2022-02-10 10:54:58 -06:00
|
|
|
name string
|
|
|
|
steps []*model.Step
|
|
|
|
executedSteps []string
|
|
|
|
result string
|
|
|
|
hasError bool
|
2022-02-08 11:22:41 -06:00
|
|
|
}{
|
|
|
|
{
|
2022-02-10 10:54:58 -06:00
|
|
|
name: "zeroSteps",
|
|
|
|
steps: []*model.Step{},
|
|
|
|
executedSteps: []string{
|
|
|
|
"startContainer",
|
|
|
|
"stopContainer",
|
|
|
|
"interpolateOutputs",
|
|
|
|
"closeContainer",
|
|
|
|
},
|
|
|
|
result: "success",
|
|
|
|
hasError: false,
|
2022-02-08 11:22:41 -06:00
|
|
|
},
|
|
|
|
{
|
2022-02-10 10:54:58 -06:00
|
|
|
name: "stepWithoutPrePost",
|
|
|
|
steps: []*model.Step{{
|
2022-02-08 11:22:41 -06:00
|
|
|
ID: "1",
|
|
|
|
}},
|
2022-02-10 10:54:58 -06:00
|
|
|
executedSteps: []string{
|
|
|
|
"startContainer",
|
|
|
|
"step1",
|
|
|
|
"stopContainer",
|
|
|
|
"interpolateOutputs",
|
|
|
|
"closeContainer",
|
|
|
|
},
|
|
|
|
result: "success",
|
|
|
|
hasError: false,
|
2022-02-08 11:22:41 -06:00
|
|
|
},
|
|
|
|
{
|
2022-02-10 10:54:58 -06:00
|
|
|
name: "stepWithFailure",
|
|
|
|
steps: []*model.Step{{
|
2022-02-08 11:22:41 -06:00
|
|
|
ID: "1",
|
|
|
|
}},
|
2022-02-10 10:54:58 -06:00
|
|
|
executedSteps: []string{
|
|
|
|
"startContainer",
|
|
|
|
"step1",
|
|
|
|
"stopContainer",
|
|
|
|
"interpolateOutputs",
|
|
|
|
"closeContainer",
|
|
|
|
},
|
|
|
|
result: "failure",
|
|
|
|
hasError: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "multipleSteps",
|
|
|
|
steps: []*model.Step{{
|
|
|
|
ID: "1",
|
|
|
|
}, {
|
|
|
|
ID: "2",
|
|
|
|
}},
|
|
|
|
executedSteps: []string{
|
|
|
|
"startContainer",
|
|
|
|
"step1",
|
|
|
|
"step2",
|
|
|
|
"stopContainer",
|
|
|
|
"interpolateOutputs",
|
|
|
|
"closeContainer",
|
|
|
|
},
|
|
|
|
result: "success",
|
|
|
|
hasError: false,
|
2022-02-08 11:22:41 -06:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tt := range table {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
|
|
ctx := common.WithJobErrorContainer(context.Background())
|
|
|
|
jpm := &jobInfoMock{}
|
2022-02-10 10:54:58 -06:00
|
|
|
executorOrder := make([]string, 0)
|
2022-02-08 11:22:41 -06:00
|
|
|
|
|
|
|
jpm.On("startContainer").Return(func(ctx context.Context) error {
|
2022-02-10 10:54:58 -06:00
|
|
|
executorOrder = append(executorOrder, "startContainer")
|
2022-02-08 11:22:41 -06:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
jpm.On("steps").Return(tt.steps)
|
|
|
|
|
|
|
|
for _, stepMock := range tt.steps {
|
2022-02-10 10:54:58 -06:00
|
|
|
func(stepMock *model.Step) {
|
|
|
|
jpm.On("newStepExecutor", stepMock).Return(func(ctx context.Context) error {
|
|
|
|
executorOrder = append(executorOrder, "step"+stepMock.ID)
|
|
|
|
if tt.hasError {
|
|
|
|
return fmt.Errorf("error")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
}(stepMock)
|
2022-02-08 11:22:41 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
jpm.On("interpolateOutputs").Return(func(ctx context.Context) error {
|
2022-02-10 10:54:58 -06:00
|
|
|
executorOrder = append(executorOrder, "interpolateOutputs")
|
2022-02-08 11:22:41 -06:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
jpm.On("matrix").Return(map[string]interface{}{})
|
|
|
|
|
|
|
|
jpm.On("stopContainer").Return(func(ctx context.Context) error {
|
2022-02-10 10:54:58 -06:00
|
|
|
executorOrder = append(executorOrder, "stopContainer")
|
2022-02-08 11:22:41 -06:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
jpm.On("result", tt.result)
|
|
|
|
|
|
|
|
jpm.On("closeContainer").Return(func(ctx context.Context) error {
|
2022-02-10 10:54:58 -06:00
|
|
|
executorOrder = append(executorOrder, "closeContainer")
|
2022-02-08 11:22:41 -06:00
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
executor := newJobExecutor(jpm)
|
|
|
|
err := executor(ctx)
|
|
|
|
assert.Nil(t, err)
|
2022-02-10 10:54:58 -06:00
|
|
|
assert.Equal(t, tt.executedSteps, executorOrder)
|
2022-02-08 11:22:41 -06:00
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|