Merge pull request #77814 from brandon-mabey/cri-runtime-service-error-injection

Fix error injection surface in FakeRuntimeService
This commit is contained in:
Kubernetes Prow Robot
2019-05-13 13:15:48 -07:00
committed by GitHub

View File

@@ -126,6 +126,7 @@ func (r *FakeRuntimeService) popError(f string) error {
return nil return nil
} }
err, errs := errs[0], errs[1:] err, errs := errs[0], errs[1:]
r.Errors[f] = errs
return err return err
} }
@@ -144,6 +145,9 @@ func (r *FakeRuntimeService) Version(apiVersion string) (*runtimeapi.VersionResp
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "Version") r.Called = append(r.Called, "Version")
if err := r.popError("Version"); err != nil {
return nil, err
}
return &runtimeapi.VersionResponse{ return &runtimeapi.VersionResponse{
Version: FakeVersion, Version: FakeVersion,
@@ -158,6 +162,9 @@ func (r *FakeRuntimeService) Status() (*runtimeapi.RuntimeStatus, error) {
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "Status") r.Called = append(r.Called, "Status")
if err := r.popError("Status"); err != nil {
return nil, err
}
return r.FakeStatus, nil return r.FakeStatus, nil
} }
@@ -167,6 +174,9 @@ func (r *FakeRuntimeService) RunPodSandbox(config *runtimeapi.PodSandboxConfig,
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "RunPodSandbox") r.Called = append(r.Called, "RunPodSandbox")
if err := r.popError("RunPodSandbox"); err != nil {
return "", err
}
// PodSandboxID should be randomized for real container runtime, but here just use // PodSandboxID should be randomized for real container runtime, but here just use
// fixed name from BuildSandboxName() for easily making fake sandboxes. // fixed name from BuildSandboxName() for easily making fake sandboxes.
@@ -196,6 +206,9 @@ func (r *FakeRuntimeService) StopPodSandbox(podSandboxID string) error {
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "StopPodSandbox") r.Called = append(r.Called, "StopPodSandbox")
if err := r.popError("StopPodSandbox"); err != nil {
return err
}
if s, ok := r.Sandboxes[podSandboxID]; ok { if s, ok := r.Sandboxes[podSandboxID]; ok {
s.State = runtimeapi.PodSandboxState_SANDBOX_NOTREADY s.State = runtimeapi.PodSandboxState_SANDBOX_NOTREADY
@@ -211,6 +224,9 @@ func (r *FakeRuntimeService) RemovePodSandbox(podSandboxID string) error {
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "RemovePodSandbox") r.Called = append(r.Called, "RemovePodSandbox")
if err := r.popError("RemovePodSandbox"); err != nil {
return err
}
// Remove the pod sandbox // Remove the pod sandbox
delete(r.Sandboxes, podSandboxID) delete(r.Sandboxes, podSandboxID)
@@ -223,6 +239,9 @@ func (r *FakeRuntimeService) PodSandboxStatus(podSandboxID string) (*runtimeapi.
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "PodSandboxStatus") r.Called = append(r.Called, "PodSandboxStatus")
if err := r.popError("PodSandboxStatus"); err != nil {
return nil, err
}
s, ok := r.Sandboxes[podSandboxID] s, ok := r.Sandboxes[podSandboxID]
if !ok { if !ok {
@@ -238,6 +257,9 @@ func (r *FakeRuntimeService) ListPodSandbox(filter *runtimeapi.PodSandboxFilter)
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "ListPodSandbox") r.Called = append(r.Called, "ListPodSandbox")
if err := r.popError("ListPodSandbox"); err != nil {
return nil, err
}
result := make([]*runtimeapi.PodSandbox, 0) result := make([]*runtimeapi.PodSandbox, 0)
for id, s := range r.Sandboxes { for id, s := range r.Sandboxes {
@@ -272,6 +294,10 @@ func (r *FakeRuntimeService) PortForward(*runtimeapi.PortForwardRequest) (*runti
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "PortForward") r.Called = append(r.Called, "PortForward")
if err := r.popError("PortForward"); err != nil {
return nil, err
}
return &runtimeapi.PortForwardResponse{}, nil return &runtimeapi.PortForwardResponse{}, nil
} }
@@ -280,6 +306,9 @@ func (r *FakeRuntimeService) CreateContainer(podSandboxID string, config *runtim
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "CreateContainer") r.Called = append(r.Called, "CreateContainer")
if err := r.popError("CreateContainer"); err != nil {
return "", err
}
// ContainerID should be randomized for real container runtime, but here just use // ContainerID should be randomized for real container runtime, but here just use
// fixed BuildContainerName() for easily making fake containers. // fixed BuildContainerName() for easily making fake containers.
@@ -309,6 +338,9 @@ func (r *FakeRuntimeService) StartContainer(containerID string) error {
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "StartContainer") r.Called = append(r.Called, "StartContainer")
if err := r.popError("StartContainer"); err != nil {
return err
}
c, ok := r.Containers[containerID] c, ok := r.Containers[containerID]
if !ok { if !ok {
@@ -327,6 +359,9 @@ func (r *FakeRuntimeService) StopContainer(containerID string, timeout int64) er
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "StopContainer") r.Called = append(r.Called, "StopContainer")
if err := r.popError("StopContainer"); err != nil {
return err
}
c, ok := r.Containers[containerID] c, ok := r.Containers[containerID]
if !ok { if !ok {
@@ -347,6 +382,9 @@ func (r *FakeRuntimeService) RemoveContainer(containerID string) error {
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "RemoveContainer") r.Called = append(r.Called, "RemoveContainer")
if err := r.popError("RemoveContainer"); err != nil {
return err
}
// Remove the container // Remove the container
delete(r.Containers, containerID) delete(r.Containers, containerID)
@@ -359,6 +397,9 @@ func (r *FakeRuntimeService) ListContainers(filter *runtimeapi.ContainerFilter)
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "ListContainers") r.Called = append(r.Called, "ListContainers")
if err := r.popError("ListContainers"); err != nil {
return nil, err
}
result := make([]*runtimeapi.Container, 0) result := make([]*runtimeapi.Container, 0)
for _, s := range r.Containers { for _, s := range r.Containers {
@@ -398,6 +439,9 @@ func (r *FakeRuntimeService) ContainerStatus(containerID string) (*runtimeapi.Co
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "ContainerStatus") r.Called = append(r.Called, "ContainerStatus")
if err := r.popError("ContainerStatus"); err != nil {
return nil, err
}
c, ok := r.Containers[containerID] c, ok := r.Containers[containerID]
if !ok { if !ok {
@@ -413,7 +457,7 @@ func (r *FakeRuntimeService) UpdateContainerResources(string, *runtimeapi.LinuxC
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "UpdateContainerResources") r.Called = append(r.Called, "UpdateContainerResources")
return nil return r.popError("UpdateContainerResources")
} }
func (r *FakeRuntimeService) ExecSync(containerID string, cmd []string, timeout time.Duration) (stdout []byte, stderr []byte, err error) { func (r *FakeRuntimeService) ExecSync(containerID string, cmd []string, timeout time.Duration) (stdout []byte, stderr []byte, err error) {
@@ -421,7 +465,8 @@ func (r *FakeRuntimeService) ExecSync(containerID string, cmd []string, timeout
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "ExecSync") r.Called = append(r.Called, "ExecSync")
return nil, nil, nil err = r.popError("ExecSync")
return
} }
func (r *FakeRuntimeService) Exec(*runtimeapi.ExecRequest) (*runtimeapi.ExecResponse, error) { func (r *FakeRuntimeService) Exec(*runtimeapi.ExecRequest) (*runtimeapi.ExecResponse, error) {
@@ -429,6 +474,10 @@ func (r *FakeRuntimeService) Exec(*runtimeapi.ExecRequest) (*runtimeapi.ExecResp
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "Exec") r.Called = append(r.Called, "Exec")
if err := r.popError("Exec"); err != nil {
return nil, err
}
return &runtimeapi.ExecResponse{}, nil return &runtimeapi.ExecResponse{}, nil
} }
@@ -437,11 +486,19 @@ func (r *FakeRuntimeService) Attach(req *runtimeapi.AttachRequest) (*runtimeapi.
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "Attach") r.Called = append(r.Called, "Attach")
if err := r.popError("Attach"); err != nil {
return nil, err
}
return &runtimeapi.AttachResponse{}, nil return &runtimeapi.AttachResponse{}, nil
} }
func (r *FakeRuntimeService) UpdateRuntimeConfig(runtimeCOnfig *runtimeapi.RuntimeConfig) error { func (r *FakeRuntimeService) UpdateRuntimeConfig(runtimeCOnfig *runtimeapi.RuntimeConfig) error {
return nil r.Lock()
defer r.Unlock()
r.Called = append(r.Called, "UpdateRuntimeConfig")
return r.popError("UpdateRuntimeConfig")
} }
func (r *FakeRuntimeService) SetFakeContainerStats(containerStats []*runtimeapi.ContainerStats) { func (r *FakeRuntimeService) SetFakeContainerStats(containerStats []*runtimeapi.ContainerStats) {
@@ -459,6 +516,9 @@ func (r *FakeRuntimeService) ContainerStats(containerID string) (*runtimeapi.Con
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "ContainerStats") r.Called = append(r.Called, "ContainerStats")
if err := r.popError("ContainerStats"); err != nil {
return nil, err
}
s, found := r.FakeContainerStats[containerID] s, found := r.FakeContainerStats[containerID]
if !found { if !found {
@@ -472,6 +532,9 @@ func (r *FakeRuntimeService) ListContainerStats(filter *runtimeapi.ContainerStat
defer r.Unlock() defer r.Unlock()
r.Called = append(r.Called, "ListContainerStats") r.Called = append(r.Called, "ListContainerStats")
if err := r.popError("ListContainerStats"); err != nil {
return nil, err
}
var result []*runtimeapi.ContainerStats var result []*runtimeapi.ContainerStats
for _, c := range r.Containers { for _, c := range r.Containers {