Documentation ¶
Index ¶
- Variables
- func BuildDockerName(manifestUUID, podFullName string, container *api.Container) string
- func GetDockerPodInfo(client DockerInterface, podFullName, uuid string) (api.PodInfo, error)
- func GetRecentDockerContainersWithNameAndUUID(client DockerInterface, podFullName, uuid, containerName string) ([]*docker.Container, error)
- func HashContainer(container *api.Container) uint64
- func ParseDockerName(name string) (podFullName, uuid, containerName string, hash uint64)
- type ContainerCommandRunner
- type DockerContainerData
- type DockerContainers
- type DockerID
- type DockerInterface
- type DockerPuller
- type FakeDockerClient
- func (f *FakeDockerClient) AssertCalls(calls []string) (err error)
- func (f *FakeDockerClient) CreateContainer(c docker.CreateContainerOptions) (*docker.Container, error)
- func (f *FakeDockerClient) InspectContainer(id string) (*docker.Container, error)
- func (f *FakeDockerClient) ListContainers(options docker.ListContainersOptions) ([]docker.APIContainers, error)
- func (f *FakeDockerClient) PullImage(opts docker.PullImageOptions, auth docker.AuthConfiguration) error
- func (f *FakeDockerClient) StartContainer(id string, hostConfig *docker.HostConfig) error
- func (f *FakeDockerClient) StopContainer(id string, timeout uint) error
- type FakeDockerPuller
Constants ¶
This section is empty.
Variables ¶
var ErrNoContainersInPod = errors.New("no containers exist for this pod")
ErrNoContainersInPod is returned when there are no containers for a given pod
Functions ¶
func BuildDockerName ¶
Creates a name which can be reversed to identify both full pod name and container name.
func GetDockerPodInfo ¶
func GetDockerPodInfo(client DockerInterface, podFullName, uuid string) (api.PodInfo, error)
GetDockerPodInfo returns docker info for all containers in the pod/manifest.
func GetRecentDockerContainersWithNameAndUUID ¶
func GetRecentDockerContainersWithNameAndUUID(client DockerInterface, podFullName, uuid, containerName string) ([]*docker.Container, error)
GetRecentDockerContainersWithNameAndUUID returns a list of dead docker containers which matches the name and uuid given.
func HashContainer ¶
func ParseDockerName ¶
Upacks a container name, returning the pod full name and container name we would have used to construct the docker name. If the docker name isn't one we created, we may return empty strings.
Types ¶
type ContainerCommandRunner ¶
type ContainerCommandRunner interface {
RunInContainer(containerID string, cmd []string) ([]byte, error)
}
func NewDockerContainerCommandRunner ¶
func NewDockerContainerCommandRunner() ContainerCommandRunner
NewDockerContainerCommandRunner creates a ContainerCommandRunner which uses nsinit to run a command inside a container.
type DockerContainerData ¶
type DockerContainerData struct {
// contains filtered or unexported fields
}
DockerContainerData is the structured representation of the JSON object returned by Docker inspect
type DockerContainers ¶
type DockerContainers map[DockerID]*docker.APIContainers
DockerContainers is a map of containers
func GetKubeletDockerContainers ¶
func GetKubeletDockerContainers(client DockerInterface) (DockerContainers, error)
GetKubeletDockerContainers returns a map of docker containers that we manage. The map key is the docker container ID
func (DockerContainers) FindContainersByPodFullName ¶
func (c DockerContainers) FindContainersByPodFullName(podFullName string) map[string]*docker.APIContainers
Note, this might return containers belong to a different Pod instance with the same name
func (DockerContainers) FindPodContainer ¶
func (c DockerContainers) FindPodContainer(podFullName, uuid, containerName string) (*docker.APIContainers, bool, uint64)
type DockerID ¶
type DockerID string
DockerID is an ID of docker container. It is a type to make it clear when we're working with docker container Ids
type DockerInterface ¶
type DockerInterface interface { ListContainers(options docker.ListContainersOptions) ([]docker.APIContainers, error) InspectContainer(id string) (*docker.Container, error) CreateContainer(docker.CreateContainerOptions) (*docker.Container, error) StartContainer(id string, hostConfig *docker.HostConfig) error StopContainer(id string, timeout uint) error PullImage(opts docker.PullImageOptions, auth docker.AuthConfiguration) error }
DockerInterface is an abstract interface for testability. It abstracts the interface of docker.Client.
type DockerPuller ¶
DockerPuller is an abstract interface for testability. It abstracts image pull operations.
func NewDockerPuller ¶
func NewDockerPuller(client DockerInterface) DockerPuller
NewDockerPuller creates a new instance of the default implementation of DockerPuller.
type FakeDockerClient ¶
type FakeDockerClient struct { sync.Mutex ContainerList []docker.APIContainers Container *docker.Container Err error Stopped []string Created []string // contains filtered or unexported fields }
FakeDockerClient is a simple fake docker client, so that kubelet can be run for testing without requiring a real docker setup.
func (*FakeDockerClient) AssertCalls ¶
func (f *FakeDockerClient) AssertCalls(calls []string) (err error)
func (*FakeDockerClient) CreateContainer ¶
func (f *FakeDockerClient) CreateContainer(c docker.CreateContainerOptions) (*docker.Container, error)
CreateContainer is a test-spy implementation of DockerInterface.CreateContainer. It adds an entry "create" to the internal method call record.
func (*FakeDockerClient) InspectContainer ¶
func (f *FakeDockerClient) InspectContainer(id string) (*docker.Container, error)
InspectContainer is a test-spy implementation of DockerInterface.InspectContainer. It adds an entry "inspect" to the internal method call record.
func (*FakeDockerClient) ListContainers ¶
func (f *FakeDockerClient) ListContainers(options docker.ListContainersOptions) ([]docker.APIContainers, error)
ListContainers is a test-spy implementation of DockerInterface.ListContainers. It adds an entry "list" to the internal method call record.
func (*FakeDockerClient) PullImage ¶
func (f *FakeDockerClient) PullImage(opts docker.PullImageOptions, auth docker.AuthConfiguration) error
PullImage is a test-spy implementation of DockerInterface.StopContainer. It adds an entry "pull" to the internal method call record.
func (*FakeDockerClient) StartContainer ¶
func (f *FakeDockerClient) StartContainer(id string, hostConfig *docker.HostConfig) error
StartContainer is a test-spy implementation of DockerInterface.StartContainer. It adds an entry "start" to the internal method call record.
func (*FakeDockerClient) StopContainer ¶
func (f *FakeDockerClient) StopContainer(id string, timeout uint) error
StopContainer is a test-spy implementation of DockerInterface.StopContainer. It adds an entry "stop" to the internal method call record.
type FakeDockerPuller ¶
type FakeDockerPuller struct { sync.Mutex ImagesPulled []string // Every pull will return the first error here, and then reslice // to remove it. Will give nil errors if this slice is empty. ErrorsToInject []error }
FakeDockerPuller is a stub implementation of DockerPuller.
func (*FakeDockerPuller) Pull ¶
func (f *FakeDockerPuller) Pull(image string) (err error)
Pull records the image pull attempt, and optionally injects an error.