chainntnfs/btcdnotify: properly include SpendingHeight in SpendDetails
This commit modifies the btcdnotify implementation of the ChainNotifier interface to properly include the height in which the watched output was spent in the SpendDetail sent as a notification. The set of tests have also been updated to assert that the proper spending height is included in received notification.
This commit is contained in:
parent
a5113c2439
commit
45bbeb8f84
@ -369,15 +369,22 @@ out:
|
|||||||
// the notification subscriber.
|
// the notification subscriber.
|
||||||
if clients, ok := b.spendNotifications[prevOut]; ok {
|
if clients, ok := b.spendNotifications[prevOut]; ok {
|
||||||
spenderSha := newSpend.tx.Hash()
|
spenderSha := newSpend.tx.Hash()
|
||||||
for _, ntfn := range clients {
|
|
||||||
spendDetails := &chainntnfs.SpendDetail{
|
spendDetails := &chainntnfs.SpendDetail{
|
||||||
SpentOutPoint: ntfn.targetOutpoint,
|
SpentOutPoint: &prevOut,
|
||||||
SpenderTxHash: spenderSha,
|
SpenderTxHash: spenderSha,
|
||||||
// TODO(roasbeef): copy tx?
|
|
||||||
SpendingTx: spendingTx.MsgTx(),
|
SpendingTx: spendingTx.MsgTx(),
|
||||||
SpenderInputIndex: uint32(i),
|
SpenderInputIndex: uint32(i),
|
||||||
}
|
}
|
||||||
|
// TODO(roasbeef): after change to
|
||||||
|
// loadfilter, only notify on block
|
||||||
|
// inclusion?
|
||||||
|
if newSpend.details != nil {
|
||||||
|
spendDetails.SpendingHeight = newSpend.details.Height
|
||||||
|
} else {
|
||||||
|
spendDetails.SpendingHeight = currentHeight
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, ntfn := range clients {
|
||||||
chainntnfs.Log.Infof("Dispatching "+
|
chainntnfs.Log.Infof("Dispatching "+
|
||||||
"spend notification for "+
|
"spend notification for "+
|
||||||
"outpoint=%v", ntfn.targetOutpoint)
|
"outpoint=%v", ntfn.targetOutpoint)
|
||||||
|
@ -287,6 +287,11 @@ func testSpendNotification(miner *rpctest.Harness,
|
|||||||
t.Fatalf("unable to brodacst tx: %v", err)
|
t.Fatalf("unable to brodacst tx: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_, currentHeight, err = miner.Node.GetBestBlock()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatalf("unable to get current height: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
// Now we mine a single block, which should include our spend. The
|
// Now we mine a single block, which should include our spend. The
|
||||||
// notification should also be sent off.
|
// notification should also be sent off.
|
||||||
if _, err := miner.Node.Generate(1); err != nil {
|
if _, err := miner.Node.Generate(1); err != nil {
|
||||||
@ -308,7 +313,7 @@ func testSpendNotification(miner *rpctest.Harness,
|
|||||||
case ntfn := <-spentNtfn:
|
case ntfn := <-spentNtfn:
|
||||||
// We've received the spend nftn. So now verify all the
|
// We've received the spend nftn. So now verify all the
|
||||||
// fields have been set properly.
|
// fields have been set properly.
|
||||||
if ntfn.SpentOutPoint != outpoint {
|
if *ntfn.SpentOutPoint != *outpoint {
|
||||||
t.Fatalf("ntfn includes wrong output, reports "+
|
t.Fatalf("ntfn includes wrong output, reports "+
|
||||||
"%v instead of %v",
|
"%v instead of %v",
|
||||||
ntfn.SpentOutPoint, outpoint)
|
ntfn.SpentOutPoint, outpoint)
|
||||||
@ -323,6 +328,11 @@ func testSpendNotification(miner *rpctest.Harness,
|
|||||||
"index, reports %v, should be %v",
|
"index, reports %v, should be %v",
|
||||||
ntfn.SpenderInputIndex, 0)
|
ntfn.SpenderInputIndex, 0)
|
||||||
}
|
}
|
||||||
|
if ntfn.SpendingHeight != currentHeight {
|
||||||
|
t.Fatalf("ntfn has wrong spending height: "+
|
||||||
|
"expected %v, got %v", currentHeight,
|
||||||
|
ntfn.SpendingHeight)
|
||||||
|
}
|
||||||
case <-time.After(2 * time.Second):
|
case <-time.After(2 * time.Second):
|
||||||
t.Fatalf("spend ntfn never received")
|
t.Fatalf("spend ntfn never received")
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user