mirror of https://github.com/k3s-io/k3s
204 lines
5.1 KiB
Go
204 lines
5.1 KiB
Go
/*
|
|
Copyright 2015 Google Inc. All rights reserved.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package container
|
|
|
|
import (
|
|
"fmt"
|
|
"reflect"
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/api"
|
|
"github.com/GoogleCloudPlatform/kubernetes/pkg/volume"
|
|
)
|
|
|
|
// FakeRuntime is a fake container runtime for testing.
|
|
type FakeRuntime struct {
|
|
sync.Mutex
|
|
CalledFunctions []string
|
|
Podlist []*Pod
|
|
ContainerList []*Container
|
|
PodStatus api.PodStatus
|
|
StartedPods []string
|
|
KilledPods []string
|
|
StartedContainers []string
|
|
KilledContainers []string
|
|
VersionInfo map[string]string
|
|
Err error
|
|
}
|
|
|
|
type FakeRuntimeCache struct {
|
|
getter podsGetter
|
|
}
|
|
|
|
func NewFakeRuntimeCache(getter podsGetter) RuntimeCache {
|
|
return &FakeRuntimeCache{getter}
|
|
}
|
|
|
|
func (f *FakeRuntimeCache) GetPods() ([]*Pod, error) {
|
|
return f.getter.GetPods(false)
|
|
}
|
|
|
|
func (f *FakeRuntimeCache) ForceUpdateIfOlder(time.Time) error {
|
|
return nil
|
|
}
|
|
|
|
// ClearCalls resets the FakeRuntime to the initial state.
|
|
func (f *FakeRuntime) ClearCalls() {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = []string{}
|
|
f.Podlist = []*Pod{}
|
|
f.ContainerList = []*Container{}
|
|
f.PodStatus = api.PodStatus{}
|
|
f.StartedPods = []string{}
|
|
f.KilledPods = []string{}
|
|
f.StartedContainers = []string{}
|
|
f.KilledContainers = []string{}
|
|
f.VersionInfo = map[string]string{}
|
|
f.Err = nil
|
|
}
|
|
|
|
func (f *FakeRuntime) assertList(expect []string, test []string) error {
|
|
if !reflect.DeepEqual(expect, test) {
|
|
return fmt.Errorf("expected %#v, got %#v", expect, test)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// AssertCalls test if the invoked functions are as expected.
|
|
func (f *FakeRuntime) AssertCalls(calls []string) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
return f.assertList(calls, f.CalledFunctions)
|
|
}
|
|
|
|
func (f *FakeRuntime) AssertStartedPods(pods []string) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
return f.assertList(pods, f.StartedPods)
|
|
}
|
|
|
|
func (f *FakeRuntime) AssertKilledPods(pods []string) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
return f.assertList(pods, f.KilledPods)
|
|
}
|
|
|
|
func (f *FakeRuntime) AssertStartedContainers(containers []string) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
return f.assertList(containers, f.StartedContainers)
|
|
}
|
|
|
|
func (f *FakeRuntime) AssertKilledContainers(containers []string) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
return f.assertList(containers, f.KilledContainers)
|
|
}
|
|
|
|
func (f *FakeRuntime) Version() (map[string]string, error) {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "Version")
|
|
return f.VersionInfo, f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) GetPods(all bool) ([]*Pod, error) {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "GetPods")
|
|
return f.Podlist, f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) RunPod(pod *api.Pod, volumeMap map[string]volume.VolumePlugin) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "RunPod")
|
|
f.StartedPods = append(f.StartedPods, string(pod.UID))
|
|
for _, c := range pod.Spec.Containers {
|
|
f.StartedContainers = append(f.StartedContainers, c.Name)
|
|
}
|
|
return f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) KillPod(pod *api.Pod) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "KillPod")
|
|
f.KilledPods = append(f.KilledPods, string(pod.UID))
|
|
for _, c := range pod.Spec.Containers {
|
|
f.KilledContainers = append(f.KilledContainers, c.Name)
|
|
}
|
|
return f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) RunContainerInPod(container api.Container, pod *api.Pod, volumeMap map[string]volume.VolumePlugin) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "RunContainerInPod")
|
|
f.StartedContainers = append(f.StartedContainers, container.Name)
|
|
|
|
pod.Spec.Containers = append(pod.Spec.Containers, container)
|
|
for _, c := range pod.Spec.Containers {
|
|
if c.Name == container.Name { // Container already in the pod.
|
|
return f.Err
|
|
}
|
|
}
|
|
pod.Spec.Containers = append(pod.Spec.Containers, container)
|
|
return f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) KillContainerInPod(container api.Container, pod *api.Pod) error {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "KillContainerInPod")
|
|
f.KilledContainers = append(f.KilledContainers, container.Name)
|
|
|
|
var containers []api.Container
|
|
for _, c := range pod.Spec.Containers {
|
|
if c.Name == container.Name {
|
|
continue
|
|
}
|
|
containers = append(containers, c)
|
|
}
|
|
return f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) GetPodStatus(pod *Pod) (api.PodStatus, error) {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "GetPodStatus")
|
|
return f.PodStatus, f.Err
|
|
}
|
|
|
|
func (f *FakeRuntime) GetContainers(all bool) ([]*Container, error) {
|
|
f.Lock()
|
|
defer f.Unlock()
|
|
|
|
f.CalledFunctions = append(f.CalledFunctions, "GetContainers")
|
|
return f.ContainerList, f.Err
|
|
}
|