emit warning on deprecated annotation volume.beta.kubernetes.io/storage-class
This commit is contained in:
@@ -17,6 +17,9 @@ limitations under the License.
|
||||
package persistentvolume
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
|
||||
"k8s.io/apimachinery/pkg/util/validation/field"
|
||||
utilfeature "k8s.io/apiserver/pkg/util/feature"
|
||||
nodeapi "k8s.io/kubernetes/pkg/api/node"
|
||||
@@ -24,6 +27,10 @@ import (
|
||||
"k8s.io/kubernetes/pkg/features"
|
||||
)
|
||||
|
||||
const (
|
||||
deprecatedStorageClassAnnotationsMsg = `deprecated since v1.8; use "storageClassName" attribute instead`
|
||||
)
|
||||
|
||||
// DropDisabledFields removes disabled fields from the pv spec.
|
||||
// This should be called from PrepareForCreate/PrepareForUpdate for all resources containing a pv spec.
|
||||
func DropDisabledFields(pvSpec *api.PersistentVolumeSpec, oldPVSpec *api.PersistentVolumeSpec) {
|
||||
@@ -49,12 +56,22 @@ func GetWarningsForPersistentVolume(pv *api.PersistentVolume) []string {
|
||||
if pv == nil {
|
||||
return nil
|
||||
}
|
||||
return warningsForPersistentVolumeSpecAndMeta(nil, &pv.Spec)
|
||||
return warningsForPersistentVolumeSpecAndMeta(nil, &pv.Spec, &pv.ObjectMeta)
|
||||
}
|
||||
|
||||
func warningsForPersistentVolumeSpecAndMeta(fieldPath *field.Path, pvSpec *api.PersistentVolumeSpec) []string {
|
||||
func warningsForPersistentVolumeSpecAndMeta(fieldPath *field.Path, pvSpec *api.PersistentVolumeSpec, pvMeta *metav1.ObjectMeta) []string {
|
||||
var warnings []string
|
||||
|
||||
if _, ok := pvMeta.Annotations[api.BetaStorageClassAnnotation]; ok {
|
||||
warnings = append(warnings,
|
||||
fmt.Sprintf(
|
||||
"%s: %s",
|
||||
fieldPath.Child("metadata", "annotations").Key(api.BetaStorageClassAnnotation),
|
||||
deprecatedStorageClassAnnotationsMsg,
|
||||
),
|
||||
)
|
||||
}
|
||||
|
||||
if pvSpec.NodeAffinity != nil && pvSpec.NodeAffinity.Required != nil {
|
||||
termFldPath := fieldPath.Child("spec", "nodeAffinity", "required", "nodeSelectorTerms")
|
||||
// use of deprecated node labels in node affinity
|
||||
|
Reference in New Issue
Block a user