mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-03 19:58:17 +00:00 
			
		
		
		
	Merge pull request #21199 from erictune/validation-helper
Auto commit by PR queue bot
This commit is contained in:
		@@ -84,6 +84,20 @@ func ValidateLabels(labels map[string]string, fldPath *field.Path) field.ErrorLi
 | 
				
			|||||||
	return allErrs
 | 
						return allErrs
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// ValidateHasLabel requires that api.ObjectMeta has a Label with key and expectedValue
 | 
				
			||||||
 | 
					func ValidateHasLabel(meta api.ObjectMeta, fldPath *field.Path, key, expectedValue string) field.ErrorList {
 | 
				
			||||||
 | 
						allErrs := field.ErrorList{}
 | 
				
			||||||
 | 
						actualValue, found := meta.Labels[key]
 | 
				
			||||||
 | 
						if !found {
 | 
				
			||||||
 | 
							allErrs = append(allErrs, field.Required(fldPath.Child("labels"), key+"="+expectedValue))
 | 
				
			||||||
 | 
							return allErrs
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if actualValue != expectedValue {
 | 
				
			||||||
 | 
							allErrs = append(allErrs, field.Invalid(fldPath.Child("labels"), meta.Labels, "expected "+key+"="+expectedValue))
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return allErrs
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// ValidateAnnotations validates that a set of annotations are correctly defined.
 | 
					// ValidateAnnotations validates that a set of annotations are correctly defined.
 | 
				
			||||||
func ValidateAnnotations(annotations map[string]string, fldPath *field.Path) field.ErrorList {
 | 
					func ValidateAnnotations(annotations map[string]string, fldPath *field.Path) field.ErrorList {
 | 
				
			||||||
	allErrs := field.ErrorList{}
 | 
						allErrs := field.ErrorList{}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -5107,3 +5107,40 @@ func TestValidateConfigMapUpdate(t *testing.T) {
 | 
				
			|||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func TestValidateHasLabel(t *testing.T) {
 | 
				
			||||||
 | 
						successCase := api.ObjectMeta{
 | 
				
			||||||
 | 
							Name:      "123",
 | 
				
			||||||
 | 
							Namespace: "ns",
 | 
				
			||||||
 | 
							Labels: map[string]string{
 | 
				
			||||||
 | 
								"other": "blah",
 | 
				
			||||||
 | 
								"foo":   "bar",
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if errs := ValidateHasLabel(successCase, field.NewPath("field"), "foo", "bar"); len(errs) != 0 {
 | 
				
			||||||
 | 
							t.Errorf("expected success: %v", errs)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						missingCase := api.ObjectMeta{
 | 
				
			||||||
 | 
							Name:      "123",
 | 
				
			||||||
 | 
							Namespace: "ns",
 | 
				
			||||||
 | 
							Labels: map[string]string{
 | 
				
			||||||
 | 
								"other": "blah",
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if errs := ValidateHasLabel(missingCase, field.NewPath("field"), "foo", "bar"); len(errs) == 0 {
 | 
				
			||||||
 | 
							t.Errorf("expected failure")
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						wrongValueCase := api.ObjectMeta{
 | 
				
			||||||
 | 
							Name:      "123",
 | 
				
			||||||
 | 
							Namespace: "ns",
 | 
				
			||||||
 | 
							Labels: map[string]string{
 | 
				
			||||||
 | 
								"other": "blah",
 | 
				
			||||||
 | 
								"foo":   "notbar",
 | 
				
			||||||
 | 
							},
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						if errs := ValidateHasLabel(wrongValueCase, field.NewPath("field"), "foo", "bar"); len(errs) == 0 {
 | 
				
			||||||
 | 
							t.Errorf("expected failure")
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user