(ut) add tests for bad filed values checking; refactor some funcs
This commit is contained in:
@@ -14,17 +14,18 @@ See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
*/
|
||||
|
||||
package persistentvolume
|
||||
package node
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/util/validation/field"
|
||||
api "k8s.io/kubernetes/pkg/apis/core"
|
||||
"k8s.io/kubernetes/pkg/apis/node"
|
||||
)
|
||||
|
||||
var DeprecatedNodeLabels = map[string]string{
|
||||
var deprecatedNodeLabels = map[string]string{
|
||||
`beta.kubernetes.io/arch`: `deprecated since v1.14; use "kubernetes.io/arch" instead`,
|
||||
`beta.kubernetes.io/os`: `deprecated since v1.14; use "kubernetes.io/os" instead`,
|
||||
`failure-domain.beta.kubernetes.io/region`: `deprecated since v1.17; use "topology.kubernetes.io/region" instead`,
|
||||
@@ -32,13 +33,20 @@ var DeprecatedNodeLabels = map[string]string{
|
||||
`beta.kubernetes.io/instance-type`: `deprecated since v1.17; use "node.kubernetes.io/instance-type" instead`,
|
||||
}
|
||||
|
||||
func GetWarningsForRuntimeClass(ctx context.Context, rc *node.RuntimeClass) []string {
|
||||
// GetLabelDeprecatedMessage returns the message for the deprecated label
|
||||
// and a bool indicating if the label is deprecated.
|
||||
func GetLabelDeprecatedMessage(key string) (string, bool) {
|
||||
msg, ok := deprecatedNodeLabels[key]
|
||||
return msg, ok
|
||||
}
|
||||
|
||||
func GetWarningsForRuntimeClass(rc *node.RuntimeClass) []string {
|
||||
var warnings []string
|
||||
|
||||
if rc != nil {
|
||||
if rc != nil && rc.Scheduling != nil && rc.Scheduling.NodeSelector != nil {
|
||||
// use of deprecated node labels in scheduling's node affinity
|
||||
for key, _ := range rc.Scheduling.NodeSelector {
|
||||
if msg, deprecated := DeprecatedNodeLabels[key]; deprecated {
|
||||
for key := range rc.Scheduling.NodeSelector {
|
||||
if msg, deprecated := GetLabelDeprecatedMessage(key); deprecated {
|
||||
warnings = append(warnings, fmt.Sprintf("%s: %s", field.NewPath("scheduling", "nodeSelector"), msg))
|
||||
}
|
||||
}
|
||||
@@ -46,3 +54,55 @@ func GetWarningsForRuntimeClass(ctx context.Context, rc *node.RuntimeClass) []st
|
||||
|
||||
return warnings
|
||||
}
|
||||
|
||||
// WarningsForNodeSelector tests if any of the node selector requirements in the template is deprecated.
|
||||
// If there are deprecated node selector requirements in either match expressions or match labels, a warning is returned.
|
||||
func WarningsForNodeSelector(nodeSelector *metav1.LabelSelector, fieldPath *field.Path) []string {
|
||||
if nodeSelector == nil {
|
||||
return nil
|
||||
}
|
||||
|
||||
var warnings []string
|
||||
// use of deprecated node labels in matchLabelExpressions
|
||||
for i, expression := range nodeSelector.MatchExpressions {
|
||||
if msg, deprecated := GetLabelDeprecatedMessage(expression.Key); deprecated {
|
||||
warnings = append(
|
||||
warnings,
|
||||
fmt.Sprintf(
|
||||
"%s: %s is %s",
|
||||
fieldPath.Child("matchExpressions").Index(i).Child("key"),
|
||||
expression.Key,
|
||||
msg,
|
||||
),
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
// use of deprecated node labels in matchLabels
|
||||
for label := range nodeSelector.MatchLabels {
|
||||
if msg, deprecated := GetLabelDeprecatedMessage(label); deprecated {
|
||||
warnings = append(warnings, fmt.Sprintf("%s: %s", fieldPath.Child("matchLabels").Child(label), msg))
|
||||
}
|
||||
}
|
||||
return warnings
|
||||
}
|
||||
|
||||
// WarningsForNodeSelectorTerm checks match expressions of node selector term
|
||||
func WarningsForNodeSelectorTerm(nodeSelectorTerm api.NodeSelectorTerm, fieldPath *field.Path) []string {
|
||||
var warnings []string
|
||||
// use of deprecated node labels in matchLabelExpressions
|
||||
for i, expression := range nodeSelectorTerm.MatchExpressions {
|
||||
if msg, deprecated := GetLabelDeprecatedMessage(expression.Key); deprecated {
|
||||
warnings = append(
|
||||
warnings,
|
||||
fmt.Sprintf(
|
||||
"%s: %s is %s",
|
||||
fieldPath.Child("matchExpressions").Index(i).Child("key"),
|
||||
expression.Key,
|
||||
msg,
|
||||
),
|
||||
)
|
||||
}
|
||||
}
|
||||
return warnings
|
||||
}
|
||||
|
Reference in New Issue
Block a user