lntest: check close initiator in basic channel itest

Update channel updates and subscription itest to check that close
initiator is appropriately set for cooperative and force closes for the
local and remote party.
This commit is contained in:
carla 2020-02-21 13:24:24 +02:00
parent e74b6f88b7
commit b3e6395635
No known key found for this signature in database
GPG Key ID: 4CA7FE54A6213C91

@ -6382,7 +6382,8 @@ func subscribeChannelNotifications(ctxb context.Context, t *harnessTest,
// verifyCloseUpdate is used to verify that a closed channel update is of the // verifyCloseUpdate is used to verify that a closed channel update is of the
// expected type. // expected type.
func verifyCloseUpdate(chanUpdate *lnrpc.ChannelEventUpdate, func verifyCloseUpdate(chanUpdate *lnrpc.ChannelEventUpdate,
force bool, forceType lnrpc.ChannelCloseSummary_ClosureType) error { closeType lnrpc.ChannelCloseSummary_ClosureType,
closeInitiator lnrpc.ChannelCloseSummary_Initiator) error {
// We should receive one inactive and one closed notification // We should receive one inactive and one closed notification
// for each channel. // for each channel.
@ -6401,23 +6402,19 @@ func verifyCloseUpdate(chanUpdate *lnrpc.ChannelEventUpdate,
chanUpdate.Type) chanUpdate.Type)
} }
switch force { if update.ClosedChannel.CloseType != closeType {
case true: return fmt.Errorf("channel closure type "+
if update.ClosedChannel.CloseType != forceType { "mismatch: expected %v, got %v",
return fmt.Errorf("channel closure type mismatch: "+ closeType,
"expected %v, got %v", update.ClosedChannel.CloseType)
forceType,
update.ClosedChannel.CloseType)
}
case false:
if update.ClosedChannel.CloseType !=
lnrpc.ChannelCloseSummary_COOPERATIVE_CLOSE {
return fmt.Errorf("channel closure type "+
"mismatch: expected %v, got %v",
lnrpc.ChannelCloseSummary_COOPERATIVE_CLOSE,
update.ClosedChannel.CloseType)
}
} }
if update.ClosedChannel.CloseInitiator != closeInitiator {
return fmt.Errorf("expected close intiator: %v, got: %v",
closeInitiator,
update.ClosedChannel.CloseInitiator)
}
default: default:
return fmt.Errorf("channel update channel of wrong type, "+ return fmt.Errorf("channel update channel of wrong type, "+
"expected closed channel, got %T", "expected closed channel, got %T",
@ -6529,18 +6526,29 @@ func testBasicChannelCreationAndUpdates(net *lntest.NetworkHarness, t *harnessTe
// verifyCloseUpdatesReceived is used to verify that Alice and Bob // verifyCloseUpdatesReceived is used to verify that Alice and Bob
// receive the correct channel updates in order. // receive the correct channel updates in order.
verifyCloseUpdatesReceived := func(sub channelSubscription, verifyCloseUpdatesReceived := func(sub channelSubscription,
forceType lnrpc.ChannelCloseSummary_ClosureType) error { forceType lnrpc.ChannelCloseSummary_ClosureType,
closeInitiator lnrpc.ChannelCloseSummary_Initiator) error {
// Ensure one inactive and one closed notification is received for each // Ensure one inactive and one closed notification is received for each
// closed channel. // closed channel.
numChannelUpds := 0 numChannelUpds := 0
for numChannelUpds < 2*numChannels { for numChannelUpds < 2*numChannels {
// Every other channel should be force closed. expectedCloseType := lnrpc.ChannelCloseSummary_COOPERATIVE_CLOSE
// Every other channel should be force closed. If this
// channel was force closed, set the expected close type
// the the type passed in.
force := (numChannelUpds/2)%2 == 0 force := (numChannelUpds/2)%2 == 0
if force {
expectedCloseType = forceType
}
select { select {
case chanUpdate := <-sub.updateChan: case chanUpdate := <-sub.updateChan:
err := verifyCloseUpdate(chanUpdate, force, forceType) err := verifyCloseUpdate(
chanUpdate, expectedCloseType,
closeInitiator,
)
if err != nil { if err != nil {
return err return err
} }
@ -6549,9 +6557,10 @@ func testBasicChannelCreationAndUpdates(net *lntest.NetworkHarness, t *harnessTe
case err := <-sub.errChan: case err := <-sub.errChan:
return err return err
case <-time.After(time.Second * 10): case <-time.After(time.Second * 10):
return fmt.Errorf("timeout waiting for channel "+ return fmt.Errorf("timeout waiting "+
"notifications, only received %d/%d "+ "for channel notifications, only "+
"chanupds", numChannelUpds, 2*numChannels) "received %d/%d chanupds",
numChannelUpds, 2*numChannels)
} }
} }
@ -6560,15 +6569,21 @@ func testBasicChannelCreationAndUpdates(net *lntest.NetworkHarness, t *harnessTe
// Verify Bob receives all closed channel notifications. He should // Verify Bob receives all closed channel notifications. He should
// receive a remote force close notification for force closed channels. // receive a remote force close notification for force closed channels.
// All channels (cooperatively and force closed) should have a remote
// close initiator because Alice closed the channels.
if err := verifyCloseUpdatesReceived(bobChanSub, if err := verifyCloseUpdatesReceived(bobChanSub,
lnrpc.ChannelCloseSummary_REMOTE_FORCE_CLOSE); err != nil { lnrpc.ChannelCloseSummary_REMOTE_FORCE_CLOSE,
lnrpc.ChannelCloseSummary_REMOTE); err != nil {
t.Fatalf("errored verifying close updates: %v", err) t.Fatalf("errored verifying close updates: %v", err)
} }
// Verify Alice receives all closed channel notifications. She should // Verify Alice receives all closed channel notifications. She should
// receive a remote force close notification for force closed channels. // receive a remote force close notification for force closed channels.
// All channels (cooperatively and force closed) should have a local
// close initiator because Alice closed the channels.
if err := verifyCloseUpdatesReceived(aliceChanSub, if err := verifyCloseUpdatesReceived(aliceChanSub,
lnrpc.ChannelCloseSummary_LOCAL_FORCE_CLOSE); err != nil { lnrpc.ChannelCloseSummary_LOCAL_FORCE_CLOSE,
lnrpc.ChannelCloseSummary_LOCAL); err != nil {
t.Fatalf("errored verifying close updates: %v", err) t.Fatalf("errored verifying close updates: %v", err)
} }
} }