htlcswitch: add new shouldAdjustCommitFee helper function
In this commit, we add a new helper function to the link which will be utilized in a later commit. This helper function will help us determine if we should update the commitment fee, in response to a change in the network fee return by our fee estimators.
This commit is contained in:
parent
5a1a3c7277
commit
c560200ba1
@ -286,6 +286,27 @@ func (l *channelLink) Stop() {
|
||||
l.cfg.BlockEpochs.Cancel()
|
||||
}
|
||||
|
||||
// shouldAdjustCommitFee returns true if we should update our commitment fee to
|
||||
// match that of the network fee. We'll only update our commitment fee if the
|
||||
// network fee is +/- 10% to our network fee.
|
||||
func shouldAdjustCommitFee(netFee, chanFee btcutil.Amount) bool {
|
||||
switch {
|
||||
// If the network fee is greater than the commitment fee, then we'll
|
||||
// switch to it if it's at least 10% greater than the commit fee.
|
||||
case netFee > chanFee && netFee >= (chanFee+(chanFee*10)/100):
|
||||
return true
|
||||
|
||||
// If the network fee is less than our commitment fee, then we'll
|
||||
// switch to it if it's at least 10% less than the commitment fee.
|
||||
case netFee < chanFee && netFee <= (chanFee-(chanFee*10)/100):
|
||||
return true
|
||||
|
||||
// Otherwise, we won't modify our fee.
|
||||
default:
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
// htlcManager is the primary goroutine which drives a channel's commitment
|
||||
// update state-machine in response to messages received via several channels.
|
||||
// This goroutine reads messages from the upstream (remote) peer, and also from
|
||||
|
@ -2021,3 +2021,101 @@ func TestChannelRetransmission(t *testing.T) {
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
// TestShouldAdjustCommitFee tests the shouldAdjustCommitFee pivot function to
|
||||
// ensure that ie behaves properly. We should only update the fee if it
|
||||
// deviates from our current fee by more 10% or more.
|
||||
func TestShouldAdjustCommitFee(t *testing.T) {
|
||||
tests := []struct {
|
||||
netFee btcutil.Amount
|
||||
chanFee btcutil.Amount
|
||||
shouldAdjust bool
|
||||
}{
|
||||
|
||||
// The network fee is 3x lower than the current commitment
|
||||
// transaction. As a result, we should adjust our fee to match
|
||||
// it.
|
||||
{
|
||||
netFee: 100,
|
||||
chanFee: 3000,
|
||||
shouldAdjust: true,
|
||||
},
|
||||
|
||||
// The network fee is lower than the current commitment fee,
|
||||
// but only slightly so, so we won't update the commitment fee.
|
||||
{
|
||||
netFee: 2999,
|
||||
chanFee: 3000,
|
||||
shouldAdjust: false,
|
||||
},
|
||||
|
||||
// The network fee is lower than the commitment fee, but only
|
||||
// right before it crosses our current threshold.
|
||||
{
|
||||
netFee: 1000,
|
||||
chanFee: 1099,
|
||||
shouldAdjust: false,
|
||||
},
|
||||
|
||||
// The network fee is lower than the commitment fee, and within
|
||||
// our range of adjustment, so we should adjust.
|
||||
{
|
||||
netFee: 1000,
|
||||
chanFee: 1100,
|
||||
shouldAdjust: true,
|
||||
},
|
||||
|
||||
// The network fee is 2x higher than our commitment fee, so we
|
||||
// should adjust upwards.
|
||||
{
|
||||
netFee: 2000,
|
||||
chanFee: 1000,
|
||||
shouldAdjust: true,
|
||||
},
|
||||
|
||||
// The network fee is higher than our commitment fee, but only
|
||||
// slightly so, so we won't update.
|
||||
{
|
||||
netFee: 1001,
|
||||
chanFee: 1000,
|
||||
shouldAdjust: false,
|
||||
},
|
||||
|
||||
// The network fee is higher than our commitment fee, but
|
||||
// hasn't yet crossed our activation threshold.
|
||||
{
|
||||
netFee: 1100,
|
||||
chanFee: 1099,
|
||||
shouldAdjust: false,
|
||||
},
|
||||
|
||||
// The network fee is higher than our commitment fee, and
|
||||
// within our activation threshold, so we should update our
|
||||
// fee.
|
||||
{
|
||||
netFee: 1100,
|
||||
chanFee: 1000,
|
||||
shouldAdjust: true,
|
||||
},
|
||||
|
||||
// Our fees match exactly, so we shouldn't update it at all.
|
||||
{
|
||||
netFee: 1000,
|
||||
chanFee: 1000,
|
||||
shouldAdjust: false,
|
||||
},
|
||||
}
|
||||
|
||||
for i, test := range tests {
|
||||
adjustedFee := shouldAdjustCommitFee(
|
||||
test.netFee, test.chanFee,
|
||||
)
|
||||
|
||||
if adjustedFee && !test.shouldAdjust {
|
||||
t.Fatalf("test #%v failed: net_fee=%v, "+
|
||||
"chan_fee=%v, adjust_expect=%v, adjust_returned=%v",
|
||||
i, test.netFee, test.chanFee, test.shouldAdjust,
|
||||
adjustedFee)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user