chanfunding: assure logic for high-fee
Without this change the high-fee logic is never tested as it is instead caught by the dust-output logic. This change uses a higher fee rate to ensure an output value above the dust limit, while still spending 20% on fees.
This commit is contained in:
parent
9e825e6c0f
commit
07549d50ff
@ -205,11 +205,13 @@ func TestCoinSelectSubtractFees(t *testing.T) {
|
|||||||
t.Parallel()
|
t.Parallel()
|
||||||
|
|
||||||
const feeRate = chainfee.SatPerKWeight(100)
|
const feeRate = chainfee.SatPerKWeight(100)
|
||||||
|
const highFeeRate = chainfee.SatPerKWeight(1000)
|
||||||
const dustLimit = btcutil.Amount(1000)
|
const dustLimit = btcutil.Amount(1000)
|
||||||
const dust = btcutil.Amount(100)
|
const dust = btcutil.Amount(100)
|
||||||
|
|
||||||
type testCase struct {
|
type testCase struct {
|
||||||
name string
|
name string
|
||||||
|
highFee bool
|
||||||
spendValue btcutil.Amount
|
spendValue btcutil.Amount
|
||||||
coins []Coin
|
coins []Coin
|
||||||
|
|
||||||
@ -321,15 +323,16 @@ func TestCoinSelectSubtractFees(t *testing.T) {
|
|||||||
{
|
{
|
||||||
// If more than 20% of funds goes to fees, it should fail.
|
// If more than 20% of funds goes to fees, it should fail.
|
||||||
name: "high fee",
|
name: "high fee",
|
||||||
|
highFee: true,
|
||||||
coins: []Coin{
|
coins: []Coin{
|
||||||
{
|
{
|
||||||
TxOut: wire.TxOut{
|
TxOut: wire.TxOut{
|
||||||
PkScript: p2wkhScript,
|
PkScript: p2wkhScript,
|
||||||
Value: int64(5 * fundingFee(feeRate, 1, false)),
|
Value: int64(5 * fundingFee(highFeeRate, 1, false)),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
spendValue: 5 * fundingFee(feeRate, 1, false),
|
spendValue: 5 * fundingFee(highFeeRate, 1, false),
|
||||||
|
|
||||||
expectErr: true,
|
expectErr: true,
|
||||||
},
|
},
|
||||||
@ -339,6 +342,11 @@ func TestCoinSelectSubtractFees(t *testing.T) {
|
|||||||
test := test
|
test := test
|
||||||
|
|
||||||
t.Run(test.name, func(t *testing.T) {
|
t.Run(test.name, func(t *testing.T) {
|
||||||
|
feeRate := feeRate
|
||||||
|
if test.highFee {
|
||||||
|
feeRate = highFeeRate
|
||||||
|
}
|
||||||
|
|
||||||
selected, localFundingAmt, changeAmt, err := CoinSelectSubtractFees(
|
selected, localFundingAmt, changeAmt, err := CoinSelectSubtractFees(
|
||||||
feeRate, test.spendValue, dustLimit, test.coins,
|
feeRate, test.spendValue, dustLimit, test.coins,
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user