Documentation ¶
Overview ¶
Package testutil includes convenience functions and types to help with testing
Index ¶
- Variables
- func GzipIt(input []byte) ([]byte, error)
- func ModifyTomlConfigFile(ctx context.Context, logger *zap.Logger, dockerClient *client.Client, ...) error
- func PollForAck(ctx context.Context, chain ChainAcker, startHeight, maxHeight uint64, ...) (ibc.PacketAcknowledgement, error)
- func PollForTimeout(ctx context.Context, chain ChainTimeouter, startHeight, maxHeight uint64, ...) (ibc.PacketTimeout, error)
- func WaitForBlocks(ctx context.Context, delta int, chains ...ChainHeighter) error
- func WaitForCondition(timeoutAfter, pollingInterval time.Duration, fn func() (bool, error)) error
- func WaitForInSync(ctx context.Context, chain ChainHeighter, nodes ...ChainHeighter) error
- type BlockPoller
- type ChainAcker
- type ChainHeighter
- type ChainTimeouter
- type Toml
Constants ¶
This section is empty.
Variables ¶
var ErrNotFound = errors.New("not found")
Functions ¶
func ModifyTomlConfigFile ¶
func ModifyTomlConfigFile( ctx context.Context, logger *zap.Logger, dockerClient *client.Client, testName string, volumeName string, filePath string, modifications Toml, ) error
ModifyTomlConfigFile reads, modifies, then overwrites a toml config file, useful for config.toml, app.toml, etc.
func PollForAck ¶
func PollForAck(ctx context.Context, chain ChainAcker, startHeight, maxHeight uint64, packet ibc.Packet) (ibc.PacketAcknowledgement, error)
PollForAck attempts to find an acknowledgement containing a packet equal to the packet argument. Polling starts at startHeight and continues until maxHeight. It is safe to call this function even if the chain has yet to produce blocks for the target min/max height range. Polling delays until heights exist on the chain. Returns an error if acknowledgement not found or problems getting height or acknowledgements.
func PollForTimeout ¶
func PollForTimeout(ctx context.Context, chain ChainTimeouter, startHeight, maxHeight uint64, packet ibc.Packet) (ibc.PacketTimeout, error)
PollForTimeout attempts to find a timeout containing a packet equal to the packet argument. Otherwise, works identically to PollForAck.
func WaitForBlocks ¶
func WaitForBlocks(ctx context.Context, delta int, chains ...ChainHeighter) error
WaitForBlocks blocks until all chains reach a block height delta equal to or greater than the delta argument. If a ChainHeighter does not monotonically increase the height, this function may block program execution indefinitely.
func WaitForCondition ¶
WaitForCondition periodically executes the given function fn based on the provided pollingInterval. The function fn should return true of the desired condition is met. If the function never returns true within the timeoutAfter period, or fn returns an error, the condition will not have been met.
func WaitForInSync ¶
func WaitForInSync(ctx context.Context, chain ChainHeighter, nodes ...ChainHeighter) error
WaitForInSync blocks until all nodes have heights greater than or equal to the chain height.
Types ¶
type BlockPoller ¶
type ChainAcker ¶
type ChainAcker interface { ChainHeighter Acknowledgements(ctx context.Context, height uint64) ([]ibc.PacketAcknowledgement, error) }
ChainAcker is a chain that can get its acknowledgements at a specified height
type ChainHeighter ¶
ChainHeighter fetches the current chain block height.
type ChainTimeouter ¶
type ChainTimeouter interface { ChainHeighter Timeouts(ctx context.Context, height uint64) ([]ibc.PacketTimeout, error) }
ChainTimeouter is a chain that can get its timeouts at a specified height