Merge pull request #1040 from gy95/AggregateErrors

add ut for AggregateErrors
This commit is contained in:
karmada-bot 2021-11-27 18:31:07 +08:00 committed by GitHub
commit 52bff3ab18
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 45 additions and 0 deletions

45
pkg/util/error_test.go Normal file
View File

@ -0,0 +1,45 @@
package util
import (
"fmt"
"reflect"
"testing"
utilerrors "k8s.io/apimachinery/pkg/util/errors"
)
func TestAggregateErrors(t *testing.T) {
err1 := fmt.Errorf("error1")
err2 := fmt.Errorf("error2")
channel := make(chan error, 2)
channel <- err1
channel <- err2
tests := []struct {
name string
input <-chan error
expected error
}{
{
name: "nil channel",
input: nil,
expected: nil,
},
{
name: "channel has no error",
input: make(chan error, 1),
expected: nil,
},
{
name: "channel has 2 errors",
input: channel,
expected: utilerrors.NewAggregate([]error{err1, err2}),
},
}
for _, test := range tests {
if got := AggregateErrors(test.input); !reflect.DeepEqual(got, test.expected) {
t.Errorf("Test %s failed: expected %v, but got %v", test.name, test.expected, got)
}
}
}