dockertools

package
v0.0.0-...-ac8ee45 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 17, 2014 License: Apache-2.0 Imports: 17 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

View Source
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

func BuildDockerName(manifestUUID, podFullName string, container *api.Container) string

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 HashContainer(container *api.Container) uint64

func ParseDockerName

func ParseDockerName(name string) (podFullName, uuid, containerName string, hash uint64)

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

type DockerPuller interface {
	Pull(image string) error
}

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL