111 lines
2.3 KiB
Go
111 lines
2.3 KiB
Go
package helper
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"k8s.io/apimachinery/pkg/util/sets"
|
|
|
|
workv1alpha2 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha2"
|
|
)
|
|
|
|
func TestWorksFullyApplied(t *testing.T) {
|
|
type args struct {
|
|
aggregatedStatuses []workv1alpha2.AggregatedStatusItem
|
|
targetClusters sets.String
|
|
}
|
|
tests := []struct {
|
|
name string
|
|
args args
|
|
want bool
|
|
}{
|
|
{
|
|
name: "no cluster",
|
|
args: args{
|
|
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
|
|
{
|
|
ClusterName: "member1",
|
|
Applied: true,
|
|
},
|
|
},
|
|
targetClusters: nil,
|
|
},
|
|
want: false,
|
|
},
|
|
{
|
|
name: "no aggregatedStatuses",
|
|
args: args{
|
|
aggregatedStatuses: nil,
|
|
targetClusters: sets.NewString("member1"),
|
|
},
|
|
want: false,
|
|
},
|
|
{
|
|
name: "cluster size is not equal to aggregatedStatuses",
|
|
args: args{
|
|
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
|
|
{
|
|
ClusterName: "member1",
|
|
Applied: true,
|
|
},
|
|
},
|
|
targetClusters: sets.NewString("member1", "member2"),
|
|
},
|
|
want: false,
|
|
},
|
|
{
|
|
name: "aggregatedStatuses is equal to clusterNames and all applied",
|
|
args: args{
|
|
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
|
|
{
|
|
ClusterName: "member1",
|
|
Applied: true,
|
|
},
|
|
{
|
|
ClusterName: "member2",
|
|
Applied: true,
|
|
},
|
|
},
|
|
targetClusters: sets.NewString("member1", "member2"),
|
|
},
|
|
want: true,
|
|
},
|
|
{
|
|
name: "aggregatedStatuses is equal to clusterNames but not all applied",
|
|
args: args{
|
|
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
|
|
{
|
|
ClusterName: "member1",
|
|
Applied: true,
|
|
},
|
|
{
|
|
ClusterName: "member2",
|
|
Applied: false,
|
|
},
|
|
},
|
|
targetClusters: sets.NewString("member1", "member2"),
|
|
},
|
|
want: false,
|
|
},
|
|
{
|
|
name: "target clusters not match expected status",
|
|
args: args{
|
|
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
|
|
{
|
|
ClusterName: "member1",
|
|
Applied: true,
|
|
},
|
|
},
|
|
targetClusters: sets.NewString("member2"),
|
|
},
|
|
want: false,
|
|
},
|
|
}
|
|
for _, tt := range tests {
|
|
t.Run(tt.name, func(t *testing.T) {
|
|
if got := worksFullyApplied(tt.args.aggregatedStatuses, tt.args.targetClusters); got != tt.want {
|
|
t.Errorf("worksFullyApplied() = %v, want %v", got, tt.want)
|
|
}
|
|
})
|
|
}
|
|
}
|