2023-11-03 10:44:03 +00:00
|
|
|
package errors_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"go.uber.org/multierr"
|
|
|
|
|
2023-11-07 07:04:33 +00:00
|
|
|
pipeline_errors "go.woodpecker-ci.org/woodpecker/pipeline/errors"
|
2023-11-03 10:44:03 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestGetPipelineErrors(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
title string
|
|
|
|
err error
|
|
|
|
expected []*pipeline_errors.PipelineError
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
title: "nil error",
|
|
|
|
err: nil,
|
|
|
|
expected: nil,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "warning",
|
|
|
|
err: &pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
expected: []*pipeline_errors.PipelineError{
|
|
|
|
{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "pipeline error",
|
|
|
|
err: &pipeline_errors.PipelineError{
|
|
|
|
IsWarning: false,
|
|
|
|
},
|
|
|
|
expected: []*pipeline_errors.PipelineError{
|
|
|
|
{
|
|
|
|
IsWarning: false,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "multiple warnings",
|
|
|
|
err: multierr.Combine(
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
),
|
|
|
|
expected: []*pipeline_errors.PipelineError{
|
|
|
|
{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "multiple errors and warnings",
|
|
|
|
err: multierr.Combine(
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: false,
|
|
|
|
},
|
|
|
|
errors.New("some error"),
|
|
|
|
),
|
|
|
|
expected: []*pipeline_errors.PipelineError{
|
|
|
|
{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
IsWarning: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
Type: pipeline_errors.PipelineErrorTypeGeneric,
|
|
|
|
IsWarning: false,
|
|
|
|
Message: "some error",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
assert.Equalf(t, pipeline_errors.GetPipelineErrors(test.err), test.expected, test.title)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestHasBlockingErrors(t *testing.T) {
|
|
|
|
t.Parallel()
|
|
|
|
|
|
|
|
tests := []struct {
|
|
|
|
title string
|
|
|
|
err error
|
|
|
|
expected bool
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
title: "nil error",
|
|
|
|
err: nil,
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "warning",
|
|
|
|
err: &pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "pipeline error",
|
|
|
|
err: &pipeline_errors.PipelineError{
|
|
|
|
IsWarning: false,
|
|
|
|
},
|
|
|
|
expected: true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "multiple warnings",
|
|
|
|
err: multierr.Combine(
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
),
|
|
|
|
expected: false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
title: "multiple errors and warnings",
|
|
|
|
err: multierr.Combine(
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: true,
|
|
|
|
},
|
|
|
|
&pipeline_errors.PipelineError{
|
|
|
|
IsWarning: false,
|
|
|
|
},
|
|
|
|
errors.New("some error"),
|
|
|
|
),
|
|
|
|
expected: true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
if pipeline_errors.HasBlockingErrors(test.err) != test.expected {
|
|
|
|
t.Error("Should only return true if there are blocking errors")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|