mirror of
https://github.com/lightninglabs/loop
synced 2024-11-11 13:11:12 +00:00
135 lines
2.5 KiB
Go
135 lines
2.5 KiB
Go
package test
|
|
|
|
import (
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/btcsuite/btcd/chaincfg/chainhash"
|
|
"github.com/btcsuite/btcd/wire"
|
|
"github.com/lightningnetwork/lnd/chainntnfs"
|
|
"golang.org/x/net/context"
|
|
)
|
|
|
|
type mockChainNotifier struct {
|
|
lnd *LndMockServices
|
|
wg sync.WaitGroup
|
|
}
|
|
|
|
// SpendRegistration contains registration details.
|
|
type SpendRegistration struct {
|
|
Outpoint *wire.OutPoint
|
|
PkScript []byte
|
|
HeightHint int32
|
|
}
|
|
|
|
// ConfRegistration contains registration details.
|
|
type ConfRegistration struct {
|
|
TxID *chainhash.Hash
|
|
PkScript []byte
|
|
HeightHint int32
|
|
NumConfs int32
|
|
}
|
|
|
|
func (c *mockChainNotifier) RegisterSpendNtfn(ctx context.Context,
|
|
outpoint *wire.OutPoint, pkScript []byte, heightHint int32) (
|
|
chan *chainntnfs.SpendDetail, chan error, error) {
|
|
|
|
c.lnd.RegisterSpendChannel <- &SpendRegistration{
|
|
HeightHint: heightHint,
|
|
Outpoint: outpoint,
|
|
PkScript: pkScript,
|
|
}
|
|
|
|
spendChan := make(chan *chainntnfs.SpendDetail, 1)
|
|
errChan := make(chan error, 1)
|
|
|
|
c.wg.Add(1)
|
|
go func() {
|
|
defer c.wg.Done()
|
|
|
|
select {
|
|
case m := <-c.lnd.SpendChannel:
|
|
select {
|
|
case spendChan <- m:
|
|
case <-ctx.Done():
|
|
}
|
|
case <-ctx.Done():
|
|
}
|
|
}()
|
|
|
|
return spendChan, errChan, nil
|
|
}
|
|
|
|
func (c *mockChainNotifier) WaitForFinished() {
|
|
c.wg.Wait()
|
|
}
|
|
|
|
func (c *mockChainNotifier) RegisterBlockEpochNtfn(ctx context.Context) (
|
|
chan int32, chan error, error) {
|
|
|
|
blockErrorChan := make(chan error, 1)
|
|
blockEpochChan := make(chan int32)
|
|
|
|
c.wg.Add(1)
|
|
go func() {
|
|
defer c.wg.Done()
|
|
|
|
// Send initial block height
|
|
select {
|
|
case blockEpochChan <- c.lnd.Height:
|
|
case <-ctx.Done():
|
|
return
|
|
}
|
|
|
|
for {
|
|
select {
|
|
case m := <-c.lnd.epochChannel:
|
|
select {
|
|
case blockEpochChan <- m:
|
|
case <-ctx.Done():
|
|
return
|
|
}
|
|
case <-ctx.Done():
|
|
return
|
|
}
|
|
}
|
|
}()
|
|
|
|
return blockEpochChan, blockErrorChan, nil
|
|
}
|
|
|
|
func (c *mockChainNotifier) RegisterConfirmationsNtfn(ctx context.Context,
|
|
txid *chainhash.Hash, pkScript []byte, numConfs, heightHint int32) (
|
|
chan *chainntnfs.TxConfirmation, chan error, error) {
|
|
|
|
confChan := make(chan *chainntnfs.TxConfirmation, 1)
|
|
errChan := make(chan error, 1)
|
|
|
|
c.wg.Add(1)
|
|
go func() {
|
|
defer c.wg.Done()
|
|
|
|
select {
|
|
case m := <-c.lnd.ConfChannel:
|
|
select {
|
|
case confChan <- m:
|
|
case <-ctx.Done():
|
|
}
|
|
case <-ctx.Done():
|
|
}
|
|
}()
|
|
|
|
select {
|
|
case c.lnd.RegisterConfChannel <- &ConfRegistration{
|
|
PkScript: pkScript,
|
|
TxID: txid,
|
|
HeightHint: heightHint,
|
|
NumConfs: numConfs,
|
|
}:
|
|
case <-time.After(Timeout):
|
|
return nil, nil, ErrTimeout
|
|
}
|
|
|
|
return confChan, errChan, nil
|
|
}
|