Skip to content

Commit

Permalink
test: Add scheduling suspension e2e
Browse files Browse the repository at this point in the history
Signed-off-by: Monokaix <[email protected]>
  • Loading branch information
Monokaix committed Jan 2, 2025
1 parent a891673 commit 944d77d
Show file tree
Hide file tree
Showing 3 changed files with 169 additions and 0 deletions.
25 changes: 25 additions & 0 deletions test/e2e/framework/propagationpolicy.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ import (
"k8s.io/apimachinery/pkg/types"

policyv1alpha1 "github.com/karmada-io/karmada/pkg/apis/policy/v1alpha1"
workv1alpha2 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha2"
karmada "github.com/karmada-io/karmada/pkg/generated/clientset/versioned"
)

Expand Down Expand Up @@ -86,6 +87,30 @@ func UpdatePropagationPolicyWithSpec(client karmada.Interface, namespace, name s
})
}

// UpdateResourceBingingSpec update ResourceBindingSpec with karmada client.
func UpdateResourceBingingSpec(client karmada.Interface, namespace, name string, resourceBindingSpec workv1alpha2.ResourceBindingSpec) {
ginkgo.By(fmt.Sprintf("Updating ResourceBinging(%s/%s) spec", namespace, name), func() {
newResourceBinding, err := client.WorkV1alpha2().ResourceBindings(namespace).Get(context.TODO(), name, metav1.GetOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred())

newResourceBinding.Spec = resourceBindingSpec
_, err = client.WorkV1alpha2().ResourceBindings(newResourceBinding.Namespace).Update(context.TODO(), newResourceBinding, metav1.UpdateOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred())
})
}

// UpdateClusterResourceBingingSpec updates ClusterResourceBindingSpec with karmada client.
func UpdateClusterResourceBingingSpec(client karmada.Interface, name string, clusterResourceBindingSpec workv1alpha2.ResourceBindingSpec) {
ginkgo.By(fmt.Sprintf("Updating ClusterResourceBinging(%s) spec", name), func() {
newClusterResourceBinding, err := client.WorkV1alpha2().ClusterResourceBindings().Get(context.TODO(), name, metav1.GetOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred(), "Failed to get ClusterResourceBinding")

newClusterResourceBinding.Spec = clusterResourceBindingSpec
_, err = client.WorkV1alpha2().ClusterResourceBindings().Update(context.TODO(), newClusterResourceBinding, metav1.UpdateOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred(), "Failed to update ClusterResourceBinding")
})
}

// WaitPropagationPolicyFitWith wait PropagationPolicy sync with fit func.
func WaitPropagationPolicyFitWith(client karmada.Interface, namespace, name string, fit func(policy *policyv1alpha1.PropagationPolicy) bool) {
gomega.Eventually(func() bool {
Expand Down
104 changes: 104 additions & 0 deletions test/e2e/scheduling_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -696,6 +696,110 @@ var _ = ginkgo.Describe("[JobReplicaScheduling] JobReplicaSchedulingStrategy tes
})
})

var _ = ginkgo.Describe("[Suspension] ResourceBinding testing", func() {
var deploymentName string
var rb *workv1alpha2.ResourceBinding

ginkgo.BeforeEach(func() {
// Create deployment.
deploymentName = deploymentNamePrefix + rand.String(RandomStrLength)
deployment := helper.NewDeployment(testNamespace, deploymentName)
framework.CreateDeployment(kubeClient, deployment)
_, err := kubeClient.AppsV1().Deployments(testNamespace).Get(context.TODO(), deploymentName, metav1.GetOptions{})
gomega.Expect(err).NotTo(gomega.HaveOccurred(), "Failed to get deployment")

// Create ResourceBinding.
rb = helper.NewResourceBinding(deploymentName, workv1alpha2.ObjectReference{
APIVersion: deployment.APIVersion,
Kind: deployment.Kind,
Namespace: testNamespace,
Name: deploymentName,
}, &policyv1alpha1.Placement{
ReplicaScheduling: &policyv1alpha1.ReplicaSchedulingStrategy{
ReplicaSchedulingType: policyv1alpha1.ReplicaSchedulingTypeDivided,
ReplicaDivisionPreference: policyv1alpha1.ReplicaDivisionPreferenceWeighted,
},
}, true)
rb, err = karmadaClient.WorkV1alpha2().ResourceBindings(testNamespace).Create(context.TODO(), rb, metav1.CreateOptions{})
gomega.Expect(err).NotTo(gomega.HaveOccurred(), "Failed to create ResourceBinding")
})

ginkgo.It("should not be scheduled when suspended and should be scheduled after resumed", func() {
ginkgo.By("Waiting for the ResourceBinding not to be scheduled when suspended", func() {
gomega.Eventually(func() bool {
latestRB, err := karmadaClient.WorkV1alpha2().ResourceBindings(testNamespace).Get(context.TODO(), rb.Name, metav1.GetOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred())
return meta.IsStatusConditionTrue(latestRB.Status.Conditions, workv1alpha2.Scheduled)
}, pollTimeout, pollInterval).Should(gomega.BeFalse(), "ResourceBinding should not be scheduled when suspended")
})

ginkgo.By("Resuming the ResourceBinding", func() {
rb.Spec.Suspension = &workv1alpha2.Suspension{}
framework.UpdateResourceBingingSpec(karmadaClient, rb.Namespace, rb.Name, rb.Spec)
})

ginkgo.By("Waiting for the ResourceBinding to be scheduled after resumed", func() {
gomega.Eventually(func() bool {
latestRB, err := karmadaClient.WorkV1alpha2().ResourceBindings(testNamespace).Get(context.TODO(), rb.Name, metav1.GetOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred())
return meta.IsStatusConditionTrue(latestRB.Status.Conditions, workv1alpha2.Scheduled)
}, pollTimeout, pollInterval).Should(gomega.BeTrue(), "ResourceBinding should be scheduled after resumed")
})
})
})

var _ = ginkgo.Describe("[Suspension] ClusterResourceBinding testing", func() {
var configMapName string
var crb *workv1alpha2.ClusterResourceBinding

ginkgo.BeforeEach(func() {
// Create ConfigMap.
configMapName = configMapNamePrefix + rand.String(RandomStrLength)
configMap := helper.NewConfigMap(testNamespace, configMapName, make(map[string]string))
framework.CreateConfigMap(kubeClient, configMap)
_, err := kubeClient.CoreV1().ConfigMaps(testNamespace).Get(context.TODO(), configMapName, metav1.GetOptions{})
gomega.Expect(err).NotTo(gomega.HaveOccurred(), "Failed to get ConfigMap")

// Create ClusterResourceBinding.
targetMember := framework.ClusterNames()[0]
crb = helper.NewClusterResourceBinding(configMapName, workv1alpha2.ObjectReference{
APIVersion: configMap.APIVersion,
Kind: configMap.Kind,
Namespace: testNamespace,
Name: configMapName,
}, &policyv1alpha1.Placement{
ClusterAffinity: &policyv1alpha1.ClusterAffinity{
ClusterNames: []string{targetMember},
},
}, true)
crb, err = karmadaClient.WorkV1alpha2().ClusterResourceBindings().Create(context.TODO(), crb, metav1.CreateOptions{})
gomega.Expect(err).NotTo(gomega.HaveOccurred(), "Failed to create ClusterResourceBinding")
})

ginkgo.It("should not be scheduled when suspended and should be scheduled after resumed", func() {
ginkgo.By("Waiting for the ClusterResourceBinding not to be scheduled when suspended", func() {
gomega.Eventually(func() bool {
latestCRB, err := karmadaClient.WorkV1alpha2().ClusterResourceBindings().Get(context.TODO(), crb.Name, metav1.GetOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred())
return meta.IsStatusConditionTrue(latestCRB.Status.Conditions, workv1alpha2.Scheduled)
}, pollTimeout, pollInterval).Should(gomega.BeFalse(), "ClusterResourceBinding should not be scheduled when suspended")
})

ginkgo.By("Resuming the ClusterResourceBinding", func() {
crb.Spec.Suspension = &workv1alpha2.Suspension{}
framework.UpdateClusterResourceBingingSpec(karmadaClient, crb.Name, crb.Spec)
})

ginkgo.By("Waiting for the ClusterResourceBinding to be scheduled after resumed", func() {
gomega.Eventually(func() bool {
latestCRB, err := karmadaClient.WorkV1alpha2().ClusterResourceBindings().Get(context.TODO(), crb.Name, metav1.GetOptions{})
gomega.Expect(err).ShouldNot(gomega.HaveOccurred())
return meta.IsStatusConditionTrue(latestCRB.Status.Conditions, workv1alpha2.Scheduled)
}, pollTimeout, pollInterval).Should(gomega.BeTrue(), "ClusterResourceBinding should be scheduled after resumed")
})
})
})

// get the resource binding associated with the workload
func getResourceBinding(workload interface{}) (*workv1alpha2.ResourceBinding, error) {
obj, err := utilhelper.ToUnstructured(workload)
Expand Down
40 changes: 40 additions & 0 deletions test/helper/resource.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,9 @@ import (
autoscalingv1alpha1 "github.com/karmada-io/karmada/pkg/apis/autoscaling/v1alpha1"
clusterv1alpha1 "github.com/karmada-io/karmada/pkg/apis/cluster/v1alpha1"
networkingv1alpha1 "github.com/karmada-io/karmada/pkg/apis/networking/v1alpha1"
policyv1alpha1 "github.com/karmada-io/karmada/pkg/apis/policy/v1alpha1"
workv1alpha1 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha1"
workv1alpha2 "github.com/karmada-io/karmada/pkg/apis/work/v1alpha2"
)

// These are different resource units.
Expand Down Expand Up @@ -993,3 +995,41 @@ func NewWorkloadRebalancer(name string, objectReferences []appsv1alpha1.ObjectRe
},
}
}

// NewResourceBinding will build a new resourceBinding object.
func NewResourceBinding(name string, resource workv1alpha2.ObjectReference, placement *policyv1alpha1.Placement, suspended bool) *workv1alpha2.ResourceBinding {
rb := &workv1alpha2.ResourceBinding{
TypeMeta: metav1.TypeMeta{
Kind: workv1alpha2.ResourceKindResourceBinding,
APIVersion: workv1alpha2.GroupVersion.Version,
},
ObjectMeta: metav1.ObjectMeta{
Name: name,
},
Spec: workv1alpha2.ResourceBindingSpec{
Resource: resource,
Placement: placement,
Suspension: &workv1alpha2.Suspension{Scheduling: &suspended},
},
}
return rb
}

// NewClusterResourceBinding will build a new resourceBinding object.
func NewClusterResourceBinding(name string, resource workv1alpha2.ObjectReference, placement *policyv1alpha1.Placement, suspended bool) *workv1alpha2.ClusterResourceBinding {
crb := &workv1alpha2.ClusterResourceBinding{
TypeMeta: metav1.TypeMeta{
Kind: workv1alpha2.ResourceKindClusterResourceBinding,
APIVersion: workv1alpha2.GroupVersion.Version,
},
ObjectMeta: metav1.ObjectMeta{
Name: name,
},
Spec: workv1alpha2.ResourceBindingSpec{
Resource: resource,
Placement: placement,
Suspension: &workv1alpha2.Suspension{Scheduling: &suspended},
},
}
return crb
}

0 comments on commit 944d77d

Please sign in to comment.