peer: update cooperative closure unit tests to latest negotiation policy
With the new negotiation policy, we instead just need to ensure that our fee inches closer to the other party’s with each iteration, and that it’s within the proper bounds.
This commit is contained in:
parent
385023f0b7
commit
1d65839bca
@ -1132,8 +1132,13 @@ func (b *breachArbiter) sweepSpendableOutputsTxn(txWeight uint64,
|
|||||||
totalAmt += input.Amount()
|
totalAmt += input.Amount()
|
||||||
}
|
}
|
||||||
|
|
||||||
feePerWeight := b.cfg.Estimator.EstimateFeePerWeight(1)
|
// We'll actually attempt to target inclusion within the next two
|
||||||
txFee := btcutil.Amount(txWeight * feePerWeight)
|
// blocks as we'd like to sweep these funds back into our wallet ASAP.
|
||||||
|
feePerWeight, err := b.cfg.Estimator.EstimateFeePerWeight(2)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
txFee := btcutil.Amount(txWeight * uint64(feePerWeight))
|
||||||
|
|
||||||
sweepAmt := int64(totalAmt - txFee)
|
sweepAmt := int64(totalAmt - txFee)
|
||||||
|
|
||||||
|
238
peer_test.go
238
peer_test.go
@ -14,6 +14,7 @@ import (
|
|||||||
"github.com/roasbeef/btcd/btcec"
|
"github.com/roasbeef/btcd/btcec"
|
||||||
"github.com/roasbeef/btcd/txscript"
|
"github.com/roasbeef/btcd/txscript"
|
||||||
"github.com/roasbeef/btcd/wire"
|
"github.com/roasbeef/btcd/wire"
|
||||||
|
"github.com/roasbeef/btcutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
func disablePeerLogger(t *testing.T) {
|
func disablePeerLogger(t *testing.T) {
|
||||||
@ -45,9 +46,12 @@ func TestPeerChannelClosureAcceptFeeResponder(t *testing.T) {
|
|||||||
chanID := lnwire.NewChanIDFromOutPoint(responderChan.ChannelPoint())
|
chanID := lnwire.NewChanIDFromOutPoint(responderChan.ChannelPoint())
|
||||||
|
|
||||||
// We send a shutdown request to Alice. She will now be the responding
|
// We send a shutdown request to Alice. She will now be the responding
|
||||||
// node in this shutdown procedure. We first expect Alice to answer this
|
// node in this shutdown procedure. We first expect Alice to answer
|
||||||
// shutdown request with a Shutdown message.
|
// this shutdown request with a Shutdown message.
|
||||||
responder.shutdownChanReqs <- lnwire.NewShutdown(chanID, dummyDeliveryScript)
|
responder.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: lnwire.NewShutdown(chanID, dummyDeliveryScript),
|
||||||
|
}
|
||||||
|
|
||||||
var msg lnwire.Message
|
var msg lnwire.Message
|
||||||
select {
|
select {
|
||||||
@ -81,8 +85,9 @@ func TestPeerChannelClosureAcceptFeeResponder(t *testing.T) {
|
|||||||
// We accept the fee, and send a ClosingSigned with the same fee back,
|
// We accept the fee, and send a ClosingSigned with the same fee back,
|
||||||
// so she knows we agreed.
|
// so she knows we agreed.
|
||||||
peerFee := responderClosingSigned.FeeSatoshis
|
peerFee := responderClosingSigned.FeeSatoshis
|
||||||
initiatorSig, proposedFee, err := initiatorChan.CreateCloseProposal(
|
initiatorSig, err := initiatorChan.CreateCloseProposal(
|
||||||
peerFee, dummyDeliveryScript, respDeliveryScript)
|
peerFee, dummyDeliveryScript, respDeliveryScript,
|
||||||
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("error creating close proposal: %v", err)
|
t.Fatalf("error creating close proposal: %v", err)
|
||||||
}
|
}
|
||||||
@ -92,8 +97,11 @@ func TestPeerChannelClosureAcceptFeeResponder(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("error parsing signature: %v", err)
|
t.Fatalf("error parsing signature: %v", err)
|
||||||
}
|
}
|
||||||
closingSigned := lnwire.NewClosingSigned(chanID, proposedFee, parsedSig)
|
closingSigned := lnwire.NewClosingSigned(chanID, peerFee, parsedSig)
|
||||||
responder.closingSignedChanReqs <- closingSigned
|
responder.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// The responder will now see that we agreed on the fee, and broadcast
|
// The responder will now see that we agreed on the fee, and broadcast
|
||||||
// the closing transaction.
|
// the closing transaction.
|
||||||
@ -132,6 +140,7 @@ func TestPeerChannelClosureAcceptFeeInitiator(t *testing.T) {
|
|||||||
CloseType: htlcswitch.CloseRegular,
|
CloseType: htlcswitch.CloseRegular,
|
||||||
ChanPoint: initiatorChan.ChannelPoint(),
|
ChanPoint: initiatorChan.ChannelPoint(),
|
||||||
Updates: updateChan,
|
Updates: updateChan,
|
||||||
|
TargetFeePerKw: 12000,
|
||||||
Err: errChan,
|
Err: errChan,
|
||||||
}
|
}
|
||||||
initiator.localCloseChanReqs <- closeCommand
|
initiator.localCloseChanReqs <- closeCommand
|
||||||
@ -155,13 +164,19 @@ func TestPeerChannelClosureAcceptFeeInitiator(t *testing.T) {
|
|||||||
// We'll answer the shutdown message with our own Shutdown, and then a
|
// We'll answer the shutdown message with our own Shutdown, and then a
|
||||||
// ClosingSigned message.
|
// ClosingSigned message.
|
||||||
chanID := shutdownMsg.ChannelID
|
chanID := shutdownMsg.ChannelID
|
||||||
initiator.shutdownChanReqs <- lnwire.NewShutdown(chanID,
|
initiator.chanCloseMsgs <- &closeMsg{
|
||||||
dummyDeliveryScript)
|
cid: chanID,
|
||||||
|
msg: lnwire.NewShutdown(chanID,
|
||||||
|
dummyDeliveryScript),
|
||||||
|
}
|
||||||
|
|
||||||
estimator := lnwallet.StaticFeeEstimator{FeeRate: 50}
|
estimator := lnwallet.StaticFeeEstimator{FeeRate: 50}
|
||||||
feeRate := estimator.EstimateFeePerWeight(1) * 1000
|
feeRate, err := estimator.EstimateFeePerWeight(1)
|
||||||
fee := responderChan.CalcFee(feeRate)
|
if err != nil {
|
||||||
closeSig, proposedFee, err := responderChan.CreateCloseProposal(fee,
|
t.Fatalf("unable to query fee estimator: %v", err)
|
||||||
|
}
|
||||||
|
fee := btcutil.Amount(responderChan.CalcFee(uint64(feeRate * 1000)))
|
||||||
|
closeSig, err := responderChan.CreateCloseProposal(fee,
|
||||||
dummyDeliveryScript, initiatorDeliveryScript)
|
dummyDeliveryScript, initiatorDeliveryScript)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unable to create close proposal: %v", err)
|
t.Fatalf("unable to create close proposal: %v", err)
|
||||||
@ -172,8 +187,11 @@ func TestPeerChannelClosureAcceptFeeInitiator(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
closingSigned := lnwire.NewClosingSigned(shutdownMsg.ChannelID,
|
closingSigned := lnwire.NewClosingSigned(shutdownMsg.ChannelID,
|
||||||
proposedFee, parsedSig)
|
fee, parsedSig)
|
||||||
initiator.closingSignedChanReqs <- closingSigned
|
initiator.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// And we expect the initiator to accept the fee, and broadcast the
|
// And we expect the initiator to accept the fee, and broadcast the
|
||||||
// closing transaction.
|
// closing transaction.
|
||||||
@ -189,9 +207,9 @@ func TestPeerChannelClosureAcceptFeeInitiator(t *testing.T) {
|
|||||||
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
if closingSignedMsg.FeeSatoshis != proposedFee {
|
if closingSignedMsg.FeeSatoshis != fee {
|
||||||
t.Fatalf("expected ClosingSigned fee to be %v, instead got %v",
|
t.Fatalf("expected ClosingSigned fee to be %v, instead got %v",
|
||||||
proposedFee, closingSignedMsg.FeeSatoshis)
|
fee, closingSignedMsg.FeeSatoshis)
|
||||||
}
|
}
|
||||||
|
|
||||||
// The initiator will now see that we agreed on the fee, and broadcast
|
// The initiator will now see that we agreed on the fee, and broadcast
|
||||||
@ -206,9 +224,9 @@ func TestPeerChannelClosureAcceptFeeInitiator(t *testing.T) {
|
|||||||
notifier.confChannel <- &chainntnfs.TxConfirmation{}
|
notifier.confChannel <- &chainntnfs.TxConfirmation{}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestPeerChannelClosureFeeNegotiationsResponder tests the shutdown responder's
|
// TestPeerChannelClosureFeeNegotiationsResponder tests the shutdown
|
||||||
// behavior in the case where we must do several rounds of fee negotiation
|
// responder's behavior in the case where we must do several rounds of fee
|
||||||
// before we agree on a fee.
|
// negotiation before we agree on a fee.
|
||||||
func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
||||||
disablePeerLogger(t)
|
disablePeerLogger(t)
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
@ -228,10 +246,13 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
chanID := lnwire.NewChanIDFromOutPoint(responderChan.ChannelPoint())
|
chanID := lnwire.NewChanIDFromOutPoint(responderChan.ChannelPoint())
|
||||||
|
|
||||||
// We send a shutdown request to Alice. She will now be the responding
|
// We send a shutdown request to Alice. She will now be the responding
|
||||||
// node in this shutdown procedure. We first expect Alice to answer this
|
// node in this shutdown procedure. We first expect Alice to answer
|
||||||
// shutdown request with a Shutdown message.
|
// this shutdown request with a Shutdown message.
|
||||||
responder.shutdownChanReqs <- lnwire.NewShutdown(chanID,
|
responder.chanCloseMsgs <- &closeMsg{
|
||||||
dummyDeliveryScript)
|
cid: chanID,
|
||||||
|
msg: lnwire.NewShutdown(chanID,
|
||||||
|
dummyDeliveryScript),
|
||||||
|
}
|
||||||
|
|
||||||
var msg lnwire.Message
|
var msg lnwire.Message
|
||||||
select {
|
select {
|
||||||
@ -264,8 +285,8 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
|
|
||||||
// We don't agree with the fee, and will send back one that's 2.5x.
|
// We don't agree with the fee, and will send back one that's 2.5x.
|
||||||
preferredRespFee := responderClosingSigned.FeeSatoshis
|
preferredRespFee := responderClosingSigned.FeeSatoshis
|
||||||
increasedFee := uint64(float64(preferredRespFee) * 2.5)
|
increasedFee := btcutil.Amount(float64(preferredRespFee) * 2.5)
|
||||||
initiatorSig, proposedFee, err := initiatorChan.CreateCloseProposal(
|
initiatorSig, err := initiatorChan.CreateCloseProposal(
|
||||||
increasedFee, dummyDeliveryScript, respDeliveryScript,
|
increasedFee, dummyDeliveryScript, respDeliveryScript,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -276,12 +297,16 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("error parsing signature: %v", err)
|
t.Fatalf("error parsing signature: %v", err)
|
||||||
}
|
}
|
||||||
closingSigned := lnwire.NewClosingSigned(chanID, proposedFee, parsedSig)
|
closingSigned := lnwire.NewClosingSigned(chanID, increasedFee, parsedSig)
|
||||||
responder.closingSignedChanReqs <- closingSigned
|
responder.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// The responder will see the new fee we propose, but with current
|
// The responder will see the new fee we propose, but with current
|
||||||
// settings wont't accept anything over 2*FeeRate. We should get a new
|
// settings it won't accept it immediately as it differs too much by
|
||||||
// proposal back, which should have the average fee rate proposed.
|
// its ideal fee. We should get a new proposal back, which should have
|
||||||
|
// the average fee rate proposed.
|
||||||
select {
|
select {
|
||||||
case outMsg := <-responder.outgoingQueue:
|
case outMsg := <-responder.outgoingQueue:
|
||||||
msg = outMsg.msg
|
msg = outMsg.msg
|
||||||
@ -294,16 +319,18 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
avgFee := (preferredRespFee + increasedFee) / 2
|
// The fee sent by the responder should be less than the fee we just
|
||||||
|
// sent as it should attempt to comrpomise.
|
||||||
peerFee := responderClosingSigned.FeeSatoshis
|
peerFee := responderClosingSigned.FeeSatoshis
|
||||||
if peerFee != avgFee {
|
if peerFee > increasedFee {
|
||||||
t.Fatalf("expected ClosingSigned with fee %v, got %v",
|
t.Fatalf("new fee should be less than our fee: new=%v, "+
|
||||||
proposedFee, responderClosingSigned.FeeSatoshis)
|
"prior=%v", peerFee, increasedFee)
|
||||||
}
|
}
|
||||||
|
lastFeeResponder := peerFee
|
||||||
|
|
||||||
// We try negotiating a 2.1x fee, which should also be rejected.
|
// We try negotiating a 2.1x fee, which should also be rejected.
|
||||||
increasedFee = uint64(float64(preferredRespFee) * 2.1)
|
increasedFee = btcutil.Amount(float64(preferredRespFee) * 2.1)
|
||||||
initiatorSig, proposedFee, err = initiatorChan.CreateCloseProposal(
|
initiatorSig, err = initiatorChan.CreateCloseProposal(
|
||||||
increasedFee, dummyDeliveryScript, respDeliveryScript,
|
increasedFee, dummyDeliveryScript, respDeliveryScript,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -314,8 +341,11 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("error parsing signature: %v", err)
|
t.Fatalf("error parsing signature: %v", err)
|
||||||
}
|
}
|
||||||
closingSigned = lnwire.NewClosingSigned(chanID, proposedFee, parsedSig)
|
closingSigned = lnwire.NewClosingSigned(chanID, increasedFee, parsedSig)
|
||||||
responder.closingSignedChanReqs <- closingSigned
|
responder.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// It still won't be accepted, and we should get a new proposal, the
|
// It still won't be accepted, and we should get a new proposal, the
|
||||||
// average of what we proposed, and what they proposed last time.
|
// average of what we proposed, and what they proposed last time.
|
||||||
@ -331,15 +361,21 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
avgFee = (peerFee + increasedFee) / 2
|
// The peer should inch towards our fee, in order to compromise.
|
||||||
|
// Additionally, this fee should be less than the fee we sent prior.
|
||||||
peerFee = responderClosingSigned.FeeSatoshis
|
peerFee = responderClosingSigned.FeeSatoshis
|
||||||
if peerFee != avgFee {
|
if peerFee < lastFeeResponder {
|
||||||
t.Fatalf("expected ClosingSigned with fee %v, got %v",
|
t.Fatalf("new fee should be greater than prior: new=%v, "+
|
||||||
proposedFee, responderClosingSigned.FeeSatoshis)
|
"prior=%v", peerFee, lastFeeResponder)
|
||||||
|
}
|
||||||
|
if peerFee > increasedFee {
|
||||||
|
t.Fatalf("new fee should be less than our fee: new=%v, "+
|
||||||
|
"prior=%v", peerFee, increasedFee)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Accept fee.
|
// Finally, we'll accept the fee by echoing back the same fee that they
|
||||||
initiatorSig, proposedFee, err = initiatorChan.CreateCloseProposal(
|
// sent to us.
|
||||||
|
initiatorSig, err = initiatorChan.CreateCloseProposal(
|
||||||
peerFee, dummyDeliveryScript, respDeliveryScript,
|
peerFee, dummyDeliveryScript, respDeliveryScript,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -351,8 +387,11 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("error parsing signature: %v", err)
|
t.Fatalf("error parsing signature: %v", err)
|
||||||
}
|
}
|
||||||
closingSigned = lnwire.NewClosingSigned(chanID, proposedFee, parsedSig)
|
closingSigned = lnwire.NewClosingSigned(chanID, peerFee, parsedSig)
|
||||||
responder.closingSignedChanReqs <- closingSigned
|
responder.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// The responder will now see that we agreed on the fee, and broadcast
|
// The responder will now see that we agreed on the fee, and broadcast
|
||||||
// the closing transaction.
|
// the closing transaction.
|
||||||
@ -366,9 +405,9 @@ func TestPeerChannelClosureFeeNegotiationsResponder(t *testing.T) {
|
|||||||
notifier.confChannel <- &chainntnfs.TxConfirmation{}
|
notifier.confChannel <- &chainntnfs.TxConfirmation{}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TestPeerChannelClosureFeeNegotiationsInitiator tests the shutdown initiator's
|
// TestPeerChannelClosureFeeNegotiationsInitiator tests the shutdown
|
||||||
// behavior in the case where we must do several rounds of fee negotiation
|
// initiator's behavior in the case where we must do several rounds of fee
|
||||||
// before we agree on a fee.
|
// negotiation before we agree on a fee.
|
||||||
func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
||||||
disablePeerLogger(t)
|
disablePeerLogger(t)
|
||||||
t.Parallel()
|
t.Parallel()
|
||||||
@ -392,6 +431,7 @@ func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
|||||||
CloseType: htlcswitch.CloseRegular,
|
CloseType: htlcswitch.CloseRegular,
|
||||||
ChanPoint: initiatorChan.ChannelPoint(),
|
ChanPoint: initiatorChan.ChannelPoint(),
|
||||||
Updates: updateChan,
|
Updates: updateChan,
|
||||||
|
TargetFeePerKw: 12000,
|
||||||
Err: errChan,
|
Err: errChan,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -417,13 +457,21 @@ func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
|||||||
// ClosingSigned message.
|
// ClosingSigned message.
|
||||||
chanID := lnwire.NewChanIDFromOutPoint(initiatorChan.ChannelPoint())
|
chanID := lnwire.NewChanIDFromOutPoint(initiatorChan.ChannelPoint())
|
||||||
respShutdown := lnwire.NewShutdown(chanID, dummyDeliveryScript)
|
respShutdown := lnwire.NewShutdown(chanID, dummyDeliveryScript)
|
||||||
initiator.shutdownChanReqs <- respShutdown
|
initiator.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: respShutdown,
|
||||||
|
}
|
||||||
|
|
||||||
estimator := lnwallet.StaticFeeEstimator{FeeRate: 50}
|
estimator := lnwallet.StaticFeeEstimator{FeeRate: 50}
|
||||||
initiatorIdealFeeRate := estimator.EstimateFeePerWeight(1) * 1000
|
initiatorIdealFeeRate, err := estimator.EstimateFeePerWeight(1)
|
||||||
initiatorIdealFee := responderChan.CalcFee(initiatorIdealFeeRate)
|
if err != nil {
|
||||||
increasedFee := uint64(float64(initiatorIdealFee) * 2.5)
|
t.Fatalf("unable to query fee estimator: %v", err)
|
||||||
closeSig, proposedFee, err := responderChan.CreateCloseProposal(
|
}
|
||||||
|
initiatorIdealFee := responderChan.CalcFee(
|
||||||
|
uint64(initiatorIdealFeeRate * 1000),
|
||||||
|
)
|
||||||
|
increasedFee := btcutil.Amount(float64(initiatorIdealFee) * 2.5)
|
||||||
|
closeSig, err := responderChan.CreateCloseProposal(
|
||||||
increasedFee, dummyDeliveryScript, initiatorDeliveryScript,
|
increasedFee, dummyDeliveryScript, initiatorDeliveryScript,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -434,33 +482,61 @@ func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
|||||||
t.Fatalf("unable to parse signature: %v", err)
|
t.Fatalf("unable to parse signature: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
closingSigned := lnwire.NewClosingSigned(shutdownMsg.ChannelID,
|
closingSigned := lnwire.NewClosingSigned(
|
||||||
proposedFee, parsedSig)
|
shutdownMsg.ChannelID, increasedFee, parsedSig,
|
||||||
initiator.closingSignedChanReqs <- closingSigned
|
)
|
||||||
|
initiator.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// And we expect the initiator to reject the fee, and suggest a lower
|
// We should get two closing signed messages, the first will be the
|
||||||
// one.
|
// ideal fee sent by the initiator in response to our shutdown request.
|
||||||
select {
|
select {
|
||||||
case outMsg := <-initiator.outgoingQueue:
|
case outMsg := <-initiator.outgoingQueue:
|
||||||
msg = outMsg.msg
|
msg = outMsg.msg
|
||||||
case <-time.After(time.Second * 5):
|
case <-time.After(time.Second * 5):
|
||||||
t.Fatalf("did not receive closing signed")
|
t.Fatalf("did not receive closing signed")
|
||||||
}
|
}
|
||||||
|
|
||||||
closingSignedMsg, ok := msg.(*lnwire.ClosingSigned)
|
closingSignedMsg, ok := msg.(*lnwire.ClosingSigned)
|
||||||
if !ok {
|
if !ok {
|
||||||
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
||||||
}
|
}
|
||||||
avgFee := (initiatorIdealFee + increasedFee) / 2
|
if uint64(closingSignedMsg.FeeSatoshis) != initiatorIdealFee {
|
||||||
peerFee := closingSignedMsg.FeeSatoshis
|
|
||||||
if peerFee != avgFee {
|
|
||||||
t.Fatalf("expected ClosingSigned fee to be %v, instead got %v",
|
t.Fatalf("expected ClosingSigned fee to be %v, instead got %v",
|
||||||
avgFee, peerFee)
|
initiatorIdealFee, closingSignedMsg.FeeSatoshis)
|
||||||
|
}
|
||||||
|
lastFeeSent := closingSignedMsg.FeeSatoshis
|
||||||
|
|
||||||
|
// The second message should be the compromise fee sent in response to
|
||||||
|
// them receiving our fee proposal.
|
||||||
|
select {
|
||||||
|
case outMsg := <-initiator.outgoingQueue:
|
||||||
|
msg = outMsg.msg
|
||||||
|
case <-time.After(time.Second * 5):
|
||||||
|
t.Fatalf("did not receive closing signed")
|
||||||
|
}
|
||||||
|
closingSignedMsg, ok = msg.(*lnwire.ClosingSigned)
|
||||||
|
if !ok {
|
||||||
|
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The peer should inch towards our fee, in order to compromise.
|
||||||
|
// Additionally, this fee should be less than the fee we sent prior.
|
||||||
|
peerFee := closingSignedMsg.FeeSatoshis
|
||||||
|
if peerFee < lastFeeSent {
|
||||||
|
t.Fatalf("new fee should be greater than prior: new=%v, "+
|
||||||
|
"prior=%v", peerFee, lastFeeSent)
|
||||||
|
}
|
||||||
|
if peerFee > increasedFee {
|
||||||
|
t.Fatalf("new fee should be less than our fee: new=%v, "+
|
||||||
|
"prior=%v", peerFee, increasedFee)
|
||||||
|
}
|
||||||
|
lastFeeSent = closingSignedMsg.FeeSatoshis
|
||||||
|
|
||||||
// We try negotiating a 2.1x fee, which should also be rejected.
|
// We try negotiating a 2.1x fee, which should also be rejected.
|
||||||
increasedFee = uint64(float64(initiatorIdealFee) * 2.1)
|
increasedFee = btcutil.Amount(float64(initiatorIdealFee) * 2.1)
|
||||||
responderSig, proposedFee, err := responderChan.CreateCloseProposal(
|
responderSig, err := responderChan.CreateCloseProposal(
|
||||||
increasedFee, dummyDeliveryScript, initiatorDeliveryScript,
|
increasedFee, dummyDeliveryScript, initiatorDeliveryScript,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -472,8 +548,11 @@ func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
|||||||
t.Fatalf("error parsing signature: %v", err)
|
t.Fatalf("error parsing signature: %v", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
closingSigned = lnwire.NewClosingSigned(chanID, proposedFee, parsedSig)
|
closingSigned = lnwire.NewClosingSigned(chanID, increasedFee, parsedSig)
|
||||||
initiator.closingSignedChanReqs <- closingSigned
|
initiator.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// It still won't be accepted, and we should get a new proposal, the
|
// It still won't be accepted, and we should get a new proposal, the
|
||||||
// average of what we proposed, and what they proposed last time.
|
// average of what we proposed, and what they proposed last time.
|
||||||
@ -489,15 +568,21 @@ func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
|||||||
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
t.Fatalf("expected ClosingSigned message, got %T", msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
avgFee = (peerFee + increasedFee) / 2
|
// Once again, the fee sent by the initiator should be greater than the
|
||||||
|
// last fee they sent, but less than the last fee we sent.
|
||||||
peerFee = initiatorClosingSigned.FeeSatoshis
|
peerFee = initiatorClosingSigned.FeeSatoshis
|
||||||
if peerFee != avgFee {
|
if peerFee < lastFeeSent {
|
||||||
t.Fatalf("expected ClosingSigned with fee %v, got %v",
|
t.Fatalf("new fee should be greater than prior: new=%v, "+
|
||||||
proposedFee, initiatorClosingSigned.FeeSatoshis)
|
"prior=%v", peerFee, lastFeeSent)
|
||||||
|
}
|
||||||
|
if peerFee > increasedFee {
|
||||||
|
t.Fatalf("new fee should be less than our fee: new=%v, "+
|
||||||
|
"prior=%v", peerFee, increasedFee)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Accept fee.
|
// At this point, we'll accept their fee by sending back a CloseSigned
|
||||||
responderSig, proposedFee, err = responderChan.CreateCloseProposal(
|
// message with an identical fee.
|
||||||
|
responderSig, err = responderChan.CreateCloseProposal(
|
||||||
peerFee, dummyDeliveryScript, initiatorDeliveryScript,
|
peerFee, dummyDeliveryScript, initiatorDeliveryScript,
|
||||||
)
|
)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -509,8 +594,11 @@ func TestPeerChannelClosureFeeNegotiationsInitiator(t *testing.T) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("error parsing signature: %v", err)
|
t.Fatalf("error parsing signature: %v", err)
|
||||||
}
|
}
|
||||||
closingSigned = lnwire.NewClosingSigned(chanID, proposedFee, parsedSig)
|
closingSigned = lnwire.NewClosingSigned(chanID, peerFee, parsedSig)
|
||||||
initiator.closingSignedChanReqs <- closingSigned
|
initiator.chanCloseMsgs <- &closeMsg{
|
||||||
|
cid: chanID,
|
||||||
|
msg: closingSigned,
|
||||||
|
}
|
||||||
|
|
||||||
// Wait for closing tx to be broadcasted.
|
// Wait for closing tx to be broadcasted.
|
||||||
select {
|
select {
|
||||||
|
@ -137,13 +137,19 @@ func createTestPeer(notifier chainntnfs.ChainNotifier,
|
|||||||
}
|
}
|
||||||
|
|
||||||
estimator := &lnwallet.StaticFeeEstimator{FeeRate: 50}
|
estimator := &lnwallet.StaticFeeEstimator{FeeRate: 50}
|
||||||
feePerKw := btcutil.Amount(estimator.EstimateFeePerWeight(1) * 1000)
|
feePerWeight, err := estimator.EstimateFeePerWeight(1)
|
||||||
|
if err != nil {
|
||||||
|
return nil, nil, nil, nil, err
|
||||||
|
}
|
||||||
|
feePerKw := feePerWeight * 1000
|
||||||
|
|
||||||
// TODO(roasbeef): need to factor in commit fee?
|
// TODO(roasbeef): need to factor in commit fee?
|
||||||
aliceCommit := channeldb.ChannelCommitment{
|
aliceCommit := channeldb.ChannelCommitment{
|
||||||
CommitHeight: 0,
|
CommitHeight: 0,
|
||||||
LocalBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
LocalBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
||||||
RemoteBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
RemoteBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
||||||
FeePerKw: feePerKw,
|
FeePerKw: feePerKw,
|
||||||
|
CommitFee: 8688,
|
||||||
CommitTx: aliceCommitTx,
|
CommitTx: aliceCommitTx,
|
||||||
CommitSig: bytes.Repeat([]byte{1}, 71),
|
CommitSig: bytes.Repeat([]byte{1}, 71),
|
||||||
}
|
}
|
||||||
@ -152,6 +158,7 @@ func createTestPeer(notifier chainntnfs.ChainNotifier,
|
|||||||
LocalBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
LocalBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
||||||
RemoteBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
RemoteBalance: lnwire.NewMSatFromSatoshis(channelBal),
|
||||||
FeePerKw: feePerKw,
|
FeePerKw: feePerKw,
|
||||||
|
CommitFee: 8688,
|
||||||
CommitTx: bobCommitTx,
|
CommitTx: bobCommitTx,
|
||||||
CommitSig: bytes.Repeat([]byte{1}, 71),
|
CommitSig: bytes.Repeat([]byte{1}, 71),
|
||||||
}
|
}
|
||||||
@ -258,9 +265,9 @@ func createTestPeer(notifier chainntnfs.ChainNotifier,
|
|||||||
activeChannels: make(map[lnwire.ChannelID]*lnwallet.LightningChannel),
|
activeChannels: make(map[lnwire.ChannelID]*lnwallet.LightningChannel),
|
||||||
newChannels: make(chan *newChannelMsg, 1),
|
newChannels: make(chan *newChannelMsg, 1),
|
||||||
|
|
||||||
|
activeChanCloses: make(map[lnwire.ChannelID]*channelCloser),
|
||||||
localCloseChanReqs: make(chan *htlcswitch.ChanClose),
|
localCloseChanReqs: make(chan *htlcswitch.ChanClose),
|
||||||
shutdownChanReqs: make(chan *lnwire.Shutdown),
|
chanCloseMsgs: make(chan *closeMsg),
|
||||||
closingSignedChanReqs: make(chan *lnwire.ClosingSigned),
|
|
||||||
|
|
||||||
queueQuit: make(chan struct{}),
|
queueQuit: make(chan struct{}),
|
||||||
quit: make(chan struct{}),
|
quit: make(chan struct{}),
|
||||||
|
Loading…
Reference in New Issue
Block a user