Merge pull request #117036 from haoruan/bugfix/warning-on-deprecated-annotations
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
 | 
					package persistentvolume
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
				
			||||||
	"k8s.io/apimachinery/pkg/util/validation/field"
 | 
						"k8s.io/apimachinery/pkg/util/validation/field"
 | 
				
			||||||
	utilfeature "k8s.io/apiserver/pkg/util/feature"
 | 
						utilfeature "k8s.io/apiserver/pkg/util/feature"
 | 
				
			||||||
	nodeapi "k8s.io/kubernetes/pkg/api/node"
 | 
						nodeapi "k8s.io/kubernetes/pkg/api/node"
 | 
				
			||||||
@@ -24,6 +27,10 @@ import (
 | 
				
			|||||||
	"k8s.io/kubernetes/pkg/features"
 | 
						"k8s.io/kubernetes/pkg/features"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const (
 | 
				
			||||||
 | 
						deprecatedStorageClassAnnotationsMsg = `deprecated since v1.8; use "storageClassName" attribute instead`
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// DropDisabledFields removes disabled fields from the pv spec.
 | 
					// DropDisabledFields removes disabled fields from the pv spec.
 | 
				
			||||||
// This should be called from PrepareForCreate/PrepareForUpdate for all resources containing a pv spec.
 | 
					// This should be called from PrepareForCreate/PrepareForUpdate for all resources containing a pv spec.
 | 
				
			||||||
func DropDisabledFields(pvSpec *api.PersistentVolumeSpec, oldPVSpec *api.PersistentVolumeSpec) {
 | 
					func DropDisabledFields(pvSpec *api.PersistentVolumeSpec, oldPVSpec *api.PersistentVolumeSpec) {
 | 
				
			||||||
@@ -49,12 +56,22 @@ func GetWarningsForPersistentVolume(pv *api.PersistentVolume) []string {
 | 
				
			|||||||
	if pv == nil {
 | 
						if pv == nil {
 | 
				
			||||||
		return 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
 | 
						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 {
 | 
						if pvSpec.NodeAffinity != nil && pvSpec.NodeAffinity.Required != nil {
 | 
				
			||||||
		termFldPath := fieldPath.Child("spec", "nodeAffinity", "required", "nodeSelectorTerms")
 | 
							termFldPath := fieldPath.Child("spec", "nodeAffinity", "required", "nodeSelectorTerms")
 | 
				
			||||||
		// use of deprecated node labels in node affinity
 | 
							// use of deprecated node labels in node affinity
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -146,6 +146,9 @@ func TestWarnings(t *testing.T) {
 | 
				
			|||||||
			template: &api.PersistentVolume{
 | 
								template: &api.PersistentVolume{
 | 
				
			||||||
				ObjectMeta: metav1.ObjectMeta{
 | 
									ObjectMeta: metav1.ObjectMeta{
 | 
				
			||||||
					Name: "foo",
 | 
										Name: "foo",
 | 
				
			||||||
 | 
										Annotations: map[string]string{
 | 
				
			||||||
 | 
											api.BetaStorageClassAnnotation: "",
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
				},
 | 
									},
 | 
				
			||||||
				Spec: api.PersistentVolumeSpec{
 | 
									Spec: api.PersistentVolumeSpec{
 | 
				
			||||||
					NodeAffinity: &api.VolumeNodeAffinity{
 | 
										NodeAffinity: &api.VolumeNodeAffinity{
 | 
				
			||||||
@@ -169,6 +172,7 @@ func TestWarnings(t *testing.T) {
 | 
				
			|||||||
				},
 | 
									},
 | 
				
			||||||
			},
 | 
								},
 | 
				
			||||||
			expected: []string{
 | 
								expected: []string{
 | 
				
			||||||
 | 
									`metadata.annotations[volume.beta.kubernetes.io/storage-class]: deprecated since v1.8; use "storageClassName" attribute instead`,
 | 
				
			||||||
				`spec.nodeAffinity.required.nodeSelectorTerms[0].matchExpressions[0].key: beta.kubernetes.io/os is deprecated since v1.14; use "kubernetes.io/os" instead`,
 | 
									`spec.nodeAffinity.required.nodeSelectorTerms[0].matchExpressions[0].key: beta.kubernetes.io/os is deprecated since v1.14; use "kubernetes.io/os" instead`,
 | 
				
			||||||
			},
 | 
								},
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -26,8 +26,9 @@ import (
 | 
				
			|||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const (
 | 
					const (
 | 
				
			||||||
	pvc            string = "PersistentVolumeClaim"
 | 
						pvc                                  string = "PersistentVolumeClaim"
 | 
				
			||||||
	volumeSnapshot string = "VolumeSnapshot"
 | 
						volumeSnapshot                       string = "VolumeSnapshot"
 | 
				
			||||||
 | 
						deprecatedStorageClassAnnotationsMsg        = `deprecated since v1.8; use "storageClassName" attribute instead`
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// DropDisabledFields removes disabled fields from the pvc spec.
 | 
					// DropDisabledFields removes disabled fields from the pvc spec.
 | 
				
			||||||
@@ -197,11 +198,25 @@ func allocatedResourcesInUse(oldPVC *core.PersistentVolumeClaim) bool {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func GetWarningsForPersistentVolumeClaim(pv *core.PersistentVolumeClaim) []string {
 | 
					func GetWarningsForPersistentVolumeClaim(pv *core.PersistentVolumeClaim) []string {
 | 
				
			||||||
 | 
						var warnings []string
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if pv == nil {
 | 
						if pv == nil {
 | 
				
			||||||
		return nil
 | 
							return nil
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return GetWarningsForPersistentVolumeClaimSpec(field.NewPath("spec"), pv.Spec)
 | 
						if _, ok := pv.ObjectMeta.Annotations[core.BetaStorageClassAnnotation]; ok {
 | 
				
			||||||
 | 
							warnings = append(warnings,
 | 
				
			||||||
 | 
								fmt.Sprintf(
 | 
				
			||||||
 | 
									"%s: %s",
 | 
				
			||||||
 | 
									field.NewPath("metadata", "annotations").Key(core.BetaStorageClassAnnotation),
 | 
				
			||||||
 | 
									deprecatedStorageClassAnnotationsMsg,
 | 
				
			||||||
 | 
								),
 | 
				
			||||||
 | 
							)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						warnings = append(warnings, GetWarningsForPersistentVolumeClaimSpec(field.NewPath("spec"), pv.Spec)...)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						return warnings
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func GetWarningsForPersistentVolumeClaimSpec(fieldPath *field.Path, pvSpec core.PersistentVolumeClaimSpec) []string {
 | 
					func GetWarningsForPersistentVolumeClaimSpec(fieldPath *field.Path, pvSpec core.PersistentVolumeClaimSpec) []string {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -25,6 +25,7 @@ import (
 | 
				
			|||||||
	"k8s.io/apimachinery/pkg/api/resource"
 | 
						"k8s.io/apimachinery/pkg/api/resource"
 | 
				
			||||||
	"k8s.io/apimachinery/pkg/util/sets"
 | 
						"k8s.io/apimachinery/pkg/util/sets"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
				
			||||||
	utilfeature "k8s.io/apiserver/pkg/util/feature"
 | 
						utilfeature "k8s.io/apiserver/pkg/util/feature"
 | 
				
			||||||
	featuregatetesting "k8s.io/component-base/featuregate/testing"
 | 
						featuregatetesting "k8s.io/component-base/featuregate/testing"
 | 
				
			||||||
	"k8s.io/kubernetes/pkg/apis/core"
 | 
						"k8s.io/kubernetes/pkg/apis/core"
 | 
				
			||||||
@@ -556,6 +557,20 @@ func TestWarnings(t *testing.T) {
 | 
				
			|||||||
			},
 | 
								},
 | 
				
			||||||
			expected: nil,
 | 
								expected: nil,
 | 
				
			||||||
		},
 | 
							},
 | 
				
			||||||
 | 
							{
 | 
				
			||||||
 | 
								name: "storageclass annotations warning",
 | 
				
			||||||
 | 
								template: &core.PersistentVolumeClaim{
 | 
				
			||||||
 | 
									ObjectMeta: metav1.ObjectMeta{
 | 
				
			||||||
 | 
										Name: "foo",
 | 
				
			||||||
 | 
										Annotations: map[string]string{
 | 
				
			||||||
 | 
											core.BetaStorageClassAnnotation: "",
 | 
				
			||||||
 | 
										},
 | 
				
			||||||
 | 
									},
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
								expected: []string{
 | 
				
			||||||
 | 
									`metadata.annotations[volume.beta.kubernetes.io/storage-class]: deprecated since v1.8; use "storageClassName" attribute instead`,
 | 
				
			||||||
 | 
								},
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	for _, tc := range testcases {
 | 
						for _, tc := range testcases {
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user