lnwire: update testing/quick tests to new wire message updates

This commit is contained in:
Olaoluwa Osuntokun 2017-07-28 16:32:26 -07:00
parent f7800709ba
commit de30c14aea
No known key found for this signature in database
GPG Key ID: 9CC5B105D03521A2

@ -146,36 +146,52 @@ func TestLightningWireProtocol(t *testing.T) {
v[0] = reflect.ValueOf(*req) v[0] = reflect.ValueOf(*req)
}, },
MsgSingleFundingRequest: func(v []reflect.Value, r *rand.Rand) { MsgOpenChannel: func(v []reflect.Value, r *rand.Rand) {
req := SingleFundingRequest{ req := OpenChannel{
ChannelType: uint8(r.Int63()),
CoinType: uint64(r.Int63()),
FeePerKw: btcutil.Amount(r.Int63()),
FundingAmount: btcutil.Amount(r.Int63()), FundingAmount: btcutil.Amount(r.Int63()),
PushSatoshis: btcutil.Amount(r.Int63()), PushAmount: btcutil.Amount(r.Int63()),
CsvDelay: uint32(r.Int31()),
DustLimit: btcutil.Amount(r.Int63()), DustLimit: btcutil.Amount(r.Int63()),
ConfirmationDepth: uint32(r.Int31()), MaxValueInFlight: btcutil.Amount(r.Int63()),
ChannelReserve: btcutil.Amount(r.Int63()),
HtlcMinimum: uint32(r.Int31()),
FeePerKiloWeight: uint32(r.Int63()),
CsvDelay: uint16(r.Int31()),
MaxAcceptedHTLCs: uint16(r.Int31()),
ChannelFlags: byte(r.Int31()),
}
if _, err := r.Read(req.ChainHash[:]); err != nil {
t.Fatalf("unable to generate chain hash: %v", err)
return
} }
if _, err := r.Read(req.PendingChannelID[:]); err != nil { if _, err := r.Read(req.PendingChannelID[:]); err != nil {
t.Fatalf("unable to generate pending chan id: %v", err) t.Fatalf("unable to generate pending chan id: %v", err)
return return
} }
var script [34]byte
if _, err := r.Read(script[:]); err != nil {
t.Fatalf("unable to generate pending chan id: %v", err)
return
}
req.DeliveryPkScript = script[:]
var err error var err error
req.ChannelDerivationPoint, err = randPubKey() req.FundingKey, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
} }
req.CommitmentKey, err = randPubKey() req.RevocationPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.PaymentPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.DelayedPaymentPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.FirstCommitmentPoint, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
@ -183,36 +199,44 @@ func TestLightningWireProtocol(t *testing.T) {
v[0] = reflect.ValueOf(req) v[0] = reflect.ValueOf(req)
}, },
MsgSingleFundingResponse: func(v []reflect.Value, r *rand.Rand) { MsgAcceptChannel: func(v []reflect.Value, r *rand.Rand) {
req := SingleFundingResponse{ req := AcceptChannel{
CsvDelay: uint32(r.Int31()),
DustLimit: btcutil.Amount(r.Int63()), DustLimit: btcutil.Amount(r.Int63()),
ConfirmationDepth: uint32(r.Int31()), MaxValueInFlight: btcutil.Amount(r.Int63()),
ChannelReserve: btcutil.Amount(r.Int63()),
MinAcceptDepth: uint32(r.Int31()),
HtlcMinimum: uint32(r.Int31()),
CsvDelay: uint16(r.Int31()),
MaxAcceptedHTLCs: uint16(r.Int31()),
} }
if _, err := r.Read(req.PendingChannelID[:]); err != nil { if _, err := r.Read(req.PendingChannelID[:]); err != nil {
t.Fatalf("unable to generate pending chan id: %v", err) t.Fatalf("unable to generate pending chan id: %v", err)
return return
} }
var script [34]byte
if _, err := r.Read(script[:]); err != nil {
t.Fatalf("unable to generate pending chan id: %v", err)
return
}
req.DeliveryPkScript = script[:]
var err error var err error
req.ChannelDerivationPoint, err = randPubKey() req.FundingKey, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
} }
req.CommitmentKey, err = randPubKey() req.RevocationPoint, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
} }
req.RevocationKey, err = randPubKey() req.PaymentPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.DelayedPaymentPoint, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
req.FirstCommitmentPoint, err = randPubKey()
if err != nil { if err != nil {
t.Fatalf("unable to generate key: %v", err) t.Fatalf("unable to generate key: %v", err)
return return
@ -220,46 +244,37 @@ func TestLightningWireProtocol(t *testing.T) {
v[0] = reflect.ValueOf(req) v[0] = reflect.ValueOf(req)
}, },
MsgSingleFundingComplete: func(v []reflect.Value, r *rand.Rand) { MsgFundingCreated: func(v []reflect.Value, r *rand.Rand) {
req := SingleFundingComplete{} req := FundingCreated{}
if _, err := r.Read(req.PendingChannelID[:]); err != nil { if _, err := r.Read(req.PendingChannelID[:]); err != nil {
t.Fatalf("unable to generate pending chan id: %v", err) t.Fatalf("unable to generate pending chan id: %v", err)
return return
} }
if _, err := r.Read(req.FundingOutPoint.Hash[:]); err != nil { if _, err := r.Read(req.FundingPoint.Hash[:]); err != nil {
t.Fatalf("unable to generate hash: %v", err) t.Fatalf("unable to generate hash: %v", err)
return return
} }
req.FundingOutPoint.Index = uint32(r.Int31()) % math.MaxUint16 req.FundingPoint.Index = uint32(r.Int31()) % math.MaxUint16
if _, err := r.Read(req.StateHintObsfucator[:]); err != nil { req.CommitSig = testSig
t.Fatalf("unable to read state hint: %v", err)
return
}
req.CommitSignature = testSig
var err error
req.RevocationKey, err = randPubKey()
if err != nil {
t.Fatalf("unable to generate key: %v", err)
return
}
v[0] = reflect.ValueOf(req) v[0] = reflect.ValueOf(req)
}, },
MsgSingleFundingSignComplete: func(v []reflect.Value, r *rand.Rand) { MsgFundingSigned: func(v []reflect.Value, r *rand.Rand) {
var c [32]byte var c [32]byte
if _, err := r.Read(c[:]); err != nil { if _, err := r.Read(c[:]); err != nil {
t.Fatalf("unable to generate chan id: %v", err) t.Fatalf("unable to generate chan id: %v", err)
return return
} }
req := NewSingleFundingSignComplete(ChannelID(c), testSig) req := FundingSigned{
ChanID: ChannelID(c),
CommitSig: testSig,
}
v[0] = reflect.ValueOf(*req) v[0] = reflect.ValueOf(req)
}, },
MsgFundingLocked: func(v []reflect.Value, r *rand.Rand) { MsgFundingLocked: func(v []reflect.Value, r *rand.Rand) {
@ -300,6 +315,12 @@ func TestLightningWireProtocol(t *testing.T) {
} }
req.CommitSig = testSig req.CommitSig = testSig
numSigs := uint16(r.Int31n(1020))
req.HtlcSigs = make([]*btcec.Signature, numSigs)
for i := 0; i < int(numSigs); i++ {
req.HtlcSigs[i] = testSig
}
v[0] = reflect.ValueOf(*req) v[0] = reflect.ValueOf(*req)
}, },
MsgRevokeAndAck: func(v []reflect.Value, r *rand.Rand) { MsgRevokeAndAck: func(v []reflect.Value, r *rand.Rand) {
@ -312,11 +333,6 @@ func TestLightningWireProtocol(t *testing.T) {
t.Fatalf("unable to generate bytes: %v", err) t.Fatalf("unable to generate bytes: %v", err)
return return
} }
if _, err := r.Read(req.NextRevocationHash[:]); err != nil {
t.Fatalf("unable to generate bytes: %v", err)
return
}
var err error var err error
req.NextRevocationKey, err = randPubKey() req.NextRevocationKey, err = randPubKey()
if err != nil { if err != nil {
@ -452,26 +468,26 @@ func TestLightningWireProtocol(t *testing.T) {
}, },
}, },
{ {
msgType: MsgSingleFundingRequest, msgType: MsgOpenChannel,
scenario: func(m SingleFundingRequest) bool { scenario: func(m OpenChannel) bool {
return mainScenario(&m) return mainScenario(&m)
}, },
}, },
{ {
msgType: MsgSingleFundingResponse, msgType: MsgAcceptChannel,
scenario: func(m SingleFundingResponse) bool { scenario: func(m AcceptChannel) bool {
return mainScenario(&m) return mainScenario(&m)
}, },
}, },
{ {
msgType: MsgSingleFundingComplete, msgType: MsgFundingCreated,
scenario: func(m SingleFundingComplete) bool { scenario: func(m FundingCreated) bool {
return mainScenario(&m) return mainScenario(&m)
}, },
}, },
{ {
msgType: MsgSingleFundingSignComplete, msgType: MsgFundingSigned,
scenario: func(m SingleFundingSignComplete) bool { scenario: func(m FundingSigned) bool {
return mainScenario(&m) return mainScenario(&m)
}, },
}, },