lntest: add new LookUpNodeByPub method to lookup active nodes by pubkey

In this commit, we add a new helper function to the NetworkHarness
struct. This helper function serves to allow test authors to look up
pointer to an active node based on its current public key.

Each time a new node is started, its public key will be re-registered
within the global nodesByPub map.
This commit is contained in:
Olaoluwa Osuntokun 2017-12-21 11:32:54 +01:00
parent ef2838fdd3
commit 2154ec130f
No known key found for this signature in database
GPG Key ID: 964EA263DD637C21

@ -32,6 +32,8 @@ type NetworkHarness struct {
activeNodes map[int]*HarnessNode activeNodes map[int]*HarnessNode
nodesByPub map[string]*HarnessNode
// Alice and Bob are the initial seeder nodes that are automatically // Alice and Bob are the initial seeder nodes that are automatically
// created to be the initial participants of the test network. // created to be the initial participants of the test network.
Alice *HarnessNode Alice *HarnessNode
@ -56,6 +58,7 @@ type NetworkHarness struct {
func NewNetworkHarness(r *rpctest.Harness) (*NetworkHarness, error) { func NewNetworkHarness(r *rpctest.Harness) (*NetworkHarness, error) {
n := NetworkHarness{ n := NetworkHarness{
activeNodes: make(map[int]*HarnessNode), activeNodes: make(map[int]*HarnessNode),
nodesByPub: make(map[string]*HarnessNode),
seenTxns: make(chan *chainhash.Hash), seenTxns: make(chan *chainhash.Hash),
bitcoinWatchRequests: make(chan *txWatchRequest), bitcoinWatchRequests: make(chan *txWatchRequest),
lndErrorChan: make(chan error), lndErrorChan: make(chan error),
@ -68,6 +71,21 @@ func NewNetworkHarness(r *rpctest.Harness) (*NetworkHarness, error) {
return &n, nil return &n, nil
} }
// LookUpNodeByPub queries the set of active nodes to locate a node according
// to its public key. The second value will be true if the node was found, and
// false otherwise.
func (n *NetworkHarness) LookUpNodeByPub(pubStr string) (*HarnessNode, error) {
n.mtx.Lock()
defer n.mtx.Unlock()
node, ok := n.nodesByPub[pubStr]
if !ok {
return nil, fmt.Errorf("unable to find node")
}
return node, nil
}
// ProcessErrors returns a channel used for reporting any fatal process errors. // ProcessErrors returns a channel used for reporting any fatal process errors.
// If any of the active nodes within the harness' test network incur a fatal // If any of the active nodes within the harness' test network incur a fatal
// error, that error is sent over this channel. // error, that error is sent over this channel.
@ -201,6 +219,7 @@ out:
// TearDownAll tears down all active nodes within the test lightning network. // TearDownAll tears down all active nodes within the test lightning network.
func (n *NetworkHarness) TearDownAll() error { func (n *NetworkHarness) TearDownAll() error {
for _, node := range n.activeNodes { for _, node := range n.activeNodes {
if err := n.ShutdownNode(node); err != nil { if err := n.ShutdownNode(node); err != nil {
return err return err
@ -236,6 +255,12 @@ func (n *NetworkHarness) NewNode(extraArgs []string) (*HarnessNode, error) {
return nil, err return nil, err
} }
// With the node started, we can now record its public key within the
// global mapping.
n.mtx.Lock()
n.nodesByPub[node.PubKeyStr] = node
n.mtx.Unlock()
return node, nil return node, nil
} }