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:
parent
ef2838fdd3
commit
2154ec130f
@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user