Validate that readiness probes can't set terminationGracePeriodSeconds
This commit is contained in:
		| @@ -2859,6 +2859,11 @@ func validateContainers(containers []core.Container, isInitContainers bool, volu | ||||
| 			allErrs = append(allErrs, validateLifecycle(ctr.Lifecycle, idxPath.Child("lifecycle"))...) | ||||
| 		} | ||||
| 		allErrs = append(allErrs, validateProbe(ctr.LivenessProbe, idxPath.Child("livenessProbe"))...) | ||||
| 		// Readiness-specific validation | ||||
| 		if ctr.ReadinessProbe != nil && ctr.ReadinessProbe.TerminationGracePeriodSeconds != nil { | ||||
| 			allErrs = append(allErrs, field.Invalid(idxPath.Child("readinessProbe", "terminationGracePeriodSeconds"), ctr.ReadinessProbe.TerminationGracePeriodSeconds, "must not be set for readinessProbes")) | ||||
| 		} | ||||
| 		allErrs = append(allErrs, validateProbe(ctr.StartupProbe, idxPath.Child("startupProbe"))...) | ||||
| 		// Liveness-specific validation | ||||
| 		if ctr.LivenessProbe != nil && ctr.LivenessProbe.SuccessThreshold != 1 { | ||||
| 			allErrs = append(allErrs, field.Invalid(idxPath.Child("livenessProbe", "successThreshold"), ctr.LivenessProbe.SuccessThreshold, "must be 1")) | ||||
|   | ||||
| @@ -6284,6 +6284,20 @@ func TestValidateContainers(t *testing.T) { | ||||
| 				TerminationMessagePolicy: "File", | ||||
| 			}, | ||||
| 		}, | ||||
| 		"invalid readiness probe, terminationGracePeriodSeconds set.": { | ||||
| 			{ | ||||
| 				Name:  "life-123", | ||||
| 				Image: "image", | ||||
| 				ReadinessProbe: &core.Probe{ | ||||
| 					Handler: core.Handler{ | ||||
| 						TCPSocket: &core.TCPSocketAction{}, | ||||
| 					}, | ||||
| 					TerminationGracePeriodSeconds: utilpointer.Int64Ptr(10), | ||||
| 				}, | ||||
| 				ImagePullPolicy:          "IfNotPresent", | ||||
| 				TerminationMessagePolicy: "File", | ||||
| 			}, | ||||
| 		}, | ||||
| 		"invalid liveness probe, no tcp socket port.": { | ||||
| 			{ | ||||
| 				Name:  "life-123", | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Elana Hashman
					Elana Hashman