Skip to content

Commit

Permalink
options: make anchors enabled by default, ignore experimental-anchors.
Browse files Browse the repository at this point in the history
We still want to test non-anchor channels, as we still support them, but
we've made it non-experimental.  To test non-anchor channels, we
use dev-force-features: -23.

Many tests change, as fees change, and we keep an emergency reserve.

Changelog-Added: Protocol: `option_anchors_zero_fee_htlc_tx` enabled, no longer experimental.
Changelog-Changed: Config: `experimental-anchors` now does nothing (it's enabled by default).
Signed-off-by: Rusty Russell <[email protected]>

Header from folded patch 'fixup!_options__make_anchors_enabled_by_default,_ignore_experimental-anchors.patch':

fixup! options: make anchors enabled by default, ignore experimental-anchors.
  • Loading branch information
rustyrussell authored and cdecker committed Feb 4, 2024
1 parent 2b9ae10 commit 4aafb77
Show file tree
Hide file tree
Showing 13 changed files with 226 additions and 225 deletions.
23 changes: 21 additions & 2 deletions contrib/pyln-testing/pyln/testing/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -939,10 +939,10 @@ def fundbalancedchannel(self, remote_node, total_capacity=FUNDAMOUNT, announce=T
else:
total_capacity = int(total_capacity)

self.fundwallet(total_capacity + 10000)
self.fundwallet(total_capacity + 35000)

if remote_node.config('experimental-dual-fund'):
remote_node.fundwallet(total_capacity + 10000)
remote_node.fundwallet(total_capacity + 35000)
# We cut the total_capacity in half, since the peer's
# expected to contribute that same amount
chan_capacity = total_capacity // 2
Expand Down Expand Up @@ -1274,6 +1274,25 @@ def mock_estimatesmartfee(r):
}
self.daemon.rpcproxy.mock_rpc('estimatesmartfee', mock_estimatesmartfee)

def mock_getmempoolinfo(r):
return {
'id': r['id'],
'error': None,
'result': {
'mempoolminfee': Decimal(feerates[4] * 4) / 10**8,
'minrelaytxfee': Decimal(feerates[4] * 4) / 10**8,
},
}

# Did they want to set minfee as well?
if len(feerates) > 4:
assert len(feerates) == 5
self.daemon.rpcproxy.mock_rpc('getmempoolinfo', mock_getmempoolinfo)

if wait_for_effect:
wait_for(lambda:
self.rpc.feerates(style='perkb')['perkb']['floor'] == feerates[4] * 4)

# Technically, this waits until it's called, not until it's processed.
# We wait until all four levels have been called.
if wait_for_effect:
Expand Down
10 changes: 0 additions & 10 deletions doc/lightningd-config.5.md
Original file line number Diff line number Diff line change
Expand Up @@ -461,7 +461,6 @@ specified multuple times. (Added in v23.08).
* **min-emergency-msat**=*msat*

This is the amount of funds to keep in the wallet to close anchor channels (which don't carry their own transaction fees). It defaults to 25000sat, and is only maintained if there are any anchor channels (or, when opening an anchor channel). This amount may be insufficient for multiple closes at once, however.


### Cleanup control options:

Expand Down Expand Up @@ -793,15 +792,6 @@ protocol to update channel types. At the moment, we only support setting
this option.


* **experimental-anchors**

Specifying this option turns on the `option_anchors_zero_fee_htlc_tx`
feature, meaning we can open anchor-based channels. This will become
the default for new channels in future, after more testing. Anchor-based
channels use larger commitment transactions, with the trade-off that they
don't have to use a worst-case fee, but can bump the commitment transaction
if it's needed. Note that this means that we need to keep
some funds aside: see `min-emergency-msat`.

BUGS
----
Expand Down
2 changes: 1 addition & 1 deletion lightningd/hsm_control.c
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,7 @@ struct ext_key *hsm_init(struct lightningd *ld)
if (feature_offered(ld->our_features->bits[INIT_FEATURE],
OPT_ANCHORS_ZERO_FEE_HTLC_TX)
&& !hsm_capable(ld, WIRE_HSMD_SIGN_ANCHORSPEND)) {
fatal("--experimental-anchors needs HSM capable of signing anchors!");
fatal("anchors needs HSM capable of signing anchors!");
}

if (feature_offered(ld->our_features->bits[INIT_FEATURE],
Expand Down
1 change: 1 addition & 0 deletions lightningd/lightningd.c
Original file line number Diff line number Diff line change
Expand Up @@ -906,6 +906,7 @@ static struct feature_set *default_features(const tal_t *ctx)
OPTIONAL_FEATURE(OPT_ZEROCONF),
OPTIONAL_FEATURE(OPT_CHANNEL_TYPE),
OPTIONAL_FEATURE(OPT_ROUTE_BLINDING),
OPTIONAL_FEATURE(OPT_ANCHORS_ZERO_FEE_HTLC_TX),
};

for (size_t i = 0; i < ARRAY_SIZE(features); i++) {
Expand Down
8 changes: 2 additions & 6 deletions lightningd/options.c
Original file line number Diff line number Diff line change
Expand Up @@ -1258,10 +1258,7 @@ static char *opt_set_quiesce(struct lightningd *ld)

static char *opt_set_anchor_zero_fee_htlc_tx(struct lightningd *ld)
{
/* Requires static_remotekey, but we always set that */
feature_set_or(ld->our_features,
take(feature_set_for_feature(NULL,
OPTIONAL_FEATURE(OPT_ANCHORS_ZERO_FEE_HTLC_TX))));
/* FIXME: deprecated_apis! */
return NULL;
}

Expand Down Expand Up @@ -1469,8 +1466,7 @@ static void register_opts(struct lightningd *ld)
" channels.");
opt_register_early_noarg("--experimental-anchors",
opt_set_anchor_zero_fee_htlc_tx, ld,
"EXPERIMENTAL: enable option_anchors_zero_fee_htlc_tx"
" to open zero-fee-anchor channels");
opt_hidden);
clnopt_witharg("--announce-addr-dns", OPT_EARLY|OPT_SHOWBOOL,
opt_set_bool_arg, opt_show_bool,
&ld->announce_dns,
Expand Down
3 changes: 1 addition & 2 deletions tests/test_bookkeeper.py
Original file line number Diff line number Diff line change
Expand Up @@ -355,8 +355,7 @@ def test_bookkeeping_missed_chans_leases(node_factory, bitcoind):
opts = {'funder-policy': 'match', 'funder-policy-mod': 100,
'lease-fee-base-sat': '100sat', 'lease-fee-basis': 100,
'plugin': str(coin_mvt_plugin),
'disable-plugin': 'bookkeeper',
'experimental-anchors': None}
'disable-plugin': 'bookkeeper'}

l1, l2 = node_factory.get_nodes(2, opts=opts)

Expand Down
Loading

0 comments on commit 4aafb77

Please sign in to comment.