karmada/pkg/util/helper/workstatus_test.go

289 lines
7.1 KiB
Go

package helper
import (
"testing"
"github.com/stretchr/testify/assert"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/util/sets"
workv1alpha1 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha1"
workv1alpha2 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha2"
)
func TestGenerateFullyAppliedCondition(t *testing.T) {
spec := workv1alpha2.ResourceBindingSpec{
Clusters: []workv1alpha2.TargetCluster{
{Name: "cluster1"},
{Name: "cluster2"},
},
}
statuses := []workv1alpha2.AggregatedStatusItem{
{ClusterName: "cluster1", Applied: true, Health: workv1alpha2.ResourceHealthy},
{ClusterName: "cluster2", Applied: true, Health: workv1alpha2.ResourceUnknown},
}
expectedTrue := metav1.ConditionTrue
expectedFalse := metav1.ConditionFalse
resultTrue := generateFullyAppliedCondition(spec, statuses)
if resultTrue.Status != expectedTrue {
t.Errorf("generateFullyAppliedCondition with fully applied statuses returned %v, expected %v", resultTrue, expectedTrue)
}
resultFalse := generateFullyAppliedCondition(spec, statuses[:1])
if resultFalse.Status != expectedFalse {
t.Errorf("generateFullyAppliedCondition with partially applied statuses returned %v, expected %v", resultFalse, expectedFalse)
}
}
func TestWorksFullyApplied(t *testing.T) {
type args struct {
aggregatedStatuses []workv1alpha2.AggregatedStatusItem
targetClusters sets.Set[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.New("member1"),
},
want: false,
},
{
name: "cluster size is not equal to aggregatedStatuses",
args: args{
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
{
ClusterName: "member1",
Applied: true,
},
},
targetClusters: sets.New("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.New("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.New("member1", "member2"),
},
want: false,
},
{
name: "target clusters not match expected status",
args: args{
aggregatedStatuses: []workv1alpha2.AggregatedStatusItem{
{
ClusterName: "member1",
Applied: true,
},
},
targetClusters: sets.New("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)
}
})
}
}
func TestGetManifestIndex(t *testing.T) {
manifest1 := workv1alpha1.Manifest{
RawExtension: runtime.RawExtension{
Raw: []byte(`{"apiVersion":"v1","kind":"Service","metadata":{"name":"test-service","namespace":"test-namespace"}}`),
},
}
manifest2 := workv1alpha1.Manifest{
RawExtension: runtime.RawExtension{
Raw: []byte(`{"apiVersion":"apps/v1","kind":"Deployment","metadata":{"name":"test-deployment","namespace":"test-namespace"}}`),
},
}
manifests := []workv1alpha1.Manifest{manifest1, manifest2}
service := &unstructured.Unstructured{
Object: map[string]interface{}{
"apiVersion": "v1",
"kind": "Service",
"metadata": map[string]interface{}{
"name": "test-service",
"namespace": "test-namespace",
},
},
}
deployment := &unstructured.Unstructured{
Object: map[string]interface{}{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": map[string]interface{}{
"name": "test-deployment",
"namespace": "test-namespace",
},
},
}
t.Run("Service", func(t *testing.T) {
index, err := GetManifestIndex(manifests, service)
if err != nil {
t.Errorf("unexpected error: %v", err)
}
if index != 0 {
t.Errorf("expected index 0, got %d", index)
}
})
t.Run("Deployment", func(t *testing.T) {
index, err := GetManifestIndex(manifests, deployment)
if err != nil {
t.Errorf("unexpected error: %v", err)
}
if index != 1 {
t.Errorf("expected index 1, got %d", index)
}
})
t.Run("No match", func(t *testing.T) {
_, err := GetManifestIndex(manifests, &unstructured.Unstructured{})
if err == nil {
t.Errorf("expected error, got nil")
}
})
}
func TestEqualIdentifier(t *testing.T) {
testCases := []struct {
name string
target *workv1alpha1.ResourceIdentifier
ordinal int
workload *unstructured.Unstructured
expectedOutput bool
}{
{
name: "identifiers are equal",
target: &workv1alpha1.ResourceIdentifier{
Ordinal: 0,
Group: "apps",
Version: "v1",
Kind: "Deployment",
Namespace: "default",
Name: "test-deployment",
},
ordinal: 0,
workload: &unstructured.Unstructured{
Object: map[string]interface{}{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": map[string]interface{}{
"namespace": "default",
"name": "test-deployment",
},
},
},
expectedOutput: true,
},
{
name: "identifiers are not equal",
target: &workv1alpha1.ResourceIdentifier{
Ordinal: 1,
Group: "apps",
Version: "v1",
Kind: "Deployment",
Namespace: "default",
Name: "test-deployment",
},
ordinal: 0,
workload: &unstructured.Unstructured{
Object: map[string]interface{}{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": map[string]interface{}{
"namespace": "default",
"name": "test-deployment",
},
},
},
expectedOutput: false,
},
}
for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
equal, err := equalIdentifier(tc.target, tc.ordinal, tc.workload)
if err != nil {
t.Errorf("unexpected error: %v", err)
}
if equal != tc.expectedOutput {
t.Errorf("expected %v, got %v", tc.expectedOutput, equal)
}
})
}
}
func TestIsResourceApplied(t *testing.T) {
// Create a WorkStatus struct with a WorkApplied condition set to True
workStatus := &workv1alpha1.WorkStatus{
Conditions: []metav1.Condition{
{
Type: workv1alpha1.WorkApplied,
Status: metav1.ConditionTrue,
},
},
}
// Call IsResourceApplied and assert that it returns true
assert.True(t, IsResourceApplied(workStatus))
}