Documentation ¶
Overview ¶
Package docker contains resources needed to setup docker containers for M3 tests.
Index ¶
- func AttachToExistingContainers(coordinatorContainerName string, dbNodesContainersNames []string) (resources.M3Resources, error)
- func NewPrometheus(opts PrometheusOptions) resources.ExternalResources
- func SetupNetwork(pool *dockertest.Pool) error
- func SetupSingleM3DBNode(opts ...SetupOptions) (resources.M3Resources, error)
- type Image
- type PrometheusOptions
- type Resource
- func (c *Resource) Close() error
- func (c *Resource) Closed() bool
- func (c *Resource) Exec(commands ...string) (string, error)
- func (c *Resource) GetPort(bindPort int) (int, error)
- func (c *Resource) GetURL(port int, path string) string
- func (c *Resource) GoalStateExec(verifier resources.GoalStateVerifier, commands ...string) error
- type ResourceOptions
- type SetupOptions
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func AttachToExistingContainers ¶
func AttachToExistingContainers( coordinatorContainerName string, dbNodesContainersNames []string, ) (resources.M3Resources, error)
AttachToExistingContainers attaches docker API to an existing coordinator and one or more dbnode containers.
func NewPrometheus ¶ added in v1.3.0
func NewPrometheus(opts PrometheusOptions) resources.ExternalResources
NewPrometheus creates a new docker-backed Prometheus that implements the resources.ExternalResources interface.
func SetupNetwork ¶ added in v1.4.0
func SetupNetwork(pool *dockertest.Pool) error
SetupNetwork sets up a network within docker.
func SetupSingleM3DBNode ¶
func SetupSingleM3DBNode(opts ...SetupOptions) (resources.M3Resources, error)
SetupSingleM3DBNode creates docker resources representing a setup with a single DB node.
Types ¶
type PrometheusOptions ¶ added in v1.3.0
type PrometheusOptions struct { // Pool is the connection to the docker API Pool *dockertest.Pool // PathToCfg contains the path to the prometheus.yml configuration // file to be used on startup. PathToCfg string // InstrumentOptions are the instrument.Options to use when // creating the resource. InstrumentOptions instrument.Options }
PrometheusOptions contains the options for spinning up docker container running Prometheus
type Resource ¶ added in v1.4.0
type Resource struct {
// contains filtered or unexported fields
}
Resource is an object that provides a handle to a service being spun up via docker.
func NewDockerResource ¶ added in v1.4.0
func NewDockerResource( pool *dockertest.Pool, resourceOpts ResourceOptions, ) (*Resource, error)
NewDockerResource creates a new DockerResource.
func (*Resource) GoalStateExec ¶ added in v1.4.0
func (c *Resource) GoalStateExec( verifier resources.GoalStateVerifier, commands ...string, ) error
GoalStateExec runs commands within a container until a specified goal state is met.
type ResourceOptions ¶ added in v1.4.0
type ResourceOptions struct { OverrideDefaults bool Source string ContainerName string Image Image PortList []int // Mounts creates mounts in the container that map back to a resource // on the host system. Mounts []string // TmpfsMounts creates mounts to the container's temporary file system TmpfsMounts []string InstrumentOpts instrument.Options }
ResourceOptions returns options for creating a Resource.
type SetupOptions ¶
type SetupOptions func(*setupOptions)
SetupOptions is a setup option.
func WithCoordinatorImage ¶
func WithCoordinatorImage(name, tag string) SetupOptions
WithCoordinatorImage sets an option to use an image name and tag for the coordinator.
func WithDBNodeImage ¶
func WithDBNodeImage(name, tag string) SetupOptions
WithDBNodeImage sets an option to use an image name and tag for the DB node.
func WithExistingCluster ¶
func WithExistingCluster(dbNodeContainerName, coordinatorContainerName string) SetupOptions
WithExistingCluster sets the names of already running containers dbnode and coordinator containers that should be used for tests.