lntest: re-write AssertChannelExists to use WaitPredicate internally
Recent changes to the funding manger’s state machine have resulted in some additional database calls during the funding process. This has slowed down the tests by a few ms here and there. Recent integration test runs have begun to fail due to AssertChannelExists returning an error as the channel hasn’t fully propagated yet. In order to remedy this, we’ll now use WaitPredicate to poll repeatedly to ensure. This should serve to reduce flakes encountered within the integration tests.
This commit is contained in:
parent
72147fe1e5
commit
c3f84b1a47
@ -766,13 +766,31 @@ func (n *NetworkHarness) AssertChannelExists(ctx context.Context,
|
|||||||
node *HarnessNode, chanPoint *wire.OutPoint) error {
|
node *HarnessNode, chanPoint *wire.OutPoint) error {
|
||||||
|
|
||||||
req := &lnrpc.ListChannelsRequest{}
|
req := &lnrpc.ListChannelsRequest{}
|
||||||
resp, err := node.ListChannels(ctx, req)
|
|
||||||
if err != nil {
|
var predErr error
|
||||||
return fmt.Errorf("unable fetch node's channels: %v", err)
|
pred := func() bool {
|
||||||
|
resp, err := node.ListChannels(ctx, req)
|
||||||
|
if err != nil {
|
||||||
|
predErr = fmt.Errorf("unable fetch node's channels: %v", err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, channel := range resp.Channels {
|
||||||
|
if channel.ChannelPoint == chanPoint.String() {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, channel := range resp.Channels {
|
if err := WaitPredicate(pred, time.Second*15); err != nil {
|
||||||
if channel.ChannelPoint == chanPoint.String() {
|
return fmt.Errorf("channel not found: %v", predErr)
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
// WaitPredicate is a helper test function that will wait for a timeout period
|
// WaitPredicate is a helper test function that will wait for a timeout period
|
||||||
// of time until the passed predicate returns true. This function is helpful as
|
// of time until the passed predicate returns true. This function is helpful as
|
||||||
// timing doesn't always line up well when running integration tests with
|
// timing doesn't always line up well when running integration tests with
|
||||||
|
Loading…
Reference in New Issue
Block a user