daemon

package
v18.9.17+incompatible Latest Latest
Warning

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

Go to latest
Published: Apr 27, 2020 License: Apache-2.0 Imports: 28 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// DefaultSwarmPort is the default port use for swarm in the tests
	DefaultSwarmPort = 2477
)

Variables

View Source
var SockRoot = filepath.Join(os.TempDir(), "docker-integration")

SockRoot holds the path of the default docker integration daemon socket

Functions

func SignalDaemonDump

func SignalDaemonDump(pid int)

SignalDaemonDump sends a signal to the daemon to write a dump file

func WithDockerdBinary

func WithDockerdBinary(dockerdBinary string) func(*Daemon)

WithDockerdBinary sets the dockerd binary to the specified one

func WithEnvironment

func WithEnvironment(e environment.Execution) func(*Daemon)

WithEnvironment sets options from internal/test/environment.Execution struct

func WithExperimental

func WithExperimental(d *Daemon)

WithExperimental sets the daemon in experimental mode

func WithInit

func WithInit(d *Daemon)

WithInit sets the daemon init

func WithSwarmDefaultAddrPool

func WithSwarmDefaultAddrPool(defaultAddrPool []string) func(*Daemon)

WithSwarmDefaultAddrPool sets the swarm default address pool to use for swarm mode

func WithSwarmDefaultAddrPoolSubnetSize

func WithSwarmDefaultAddrPoolSubnetSize(subnetSize uint32) func(*Daemon)

WithSwarmDefaultAddrPoolSubnetSize sets the subnet length mask of swarm default address pool to use for swarm mode

func WithSwarmListenAddr

func WithSwarmListenAddr(listenAddr string) func(*Daemon)

WithSwarmListenAddr sets the swarm listen addr to use for swarm mode

func WithSwarmPort

func WithSwarmPort(port int) func(*Daemon)

WithSwarmPort sets the swarm port to use for swarm mode

Types

type ConfigConstructor

type ConfigConstructor func(*swarm.Config)

ConfigConstructor defines a swarm config constructor

type Daemon

type Daemon struct {
	GlobalFlags       []string
	Root              string
	Folder            string
	Wait              chan error
	UseDefaultHost    bool
	UseDefaultTLSHost bool

	SwarmPort       int // FIXME(vdemeester) should probably not be exported
	DefaultAddrPool []string
	SubnetSize      uint32
	// cached information
	CachedInfo types.Info
	// contains filtered or unexported fields
}

Daemon represents a Docker daemon for the testing framework

func New

func New(t testingT, ops ...func(*Daemon)) *Daemon

New returns a Daemon instance to be used for testing. This will create a directory such as d123456789 in the folder specified by $DOCKER_INTEGRATION_DAEMON_DEST or $DEST. The daemon will not automatically start.

func (*Daemon) ActiveContainers

func (d *Daemon) ActiveContainers(t assert.TestingT) []string

ActiveContainers returns the list of ids of the currently running containers

func (*Daemon) Cleanup

func (d *Daemon) Cleanup(t testingT)

Cleanup cleans the daemon files : exec root (network namespaces, ...), swarmkit files

func (*Daemon) CreateConfig

func (d *Daemon) CreateConfig(t assert.TestingT, configSpec swarm.ConfigSpec) string

CreateConfig creates a config given the specified spec

func (*Daemon) CreateSecret

func (d *Daemon) CreateSecret(t assert.TestingT, secretSpec swarm.SecretSpec) string

CreateSecret creates a secret given the specified spec

func (*Daemon) CreateService

func (d *Daemon) CreateService(t assert.TestingT, f ...ServiceConstructor) string

CreateService creates a swarm service given the specified service constructor

func (*Daemon) DeleteConfig

func (d *Daemon) DeleteConfig(t assert.TestingT, id string)

DeleteConfig removes the swarm config identified by the specified id

func (*Daemon) DeleteSecret

func (d *Daemon) DeleteSecret(t assert.TestingT, id string)

DeleteSecret removes the swarm secret identified by the specified id

func (*Daemon) DumpStackAndQuit

func (d *Daemon) DumpStackAndQuit()

DumpStackAndQuit sends SIGQUIT to the daemon, which triggers it to dump its stack to its log file and exit This is used primarily for gathering debug information on test timeout

func (*Daemon) FindContainerIP

func (d *Daemon) FindContainerIP(t assert.TestingT, id string) string

FindContainerIP returns the ip of the specified container

func (*Daemon) GetConfig

func (d *Daemon) GetConfig(t assert.TestingT, id string) *swarm.Config

GetConfig returns a swarm config identified by the specified id

func (*Daemon) GetNode

func (d *Daemon) GetNode(t assert.TestingT, id string) *swarm.Node

GetNode returns a swarm node identified by the specified id

func (*Daemon) GetSecret

func (d *Daemon) GetSecret(t assert.TestingT, id string) *swarm.Secret

GetSecret returns a swarm secret identified by the specified id

func (*Daemon) GetService

func (d *Daemon) GetService(t assert.TestingT, id string) *swarm.Service

GetService returns the swarm service corresponding to the specified id

func (*Daemon) GetServiceTasks

func (d *Daemon) GetServiceTasks(t assert.TestingT, service string) []swarm.Task

GetServiceTasks returns the swarm tasks for the specified service

func (*Daemon) GetSwarm

func (d *Daemon) GetSwarm(t assert.TestingT) swarm.Swarm

GetSwarm returns the current swarm object

func (*Daemon) GetTask

func (d *Daemon) GetTask(t assert.TestingT, id string) swarm.Task

GetTask returns the swarm task identified by the specified id

func (*Daemon) ID

func (d *Daemon) ID() string

ID returns the generated id of the daemon

func (*Daemon) Info

func (d *Daemon) Info(t assert.TestingT) types.Info

Info returns the info struct for this daemon

func (*Daemon) Interrupt

func (d *Daemon) Interrupt() error

Interrupt stops the daemon by sending it an Interrupt signal

func (*Daemon) JoinTokens

func (d *Daemon) JoinTokens(t assert.TestingT) swarm.JoinTokens

JoinTokens returns the current swarm join tokens

func (*Daemon) Kill

func (d *Daemon) Kill() error

Kill will send a SIGKILL to the daemon

func (*Daemon) ListConfigs

func (d *Daemon) ListConfigs(t assert.TestingT) []swarm.Config

ListConfigs returns the list of the current swarm configs

func (*Daemon) ListNodes

func (d *Daemon) ListNodes(t assert.TestingT) []swarm.Node

ListNodes returns the list of the current swarm nodes

func (*Daemon) ListSecrets

func (d *Daemon) ListSecrets(t assert.TestingT) []swarm.Secret

ListSecrets returns the list of the current swarm secrets

func (*Daemon) ListServices

func (d *Daemon) ListServices(t assert.TestingT) []swarm.Service

ListServices returns the list of the current swarm services

func (*Daemon) LoadBusybox

func (d *Daemon) LoadBusybox(t assert.TestingT)

LoadBusybox image into the daemon

func (*Daemon) LogFileName

func (d *Daemon) LogFileName() string

LogFileName returns the path the daemon's log file

func (*Daemon) NewClient

func (d *Daemon) NewClient() (*client.Client, error)

NewClient creates new client based on daemon's socket path FIXME(vdemeester): replace NewClient with NewClientT

func (*Daemon) NewClientT

func (d *Daemon) NewClientT(t assert.TestingT) *client.Client

NewClientT creates new client based on daemon's socket path FIXME(vdemeester): replace NewClient with NewClientT

func (*Daemon) NodeID

func (d *Daemon) NodeID() string

NodeID returns the swarm mode node ID

func (*Daemon) Pid

func (d *Daemon) Pid() int

Pid returns the pid of the daemon

func (*Daemon) PluginIsNotPresent

func (d *Daemon) PluginIsNotPresent(name string) func(poll.LogT) poll.Result

PluginIsNotPresent provides a poller to check if the specified plugin is not present

func (*Daemon) PluginIsNotRunning

func (d *Daemon) PluginIsNotRunning(name string) func(poll.LogT) poll.Result

PluginIsNotRunning provides a poller to check if the specified plugin is not running

func (*Daemon) PluginIsRunning

func (d *Daemon) PluginIsRunning(name string) func(poll.LogT) poll.Result

PluginIsRunning provides a poller to check if the specified plugin is running

func (*Daemon) PluginReferenceIs

func (d *Daemon) PluginReferenceIs(name, expectedRef string) func(poll.LogT) poll.Result

PluginReferenceIs provides a poller to check if the specified plugin has the specified reference

func (*Daemon) ReadLogFile

func (d *Daemon) ReadLogFile() ([]byte, error)

ReadLogFile returns the content of the daemon log file

func (*Daemon) ReloadConfig

func (d *Daemon) ReloadConfig() error

ReloadConfig asks the daemon to reload its configuration

func (*Daemon) RemoveNode

func (d *Daemon) RemoveNode(t assert.TestingT, id string, force bool)

RemoveNode removes the specified node

func (*Daemon) RemoveService

func (d *Daemon) RemoveService(t assert.TestingT, id string)

RemoveService removes the specified service

func (*Daemon) Restart

func (d *Daemon) Restart(t testingT, args ...string)

Restart will restart the daemon by first stopping it and the starting it. If an error occurs while starting the daemon, the test will fail.

func (*Daemon) RestartWithError

func (d *Daemon) RestartWithError(arg ...string) error

RestartWithError will restart the daemon by first stopping it and then starting it.

func (*Daemon) RootDir

func (d *Daemon) RootDir() string

RootDir returns the root directory of the daemon.

func (*Daemon) RotateTokens

func (d *Daemon) RotateTokens(t assert.TestingT)

RotateTokens update the swarm to rotate tokens

func (*Daemon) Signal

func (d *Daemon) Signal(signal os.Signal) error

Signal sends the specified signal to the daemon if running

func (*Daemon) Sock

func (d *Daemon) Sock() string

Sock returns the socket path of the daemon

func (*Daemon) Start

func (d *Daemon) Start(t testingT, args ...string)

Start starts the daemon and return once it is ready to receive requests.

func (*Daemon) StartAndSwarmInit

func (d *Daemon) StartAndSwarmInit(t testingT)

StartAndSwarmInit starts the daemon (with busybox) and init the swarm

func (*Daemon) StartAndSwarmJoin

func (d *Daemon) StartAndSwarmJoin(t testingT, leader *Daemon, manager bool)

StartAndSwarmJoin starts the daemon (with busybox) and join the specified swarm as worker or manager

func (*Daemon) StartWithBusybox

func (d *Daemon) StartWithBusybox(t testingT, arg ...string)

StartWithBusybox will first start the daemon with Daemon.Start() then save the busybox image from the main daemon and load it into this Daemon instance.

func (*Daemon) StartWithError

func (d *Daemon) StartWithError(args ...string) error

StartWithError starts the daemon and return once it is ready to receive requests. It returns an error in case it couldn't start.

func (*Daemon) StartWithLogFile

func (d *Daemon) StartWithLogFile(out *os.File, providedArgs ...string) error

StartWithLogFile will start the daemon and attach its streams to a given file.

func (*Daemon) Stop

func (d *Daemon) Stop(t testingT)

Stop will send a SIGINT every second and wait for the daemon to stop. If it times out, a SIGKILL is sent. Stop will not delete the daemon directory. If a purged daemon is needed, instantiate a new one with NewDaemon. If an error occurs while starting the daemon, the test will fail.

func (*Daemon) StopWithError

func (d *Daemon) StopWithError() error

StopWithError will send a SIGINT every second and wait for the daemon to stop. If it timeouts, a SIGKILL is sent. Stop will not delete the daemon directory. If a purged daemon is needed, instantiate a new one with NewDaemon.

func (*Daemon) StorageDriver

func (d *Daemon) StorageDriver() string

StorageDriver returns the configured storage driver of the daemon

func (*Daemon) SwarmInfo

func (d *Daemon) SwarmInfo(t assert.TestingT) swarm.Info

SwarmInfo returns the swarm information of the daemon

func (*Daemon) SwarmInit

func (d *Daemon) SwarmInit(t assert.TestingT, req swarm.InitRequest)

SwarmInit initializes a new swarm cluster.

func (*Daemon) SwarmJoin

func (d *Daemon) SwarmJoin(t assert.TestingT, req swarm.JoinRequest)

SwarmJoin joins a daemon to an existing cluster.

func (*Daemon) SwarmLeave

func (d *Daemon) SwarmLeave(force bool) error

SwarmLeave forces daemon to leave current cluster.

func (*Daemon) SwarmListenAddr

func (d *Daemon) SwarmListenAddr() string

SwarmListenAddr returns the listen-addr used for the daemon

func (*Daemon) SwarmUnlock

func (d *Daemon) SwarmUnlock(req swarm.UnlockRequest) error

SwarmUnlock tries to unlock a locked swarm

func (*Daemon) UpdateConfig

func (d *Daemon) UpdateConfig(t assert.TestingT, id string, f ...ConfigConstructor)

UpdateConfig updates the swarm config identified by the specified id Currently, only label update is supported.

func (*Daemon) UpdateNode

func (d *Daemon) UpdateNode(t assert.TestingT, id string, f ...NodeConstructor)

UpdateNode updates a swarm node with the specified node constructor

func (*Daemon) UpdateSecret

func (d *Daemon) UpdateSecret(t assert.TestingT, id string, f ...SecretConstructor)

UpdateSecret updates the swarm secret identified by the specified id Currently, only label update is supported.

func (*Daemon) UpdateService

func (d *Daemon) UpdateService(t assert.TestingT, service *swarm.Service, f ...ServiceConstructor)

UpdateService updates a swarm service with the specified service constructor

func (*Daemon) UpdateSwarm

func (d *Daemon) UpdateSwarm(t assert.TestingT, f ...SpecConstructor)

UpdateSwarm updates the current swarm object with the specified spec constructors

type NodeConstructor

type NodeConstructor func(*swarm.Node)

NodeConstructor defines a swarm node constructor

type SecretConstructor

type SecretConstructor func(*swarm.Secret)

SecretConstructor defines a swarm secret constructor

type ServiceConstructor

type ServiceConstructor func(*swarm.Service)

ServiceConstructor defines a swarm service constructor function

type SpecConstructor

type SpecConstructor func(*swarm.Spec)

SpecConstructor defines a swarm spec constructor

Jump to

Keyboard shortcuts

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