itest: batch channel fee params

This commit is contained in:
Slyghtning 2023-07-22 18:28:16 +02:00
parent 47bcf7af69
commit 14be2cdae0
No known key found for this signature in database
GPG key ID: F82D456EA023C9BF
2 changed files with 110 additions and 7 deletions

View file

@ -1,6 +1,7 @@
package itest
import (
"context"
"fmt"
"testing"
"time"
@ -9,6 +10,7 @@ import (
"github.com/btcsuite/btcd/chaincfg/chainhash"
"github.com/btcsuite/btcd/txscript"
"github.com/btcsuite/btcd/wire"
"github.com/lightningnetwork/lnd/chainreg"
"github.com/lightningnetwork/lnd/funding"
"github.com/lightningnetwork/lnd/input"
"github.com/lightningnetwork/lnd/labels"
@ -717,13 +719,24 @@ func testBatchChanFunding(ht *lntest.HarnessTest) {
carol := ht.NewNode("carol", []string{"--minchansize=200000"})
dave := ht.NewNode("dave", nil)
// Next we create a node that will receive a zero-conf channel open from
// Alice. We'll create the node with the required parameters.
scidAliasArgs := []string{
"--protocol.option-scid-alias",
"--protocol.zero-conf",
"--protocol.anchors",
}
eve := ht.NewNode("eve", scidAliasArgs)
alice, bob := ht.Alice, ht.Bob
ht.RestartNodeWithExtraArgs(alice, scidAliasArgs)
// Before we start the test, we'll ensure Alice is connected to Carol
// and Dave so she can open channels to both of them (and Bob).
// and Dave, so she can open channels to both of them (and Bob).
ht.EnsureConnected(alice, bob)
ht.EnsureConnected(alice, carol)
ht.EnsureConnected(alice, dave)
ht.EnsureConnected(alice, eve)
// Let's create our batch TX request. This first one should fail as we
// open a channel to Carol that is too small for her min chan size.
@ -733,26 +746,51 @@ func testBatchChanFunding(ht *lntest.HarnessTest) {
Channels: []*lnrpc.BatchOpenChannel{{
NodePubkey: bob.PubKey[:],
LocalFundingAmount: 100_000,
BaseFee: 1337,
UseBaseFee: true,
}, {
NodePubkey: carol.PubKey[:],
LocalFundingAmount: 100_000,
FeeRate: 1337,
UseFeeRate: true,
}, {
NodePubkey: dave.PubKey[:],
LocalFundingAmount: 100_000,
BaseFee: 1337,
UseBaseFee: true,
FeeRate: 1337,
UseFeeRate: true,
}, {
NodePubkey: eve.PubKey[:],
LocalFundingAmount: 100_000,
Private: true,
ZeroConf: true,
CommitmentType: lnrpc.CommitmentType_ANCHORS,
}},
}
// Check that batch opening fails due to the minchansize requirement.
err := alice.RPC.BatchOpenChannelAssertErr(batchReq)
require.Contains(ht, err.Error(), "initial negotiation failed")
// Let's fix the minimum amount for Alice now and try again.
batchReq.Channels[1].LocalFundingAmount = 200_000
// Set up a ChannelAcceptor for Eve to accept a zero-conf opening from
// Alice.
acceptStream, cancel := eve.RPC.ChannelAcceptor()
go acceptChannel(ht.T, true, acceptStream)
// Batch-open all channels.
batchResp := alice.RPC.BatchOpenChannel(batchReq)
require.Len(ht, batchResp.PendingChannels, 3)
require.Len(ht, batchResp.PendingChannels, 4)
txHash, err := chainhash.NewHash(batchResp.PendingChannels[0].Txid)
require.NoError(ht, err)
// Remove the ChannelAcceptor.
cancel()
chanPoint1 := &lnrpc.ChannelPoint{
FundingTxid: &lnrpc.ChannelPoint_FundingTxidBytes{
FundingTxidBytes: batchResp.PendingChannels[0].Txid,
@ -771,7 +809,26 @@ func testBatchChanFunding(ht *lntest.HarnessTest) {
},
OutputIndex: batchResp.PendingChannels[2].OutputIndex,
}
chanPoint4 := &lnrpc.ChannelPoint{
FundingTxid: &lnrpc.ChannelPoint_FundingTxidBytes{
FundingTxidBytes: batchResp.PendingChannels[3].Txid,
},
OutputIndex: batchResp.PendingChannels[3].OutputIndex,
}
// Ensure that Alice can send funds to Eve via the zero-conf channel
// before the batch transaction was mined.
ht.AssertTopologyChannelOpen(alice, chanPoint4)
eveInvoiceParams := &lnrpc.Invoice{
Value: int64(10_000),
Private: true,
}
eveInvoiceResp := eve.RPC.AddInvoice(eveInvoiceParams)
ht.CompletePaymentRequests(
alice, []string{eveInvoiceResp.PaymentRequest},
)
// Mine the batch transaction and check the network topology.
block := ht.MineBlocksAndAssertNumTxes(6, 1)[0]
ht.Miner.AssertTxInBlock(block, txHash)
ht.AssertTopologyChannelOpen(alice, chanPoint1)
@ -780,15 +837,18 @@ func testBatchChanFunding(ht *lntest.HarnessTest) {
// Check if the change type from the batch_open_channel funding is P2TR.
rawTx := ht.Miner.GetRawTransaction(txHash)
require.Len(ht, rawTx.MsgTx().TxOut, 4)
require.Len(ht, rawTx.MsgTx().TxOut, 5)
// For calculating the change output index we use the formula for the
// sum of consecutive of integers (n(n+1)/2). All the channel point
// indexes are known, so we just calculate the difference to get the
// change output index.
changeIndex := uint32(6) - (chanPoint1.OutputIndex +
chanPoint2.OutputIndex + chanPoint3.OutputIndex)
// Example: Batch outputs = 4, sum_consecutive_ints(4) = 10
// Subtract all other output indices to get the change index:
// 10 - 0 - 1 - 2 - 3 = 4
changeIndex := uint32(10) - (chanPoint1.OutputIndex +
chanPoint2.OutputIndex + chanPoint3.OutputIndex +
chanPoint4.OutputIndex)
ht.AssertOutputScriptClass(
rawTx, changeIndex, txscript.WitnessV1TaprootTy,
)
@ -808,6 +868,28 @@ func testBatchChanFunding(ht *lntest.HarnessTest) {
resp := carol.RPC.AddInvoice(invoice)
ht.CompletePaymentRequests(alice, []string{resp.PaymentRequest})
// Confirm that Alice's channel partners see here initial fee settings.
ensurePolicy(
ht, alice, bob, chanPoint1,
lnwire.MilliSatoshi(batchReq.Channels[0].BaseFee),
chainreg.DefaultBitcoinFeeRate,
)
ensurePolicy(
ht, alice, carol, chanPoint2,
chainreg.DefaultBitcoinBaseFeeMSat,
lnwire.MilliSatoshi(batchReq.Channels[1].FeeRate),
)
ensurePolicy(
ht, alice, dave, chanPoint3,
lnwire.MilliSatoshi(batchReq.Channels[2].BaseFee),
lnwire.MilliSatoshi(batchReq.Channels[2].FeeRate),
)
ensurePolicy(
ht, alice, eve, chanPoint4,
chainreg.DefaultBitcoinBaseFeeMSat,
chainreg.DefaultBitcoinFeeRate,
)
// To conclude, we'll close the newly created channel between Carol and
// Dave. This function will also block until the channel is closed and
// will additionally assert the relevant channel closing post
@ -815,6 +897,27 @@ func testBatchChanFunding(ht *lntest.HarnessTest) {
ht.CloseChannel(alice, chanPoint1)
ht.CloseChannel(alice, chanPoint2)
ht.CloseChannel(alice, chanPoint3)
ht.CloseChannel(alice, chanPoint4)
}
// ensurePolicy ensures that the peer sees alice's channel fee settings.
func ensurePolicy(ht *lntest.HarnessTest, alice, peer *node.HarnessNode,
chanPoint *lnrpc.ChannelPoint, expectedBaseFee lnwire.MilliSatoshi,
expectedFeeRate lnwire.MilliSatoshi) {
channel := ht.AssertChannelExists(peer, chanPoint)
policy, err := peer.RPC.LN.GetChanInfo(
context.Background(), &lnrpc.ChanInfoRequest{
ChanId: channel.ChanId,
},
)
require.NoError(ht, err)
alicePolicy := policy.Node1Policy
if alice.PubKeyStr == policy.Node2Pub {
alicePolicy = policy.Node2Policy
}
require.EqualValues(ht, expectedBaseFee, alicePolicy.FeeBaseMsat)
require.EqualValues(ht, expectedFeeRate, alicePolicy.FeeRateMilliMsat)
}
// deriveFundingShim creates a channel funding shim by deriving the necessary

View file

@ -388,7 +388,7 @@ func (h *HarnessTest) AssertOutputScriptClass(tx *btcutil.Tx,
pkScript, err := txscript.ParsePkScript(txOut.PkScript)
require.NoError(h, err)
require.Equal(h, pkScript.Class(), scriptClass)
require.Equal(h, scriptClass, pkScript.Class())
}
// findChannel tries to find a target channel in the node using the given