// updateProbe updates only those fields with flags set by the user func (o *ProbeOptions) updateProbe(probe *kapi.Probe) { switch { case o.Command != nil: probe.Handler = kapi.Handler{Exec: &kapi.ExecAction{Command: o.Command}} case o.HTTPGetAction != nil: probe.Handler = kapi.Handler{HTTPGet: o.HTTPGetAction} case len(o.OpenTCPSocket) > 0: probe.Handler = kapi.Handler{TCPSocket: &kapi.TCPSocketAction{Port: intOrString(o.OpenTCPSocket)}} } if o.InitialDelaySeconds != nil { probe.InitialDelaySeconds = int32(*o.InitialDelaySeconds) } if o.SuccessThreshold != nil { probe.SuccessThreshold = int32(*o.SuccessThreshold) } if o.FailureThreshold != nil { probe.FailureThreshold = int32(*o.FailureThreshold) } if o.TimeoutSeconds != nil { probe.TimeoutSeconds = int32(*o.TimeoutSeconds) } if o.PeriodSeconds != nil { probe.PeriodSeconds = int32(*o.PeriodSeconds) } }
func setTestProbe(pod *api.Pod, probeType probeType, probeSpec api.Probe) { // All tests rely on the fake exec prober. probeSpec.Handler = api.Handler{ Exec: &api.ExecAction{}, } // Apply test defaults, overwridden for test speed. defaults := map[string]int64{ "TimeoutSeconds": 1, "PeriodSeconds": 1, "SuccessThreshold": 1, "FailureThreshold": 1, } for field, value := range defaults { f := reflect.ValueOf(&probeSpec).Elem().FieldByName(field) if f.Int() == 0 { f.SetInt(value) } } switch probeType { case readiness: pod.Spec.Containers[0].ReadinessProbe = &probeSpec case liveness: pod.Spec.Containers[0].LivenessProbe = &probeSpec } }
func newTestWorker(m *manager, probeType probeType, probeSpec api.Probe) *worker { // All tests rely on the fake exec prober. probeSpec.Handler = api.Handler{ Exec: &api.ExecAction{}, } pod := getTestPod(probeType, probeSpec) return newWorker(m, probeType, &pod, pod.Spec.Containers[0]) }
func getTestPod(probeType probeType, probeSpec api.Probe) api.Pod { container := api.Container{ Name: testContainerName, } // All tests rely on the fake exec prober. probeSpec.Handler = api.Handler{ Exec: &api.ExecAction{}, } // Apply test defaults, overwridden for test speed. defaults := map[string]int64{ "TimeoutSeconds": 1, "PeriodSeconds": 1, "SuccessThreshold": 1, "FailureThreshold": 1, } for field, value := range defaults { f := reflect.ValueOf(&probeSpec).Elem().FieldByName(field) if f.Int() == 0 { f.SetInt(value) } } switch probeType { case readiness: container.ReadinessProbe = &probeSpec case liveness: container.LivenessProbe = &probeSpec } pod := api.Pod{ Spec: api.PodSpec{ Containers: []api.Container{container}, RestartPolicy: api.RestartPolicyNever, }, } pod.Name = "testPod" pod.UID = testPodUID return pod }
func newTestWorker(m *manager, probeType probeType, probeSpec api.Probe) *worker { // All tests rely on the fake exec prober. probeSpec.Handler = api.Handler{ Exec: &api.ExecAction{}, } // Apply default values. defaults := map[string]int64{ "TimeoutSeconds": 1, "PeriodSeconds": 10, "SuccessThreshold": 1, "FailureThreshold": 3, } for field, value := range defaults { f := reflect.ValueOf(&probeSpec).Elem().FieldByName(field) if f.Int() == 0 { f.SetInt(value) } } pod := getTestPod(probeType, probeSpec) return newWorker(m, probeType, &pod, pod.Spec.Containers[0]) }