Skip to content

Commit

Permalink
Merge branch '0-18-4-branch-rc1-9272' into 0-18-4-branch-rc1
Browse files Browse the repository at this point in the history
  • Loading branch information
guggero committed Nov 19, 2024
2 parents 4c9d25c + 86de1eb commit 78c8990
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 13 deletions.
13 changes: 8 additions & 5 deletions sweep/fee_bumper.go
Original file line number Diff line number Diff line change
Expand Up @@ -455,6 +455,7 @@ func (t *TxPublisher) createRBFCompliantTx(req *BumpRequest,
// The tx is valid, return the request ID.
requestID := t.storeRecord(
sweepCtx.tx, req, f, sweepCtx.fee,
sweepCtx.outpointToTxIndex,
)

log.Infof("Created tx %v for %v inputs: feerate=%v, "+
Expand Down Expand Up @@ -510,7 +511,8 @@ func (t *TxPublisher) createRBFCompliantTx(req *BumpRequest,

// storeRecord stores the given record in the records map.
func (t *TxPublisher) storeRecord(tx *wire.MsgTx, req *BumpRequest,
f FeeFunction, fee btcutil.Amount) uint64 {
f FeeFunction, fee btcutil.Amount,
outpointToTxIndex map[wire.OutPoint]int) uint64 {

// Increase the request counter.
//
Expand All @@ -520,10 +522,11 @@ func (t *TxPublisher) storeRecord(tx *wire.MsgTx, req *BumpRequest,

// Register the record.
t.records.Store(requestID, &monitorRecord{
tx: tx,
req: req,
feeFunction: f,
fee: fee,
tx: tx,
req: req,
feeFunction: f,
fee: fee,
outpointToTxIndex: outpointToTxIndex,
})

return requestID
Expand Down
71 changes: 63 additions & 8 deletions sweep/fee_bumper_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -323,8 +323,16 @@ func TestStoreRecord(t *testing.T) {
// Get the current counter and check it's increased later.
initialCounter := tp.requestCounter.Load()

op := wire.OutPoint{
Hash: chainhash.Hash{1},
Index: 0,
}
utxoIndex := map[wire.OutPoint]int{
op: 0,
}

// Call the method under test.
requestID := tp.storeRecord(tx, req, feeFunc, fee)
requestID := tp.storeRecord(tx, req, feeFunc, fee, utxoIndex)

// Check the request ID is as expected.
require.Equal(t, initialCounter+1, requestID)
Expand All @@ -336,6 +344,7 @@ func TestStoreRecord(t *testing.T) {
require.Equal(t, feeFunc, record.feeFunction)
require.Equal(t, fee, record.fee)
require.Equal(t, req, record.req)
require.Equal(t, utxoIndex, record.outpointToTxIndex)
}

// mockers wraps a list of mocked interfaces used inside tx publisher.
Expand Down Expand Up @@ -665,9 +674,17 @@ func TestTxPublisherBroadcast(t *testing.T) {
feerate := chainfee.SatPerKWeight(1000)
m.feeFunc.On("FeeRate").Return(feerate)

op := wire.OutPoint{
Hash: chainhash.Hash{1},
Index: 0,
}
utxoIndex := map[wire.OutPoint]int{
op: 0,
}

// Create a testing record and put it in the map.
fee := btcutil.Amount(1000)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee, utxoIndex)

// Quickly check when the requestID cannot be found, an error is
// returned.
Expand Down Expand Up @@ -754,6 +771,14 @@ func TestRemoveResult(t *testing.T) {
// Create a testing record and put it in the map.
fee := btcutil.Amount(1000)

op := wire.OutPoint{
Hash: chainhash.Hash{1},
Index: 0,
}
utxoIndex := map[wire.OutPoint]int{
op: 0,
}

testCases := []struct {
name string
setupRecord func() uint64
Expand All @@ -765,7 +790,9 @@ func TestRemoveResult(t *testing.T) {
// removed.
name: "remove on TxConfirmed",
setupRecord: func() uint64 {
id := tp.storeRecord(tx, req, m.feeFunc, fee)
id := tp.storeRecord(
tx, req, m.feeFunc, fee, utxoIndex,
)
tp.subscriberChans.Store(id, nil)

return id
Expand All @@ -780,7 +807,9 @@ func TestRemoveResult(t *testing.T) {
// When the tx is failed, the records will be removed.
name: "remove on TxFailed",
setupRecord: func() uint64 {
id := tp.storeRecord(tx, req, m.feeFunc, fee)
id := tp.storeRecord(
tx, req, m.feeFunc, fee, utxoIndex,
)
tp.subscriberChans.Store(id, nil)

return id
Expand All @@ -796,7 +825,9 @@ func TestRemoveResult(t *testing.T) {
// Noop when the tx is neither confirmed or failed.
name: "noop when tx is not confirmed or failed",
setupRecord: func() uint64 {
id := tp.storeRecord(tx, req, m.feeFunc, fee)
id := tp.storeRecord(
tx, req, m.feeFunc, fee, utxoIndex,
)
tp.subscriberChans.Store(id, nil)

return id
Expand Down Expand Up @@ -844,9 +875,17 @@ func TestNotifyResult(t *testing.T) {
// Create a test tx.
tx := &wire.MsgTx{LockTime: 1}

op := wire.OutPoint{
Hash: chainhash.Hash{1},
Index: 0,
}
utxoIndex := map[wire.OutPoint]int{
op: 0,
}

// Create a testing record and put it in the map.
fee := btcutil.Amount(1000)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee, utxoIndex)

// Create a subscription to the event.
subscriber := make(chan *BumpResult, 1)
Expand Down Expand Up @@ -1201,9 +1240,17 @@ func TestHandleTxConfirmed(t *testing.T) {
// Create a test tx.
tx := &wire.MsgTx{LockTime: 1}

op := wire.OutPoint{
Hash: chainhash.Hash{1},
Index: 0,
}
utxoIndex := map[wire.OutPoint]int{
op: 0,
}

// Create a testing record and put it in the map.
fee := btcutil.Amount(1000)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee, utxoIndex)
record, ok := tp.records.Load(requestID)
require.True(t, ok)

Expand Down Expand Up @@ -1273,9 +1320,17 @@ func TestHandleFeeBumpTx(t *testing.T) {
tx: tx,
}

op := wire.OutPoint{
Hash: chainhash.Hash{1},
Index: 0,
}
utxoIndex := map[wire.OutPoint]int{
op: 0,
}

// Create a testing record and put it in the map.
fee := btcutil.Amount(1000)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee)
requestID := tp.storeRecord(tx, req, m.feeFunc, fee, utxoIndex)

// Create a subscription to the event.
subscriber := make(chan *BumpResult, 1)
Expand Down

0 comments on commit 78c8990

Please sign in to comment.