services

package
v0.0.0-...-5bec9b4 Latest Latest
Warning

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

Go to latest
Published: Jan 28, 2021 License: Apache-2.0 Imports: 4 Imported by: 5

Documentation

Index

Constants

View Source
const (
	MockServicePort = 1000
)

Variables

This section is empty.

Functions

This section is empty.

Types

type AvailabilityChecker

type AvailabilityChecker interface {
	WaitForStartup(timeBetweenPolls time.Duration, maxNumRetries int) error
}

type DefaultAvailabilityChecker

type DefaultAvailabilityChecker struct {
	// contains filtered or unexported fields
}

Struct for polling a service until it's available, with configurable retry options

func NewDefaultAvailabilityChecker

func NewDefaultAvailabilityChecker(serviceId ServiceID, toCheck Service) *DefaultAvailabilityChecker

func (DefaultAvailabilityChecker) WaitForStartup

func (checker DefaultAvailabilityChecker) WaitForStartup(timeBetweenPolls time.Duration, maxNumRetries int) error

Waits for the service that was passed in at construction time to start up by making requests to the service until

the service is available or the maximum number of retries are reached

type DockerContainerInitializer

type DockerContainerInitializer interface {
	// Gets the Docker image that will be used for instantiating the Docker container
	GetDockerImage() string

	// Gets the "set" of ports that the Docker container running the service will listen on
	// This is in Docker port specification syntax, e.g. "80" (default TCP) or "80/udp"
	// It might even support ranges (e.g. "90:100/tcp"), though this is untested as of 2020-12-08
	GetUsedPorts() map[string]bool

	// GENERICS TOOD: When Go has generics, make this return type be parameterized
	/*
		Uses the IP address of the Docker container running the service and the service ID to create an implementation of
		the interface the developer has created to represent their service.

		NOTE: Because Go doesn't have generics, we can't properly parameterize the return type to be the actual service interface
		that the developer has created; nonetheless, the developer should return an implementation of their interface (which itself
		should extend Service).

		Args:
			serviceId: The ID of the service being created
			ipAddr: The IP address of the Docker container running the service
	*/
	GetService(serviceId ServiceID, ipAddr string) Service

	// GENERICS TOOD: If Go had generics, we could parameterize this entire class with an enum of the types of files this service consumes
	/*
		This method is used to declare that the service will need a set of files in order to run. To do this, the developer
		declares a set of string keys that are meaningful to the developer, and Kurtosis will create one file per key. These newly-createed
		file objects will then be passed in to the `InitializeMountedFiles` and `GetStartCommand` functions below keyed on the
		strings that the developer passed in, so that the developer can initialize the contents of the files as they please.
		Kurtosis then guarantees that these files will be made available to the service at startup time.

		NOTE: The keys that the developer returns here are ONLY used for developer identification purposes; the actual
		filenames and filepaths of the file are implementation details handled by Kurtosis!

		Returns:
			A "set" of user-defined key strings identifying the files that the service will need, which is how files will be
				identified in `InitializeMountedFiles` and `GetStartCommand`
	*/
	// TODO Rename "getFilesToGenerate"
	GetFilesToMount() map[string]bool

	/*
		Initializes the contents of the files that the developer requested in `GetFilesToMount` with whatever
			contents the developer desires. This will be called before service startup.

		Args:
			mountedFiles: A mapping of developer_key -> file_pointer, with developer_key corresponding to the keys declares in
				`GetFilesToMount`
	*/
	// TODO Rename "initializeFilesToGenerate"
	InitializeMountedFiles(mountedFiles map[string]*os.File) error

	/*
		Allows the mounting of external files into a service container by mapping files artifacts (defined in your
		test's configuration) to mountpoints on the service container.

		NOTE: As of 2021-01-06, only GZ-compressed TAR artifacts are supported.

		Returns:
			A map of filesArtifactId -> serviceContainerMountpoint, where:
				1) The map key is the ID of the files artifact as defined in your TestConfiguration.
				2) The map value is the filepath inside of the service container where the
					contents of the archive file should be mounted after decompression.
	*/
	GetFilesArtifactMountpoints() map[FilesArtifactID]string

	/*
		Kurtosis mounts the files that the developer requested in `GetFilesToMount` via a Docker volume, but Kurtosis doesn't
		know anything about the Docker image backing the service so therefore doesn't know what filepath it can safely mount
		the volume on. This function uses the developer's knowledge of the Docker image running the service to inform
		Kurtosis of a filepath where the Docker volume can be safely mounted.

		Returns:
			A filepath on the Docker image backing this service that's safe to mount the test volume on
	*/
	GetTestVolumeMountpoint() string

	/*
		Uses the given arguments to build the command that the Docker container running this service will be launched with.

		NOTE: Because the IP address of the container is an implementation detail, any references to the IP address of the
			container should use the placeholder "SERVICEIP" instead. This will get replaced at launch time with the service's
			actual IP.

		Args:
			mountedFileFilepaths: Mapping of developer_key -> initialized_file_filepath where developer_key corresponds to the keys returned
				in the `GetFilesToMount` function, and initialized_file_filepath is the path *on the Docker container* of where the
				file has been mounted. The files will have already been initialized via the `InitializeMountedFiles` function.
			ipAddr: The IP address of the service being started.

		Returns:
			The command fragments which will be used to construct the run command which will be used to launch the Docker container
				running the service. If this is nil, then no explicit command will be specified and whatever command the Dockerfile
				specifies will be run instead.
	*/
	GetStartCommand(mountedFileFilepaths map[string]string, ipAddr string) ([]string, error)
}

TODO Create a DockerContainerInitializerBuilder rather than forcing users to update their code with a new

method every time a new feature comes out!

GENERIC TOOD: If Go had generics, this would be parameterized with the subtype of Service that this returns

type FilesArtifactID

type FilesArtifactID string

The ID of an artifact containing files that should be mounted into a service container

type MockDockerContainerInitializer

type MockDockerContainerInitializer struct{}

func NewMockDockerContainerInitializer

func NewMockDockerContainerInitializer() *MockDockerContainerInitializer

func (MockDockerContainerInitializer) GetDockerImage

func (m MockDockerContainerInitializer) GetDockerImage() string

func (MockDockerContainerInitializer) GetFilesArtifactMountpoints

func (m MockDockerContainerInitializer) GetFilesArtifactMountpoints() map[FilesArtifactID]string

func (MockDockerContainerInitializer) GetFilesToMount

func (m MockDockerContainerInitializer) GetFilesToMount() map[string]bool

func (MockDockerContainerInitializer) GetService

func (m MockDockerContainerInitializer) GetService(serviceId ServiceID, ipAddr string) Service

func (MockDockerContainerInitializer) GetStartCommand

func (m MockDockerContainerInitializer) GetStartCommand(mountedFileFilepaths map[string]string, ipPlaceholder string) ([]string, error)

func (MockDockerContainerInitializer) GetTestVolumeMountpoint

func (m MockDockerContainerInitializer) GetTestVolumeMountpoint() string

func (MockDockerContainerInitializer) GetUsedPorts

func (m MockDockerContainerInitializer) GetUsedPorts() map[string]bool

func (MockDockerContainerInitializer) InitializeMountedFiles

func (m MockDockerContainerInitializer) InitializeMountedFiles(mountedFiles map[string]*os.File) error

type MockService

type MockService struct {
	// contains filtered or unexported fields
}

Mock service, for testing purposes only

func NewMockService

func NewMockService(serviceId ServiceID, ipAddr string, becomesAvailableOnCheck int) *MockService

func (MockService) GetIPAddress

func (m MockService) GetIPAddress() string

func (MockService) GetServiceID

func (m MockService) GetServiceID() ServiceID

func (*MockService) IsAvailable

func (m *MockService) IsAvailable() bool

type Service

type Service interface {
	GetServiceID() ServiceID

	// Returns the IP address of the service
	GetIPAddress() string

	// Returns true if the service is available
	IsAvailable() bool
}

The developer should implement their own use-case-specific interface that extends this one

type ServiceID

type ServiceID string

The identifier used for services with the network.

Jump to

Keyboard shortcuts

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