watchtower/wtwire/init_test: table test CheckRemoteInit
This commit is contained in:
parent
572537874b
commit
40df51eaaa
106
watchtower/wtwire/init_test.go
Normal file
106
watchtower/wtwire/init_test.go
Normal file
@ -0,0 +1,106 @@
|
||||
package wtwire_test
|
||||
|
||||
import (
|
||||
"testing"
|
||||
|
||||
"github.com/btcsuite/btcd/chaincfg"
|
||||
"github.com/btcsuite/btcd/chaincfg/chainhash"
|
||||
"github.com/lightningnetwork/lnd/lnwire"
|
||||
"github.com/lightningnetwork/lnd/watchtower/wtwire"
|
||||
)
|
||||
|
||||
var (
|
||||
testnetChainHash = *chaincfg.TestNet3Params.GenesisHash
|
||||
mainnetChainHash = *chaincfg.MainNetParams.GenesisHash
|
||||
)
|
||||
|
||||
type checkRemoteInitTest struct {
|
||||
name string
|
||||
lFeatures *lnwire.RawFeatureVector
|
||||
lHash chainhash.Hash
|
||||
rFeatures *lnwire.RawFeatureVector
|
||||
rHash chainhash.Hash
|
||||
expErr error
|
||||
}
|
||||
|
||||
var checkRemoteInitTests = []checkRemoteInitTest{
|
||||
{
|
||||
name: "same chain, local-optional remote-required",
|
||||
lFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsOptional),
|
||||
lHash: testnetChainHash,
|
||||
rFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsRequired),
|
||||
rHash: testnetChainHash,
|
||||
},
|
||||
{
|
||||
name: "same chain, local-required remote-optional",
|
||||
lFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsRequired),
|
||||
lHash: testnetChainHash,
|
||||
rFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsOptional),
|
||||
rHash: testnetChainHash,
|
||||
},
|
||||
{
|
||||
name: "different chain, local-optional remote-required",
|
||||
lFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsOptional),
|
||||
lHash: testnetChainHash,
|
||||
rFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsRequired),
|
||||
rHash: mainnetChainHash,
|
||||
expErr: wtwire.NewErrUnknownChainHash(mainnetChainHash),
|
||||
},
|
||||
{
|
||||
name: "different chain, local-required remote-optional",
|
||||
lFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsOptional),
|
||||
lHash: testnetChainHash,
|
||||
rFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsRequired),
|
||||
rHash: mainnetChainHash,
|
||||
expErr: wtwire.NewErrUnknownChainHash(mainnetChainHash),
|
||||
},
|
||||
{
|
||||
name: "same chain, remote-unknown-required",
|
||||
lFeatures: lnwire.NewRawFeatureVector(wtwire.WtSessionsOptional),
|
||||
lHash: testnetChainHash,
|
||||
rFeatures: lnwire.NewRawFeatureVector(lnwire.GossipQueriesRequired),
|
||||
rHash: testnetChainHash,
|
||||
expErr: wtwire.NewErrUnknownRequiredFeatures(
|
||||
lnwire.GossipQueriesRequired,
|
||||
),
|
||||
},
|
||||
}
|
||||
|
||||
// TestCheckRemoteInit asserts the behavior of CheckRemoteInit when called with
|
||||
// the remote party's Init message and the default wtwire.Features. We assert
|
||||
// the validity of advertised features from the perspective of both client and
|
||||
// server, as well as failure cases such as differing chain hashes or unknown
|
||||
// required features.
|
||||
func TestCheckRemoteInit(t *testing.T) {
|
||||
for _, test := range checkRemoteInitTests {
|
||||
t.Run(test.name, func(t *testing.T) {
|
||||
testCheckRemoteInit(t, test)
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
func testCheckRemoteInit(t *testing.T, test checkRemoteInitTest) {
|
||||
localInit := wtwire.NewInitMessage(test.lFeatures, test.lHash)
|
||||
remoteInit := wtwire.NewInitMessage(test.rFeatures, test.rHash)
|
||||
|
||||
err := localInit.CheckRemoteInit(remoteInit, wtwire.FeatureNames)
|
||||
switch {
|
||||
|
||||
// Both non-nil, pass.
|
||||
case err == nil && test.expErr == nil:
|
||||
return
|
||||
|
||||
// One is nil and one is non-nil, fail.
|
||||
default:
|
||||
t.Fatalf("error mismatch, want: %v, got: %v", test.expErr, err)
|
||||
|
||||
// Both non-nil, assert same error type.
|
||||
case err != nil && test.expErr != nil:
|
||||
}
|
||||
|
||||
// Compare error strings to assert same type.
|
||||
if err.Error() != test.expErr.Error() {
|
||||
t.Fatalf("error mismatch, want: %v, got: %v",
|
||||
test.expErr.Error(), err.Error())
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user