Merge pull request #5216 from yanfeng1992/fix-apienables
skip the filter if the cluster is already in the list of scheduling result even if the API is missed
This commit is contained in:
commit
ec0521a754
|
@ -19,6 +19,7 @@ package apienablement
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
|
"k8s.io/apimachinery/pkg/api/meta"
|
||||||
"k8s.io/klog/v2"
|
"k8s.io/klog/v2"
|
||||||
|
|
||||||
clusterv1alpha1 "github.com/karmada-io/karmada/pkg/apis/cluster/v1alpha1"
|
clusterv1alpha1 "github.com/karmada-io/karmada/pkg/apis/cluster/v1alpha1"
|
||||||
|
@ -54,10 +55,19 @@ func (p *APIEnablement) Filter(
|
||||||
_ *workv1alpha2.ResourceBindingStatus,
|
_ *workv1alpha2.ResourceBindingStatus,
|
||||||
cluster *clusterv1alpha1.Cluster,
|
cluster *clusterv1alpha1.Cluster,
|
||||||
) *framework.Result {
|
) *framework.Result {
|
||||||
if !helper.IsAPIEnabled(cluster.Status.APIEnablements, bindingSpec.Resource.APIVersion, bindingSpec.Resource.Kind) {
|
if helper.IsAPIEnabled(cluster.Status.APIEnablements, bindingSpec.Resource.APIVersion, bindingSpec.Resource.Kind) {
|
||||||
klog.V(2).Infof("Cluster(%s) not fit as missing API(%s, kind=%s)", cluster.Name, bindingSpec.Resource.APIVersion, bindingSpec.Resource.Kind)
|
return framework.NewResult(framework.Success)
|
||||||
return framework.NewResult(framework.Unschedulable, "cluster(s) did not have the API resource")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return framework.NewResult(framework.Success)
|
// Let the cluster pass if it is already on the list of schedule result and the cluster's
|
||||||
|
// API enablements is incomplete, to avoid the issue that cluster be accidentally removed
|
||||||
|
// due to untrusted API enablements.
|
||||||
|
if bindingSpec.TargetContains(cluster.Name) &&
|
||||||
|
!meta.IsStatusConditionTrue(cluster.Status.Conditions, clusterv1alpha1.ClusterConditionCompleteAPIEnablements) {
|
||||||
|
return framework.NewResult(framework.Success)
|
||||||
|
}
|
||||||
|
|
||||||
|
klog.V(2).Infof("Cluster(%s) not fit as missing API(%s, kind=%s)", cluster.Name, bindingSpec.Resource.APIVersion, bindingSpec.Resource.Kind)
|
||||||
|
|
||||||
|
return framework.NewResult(framework.Unschedulable, "cluster(s) did not have the API resource")
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue