itest: make commit type enum

To prepare for adding more commit types to test for basic channel
funding, we make the commit type an enum that gets its own set of
subtests.
This commit is contained in:
Johan T. Halseth 2020-03-06 16:11:48 +01:00
parent f95a82bf5f
commit 51c5352ae4
No known key found for this signature in database
GPG Key ID: 15BAADA29DA20D26

@ -953,6 +953,43 @@ func testOnchainFundRecovery(net *lntest.NetworkHarness, t *harnessTest) {
restoreCheckBalance(6*btcutil.SatoshiPerBitcoin, 6, 20, nil) restoreCheckBalance(6*btcutil.SatoshiPerBitcoin, 6, 20, nil)
} }
// commitType is a simple enum used to run though the basic funding flow with
// different commitment formats.
type commitType byte
const (
// commitTypeLegacy is the old school commitment type.
commitTypeLegacy = iota
// commiTypeTweakless is the commitment type where the remote key is
// static (non-tweaked).
commitTypeTweakless
)
// String returns that name of the commitment type.
func (c commitType) String() string {
switch c {
case commitTypeLegacy:
return "legacy"
case commitTypeTweakless:
return "tweakless"
default:
return "invalid"
}
}
// Args returns the command line flag to supply to enable this commitment type.
func (c commitType) Args() []string {
switch c {
case commitTypeLegacy:
return []string{"--legacyprotocol.committweak"}
case commitTypeTweakless:
return []string{}
}
return nil
}
// basicChannelFundingTest is a sub-test of the main testBasicChannelFunding // basicChannelFundingTest is a sub-test of the main testBasicChannelFunding
// test. Given two nodes: Alice and Bob, it'll assert proper channel creation, // test. Given two nodes: Alice and Bob, it'll assert proper channel creation,
// then return a function closure that should be called to assert proper // then return a function closure that should be called to assert proper
@ -1049,19 +1086,23 @@ func testBasicChannelFunding(net *lntest.NetworkHarness, t *harnessTest) {
ctxb := context.Background() ctxb := context.Background()
// Run through the test with combinations of all the different
// commitment types.
allTypes := []commitType{
commitTypeLegacy,
commitTypeTweakless,
}
test: test:
// We'll test all possible combinations of the feature bit presence // We'll test all possible combinations of the feature bit presence
// that both nodes can signal for this new channel type. We'll make a // that both nodes can signal for this new channel type. We'll make a
// new Carol+Dave for each test instance as well. // new Carol+Dave for each test instance as well.
for _, carolTweakless := range []bool{true, false} { for _, carolCommitType := range allTypes {
for _, daveTweakless := range []bool{true, false} { for _, daveCommitType := range allTypes {
// Based on the current tweak variable for Carol, we'll // Based on the current tweak variable for Carol, we'll
// preferentially signal the legacy commitment format. // preferentially signal the legacy commitment format.
// We do the same for Dave shortly below. // We do the same for Dave shortly below.
var carolArgs []string carolArgs := carolCommitType.Args()
if !carolTweakless {
carolArgs = []string{"--legacyprotocol.committweak"}
}
carol, err := net.NewNode("Carol", carolArgs) carol, err := net.NewNode("Carol", carolArgs)
if err != nil { if err != nil {
t.Fatalf("unable to create new node: %v", err) t.Fatalf("unable to create new node: %v", err)
@ -1075,10 +1116,7 @@ test:
t.Fatalf("unable to send coins to carol: %v", err) t.Fatalf("unable to send coins to carol: %v", err)
} }
var daveArgs []string daveArgs := daveCommitType.Args()
if !daveTweakless {
daveArgs = []string{"--legacyprotocol.committweak"}
}
dave, err := net.NewNode("Dave", daveArgs) dave, err := net.NewNode("Dave", daveArgs)
if err != nil { if err != nil {
t.Fatalf("unable to create new node: %v", err) t.Fatalf("unable to create new node: %v", err)
@ -1093,8 +1131,8 @@ test:
t.Fatalf("unable to connect peers: %v", err) t.Fatalf("unable to connect peers: %v", err)
} }
testName := fmt.Sprintf("carol_tweak=%v,dave_tweak=%v", testName := fmt.Sprintf("carol_commit=%v,dave_commit=%v",
carolTweakless, daveTweakless) carolCommitType, daveCommitType)
ht := t ht := t
success := t.t.Run(testName, func(t *testing.T) { success := t.t.Run(testName, func(t *testing.T) {
@ -1105,6 +1143,10 @@ test:
t.Fatalf("failed funding flow: %v", err) t.Fatalf("failed funding flow: %v", err)
} }
carolTweakless := carolCommitType == commitTypeTweakless
daveTweakless := daveCommitType == commitTypeTweakless
tweaklessSignalled := carolTweakless && daveTweakless tweaklessSignalled := carolTweakless && daveTweakless
tweaklessChans := (carolChannel.StaticRemoteKey && tweaklessChans := (carolChannel.StaticRemoteKey &&
daveChannel.StaticRemoteKey) daveChannel.StaticRemoteKey)