ln-service 57.25.0 → 57.25.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/README.md +1 -0
- package/package.json +4 -2
- package/test/chainrpc-integration/test_get_height.js +2 -1
- package/test/chainrpc-integration/test_subscribe_to_blocks.js +0 -2
- package/test/chainrpc-integration/test_subscribe_to_chain_address.js +0 -4
- package/test/integration/test_add_peer.js +0 -1
- package/test/integration/test_get_chain_fee_estimate.js +10 -3
- package/test/integration/test_get_pending_payments.js +1 -1
- package/test/integration/test_subscribe_to_channels.js +1 -1
- package/test/integration/test_subscribe_to_graph.js +1 -1
- package/test/integration/test_subscribe_to_peers.js +0 -1
- package/test/integration/test_subscribe_to_transactions.js +4 -1
- package/test/invoicesrpc-integration/test_get_sweep_transactions.js +0 -1
- package/test/invoicesrpc-integration/test_subscribe_settle_invoice.js +4 -2
- package/test/routerrpc-integration/test_delete_forwarding_reputations.js +1 -1
- package/test/routerrpc-integration/test_get_forwarding_confidence.js +1 -1
- package/test/routerrpc-integration/test_get_forwarding_reputations.js +1 -1
- package/test/routerrpc-integration/test_get_payment.js +1 -1
- package/test/routerrpc-integration/test_get_route_confidence.js +1 -1
- package/test/routerrpc-integration/test_get_route_through_hops.js +4 -2
- package/test/routerrpc-integration/test_get_routing_fee_estimate.js +1 -1
- package/test/routerrpc-integration/test_multipath_payment.js +1 -1
- package/test/routerrpc-integration/test_pay_via_payment_details.js +9 -5
- package/test/routerrpc-integration/test_pay_via_payment_request.js +5 -4
- package/test/routerrpc-integration/test_pay_via_routes.js +5 -3
- package/test/routerrpc-integration/test_probe_for_route.js +2 -2
- package/test/routerrpc-integration/test_route_from_channels_complex.js +1 -1
- package/test/routerrpc-integration/test_route_from_channels_simple.js +1 -1
- package/test/routerrpc-integration/test_subscribe_to_forward_requests.js +1 -2
- package/test/routerrpc-integration/test_subscribe_to_forwards.js +1 -2
- package/test/routerrpc-integration/test_subscribe_to_past_payments.js +0 -2
- package/test/routerrpc-integration/test_subscribe_to_payments.js +0 -1
- package/test/tower_clientrpc-integration/test_connect_watchtower.js +4 -0
- package/test/tower_clientrpc-integration/test_get_connected_watchtowers.js +4 -0
- package/test/walletrpc-integration/test_fund_psbt.js +4 -1
- package/test/walletrpc-integration/test_get_chain_fee_rate.js +6 -1
- package/test/walletrpc-integration/test_get_pending_sweeps.js +0 -1
- package/test/walletrpc-integration/test_request_batched_fee_increase.js +0 -1
- package/test/walletrpc-integration/test_request_chain_fee_increase.js +14 -12
package/CHANGELOG.md
CHANGED
package/README.md
CHANGED
package/package.json
CHANGED
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
"dependencies": {
|
|
10
10
|
"bolt07": "1.9.4",
|
|
11
11
|
"invoices": "4.0.0",
|
|
12
|
-
"lightning": "10.25.
|
|
12
|
+
"lightning": "10.25.3",
|
|
13
13
|
"macaroon": "3.0.4"
|
|
14
14
|
},
|
|
15
15
|
"description": "Interaction helper for your Lightning Network daemon",
|
|
@@ -51,6 +51,8 @@
|
|
|
51
51
|
"url": "https://github.com/alexbosworth/ln-service.git"
|
|
52
52
|
},
|
|
53
53
|
"scripts": {
|
|
54
|
+
"integration-test-0.19.1": "DOCKER_LND_VERSION=v0.19.1-beta npm run test",
|
|
55
|
+
"integration-test-0.19.0": "DOCKER_LND_VERSION=v0.19.0-beta npm run test",
|
|
54
56
|
"integration-test-0.18.5": "DOCKER_LND_VERSION=v0.18.5-beta npm run test",
|
|
55
57
|
"integration-test-0.18.4": "DOCKER_LND_VERSION=v0.18.4-beta npm run test",
|
|
56
58
|
"integration-test-0.18.3": "DOCKER_LND_VERSION=v0.18.3-beta npm run test",
|
|
@@ -76,5 +78,5 @@
|
|
|
76
78
|
"integration-test-0.14.4": "DOCKER_LND_VERSION=v0.14.4-beta npm run test",
|
|
77
79
|
"test": "echo $DOCKER_LND_VERSION && node test/runner"
|
|
78
80
|
},
|
|
79
|
-
"version": "57.25.
|
|
81
|
+
"version": "57.25.2"
|
|
80
82
|
}
|
|
@@ -7,6 +7,7 @@ const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
|
7
7
|
const {getHeight} = require('./../../');
|
|
8
8
|
|
|
9
9
|
const confirmationCount = 6;
|
|
10
|
+
const interval = 100;
|
|
10
11
|
const times = 100;
|
|
11
12
|
|
|
12
13
|
// Get height should return height
|
|
@@ -17,7 +18,7 @@ test(`Get height`, async () => {
|
|
|
17
18
|
|
|
18
19
|
const startHeight = (await getHeight({lnd})).current_block_height;
|
|
19
20
|
|
|
20
|
-
await asyncRetry({times}, async () => {
|
|
21
|
+
await asyncRetry({interval, times}, async () => {
|
|
21
22
|
await generate({});
|
|
22
23
|
|
|
23
24
|
const endHeight = (await getHeight({lnd})).current_block_height;
|
|
@@ -7,12 +7,10 @@ const asyncRetry = require('async/retry');
|
|
|
7
7
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
8
8
|
|
|
9
9
|
const {createChainAddress} = require('./../../');
|
|
10
|
-
const {generateBlocks} = require('./../macros');
|
|
11
10
|
const {getHeight} = require('./../../');
|
|
12
11
|
const {getChainBalance} = require('./../../');
|
|
13
12
|
const {getWalletInfo} = require('./../../');
|
|
14
13
|
const {subscribeToBlocks} = require('./../../');
|
|
15
|
-
const {waitForTermination} = require('./../macros');
|
|
16
14
|
|
|
17
15
|
const confirmationCount = 6;
|
|
18
16
|
const interval = 50;
|
|
@@ -4,16 +4,12 @@ const test = require('node:test');
|
|
|
4
4
|
const asyncRetry = require('async/retry');
|
|
5
5
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
6
6
|
|
|
7
|
-
const {chainSendTransaction} = require('./../macros');
|
|
8
7
|
const {createChainAddress} = require('./../../');
|
|
9
|
-
const {generateBlocks} = require('./../macros');
|
|
10
8
|
const {getChainBalance} = require('./../../');
|
|
11
9
|
const {getChainTransactions} = require('./../../');
|
|
12
10
|
const {getHeight} = require('./../../');
|
|
13
|
-
const {mineTransaction} = require('./../macros');
|
|
14
11
|
const {sendToChainAddress} = require('./../../');
|
|
15
12
|
const {subscribeToChainAddress} = require('./../../');
|
|
16
|
-
const {waitForTermination} = require('./../macros');
|
|
17
13
|
|
|
18
14
|
const count = 100;
|
|
19
15
|
const defaultFee = 1e3;
|
|
@@ -5,7 +5,6 @@ const asyncRetry = require('async/retry');
|
|
|
5
5
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
6
6
|
|
|
7
7
|
const {addPeer} = require('./../../');
|
|
8
|
-
const {createCluster} = require('./../macros');
|
|
9
8
|
const {getPeers} = require('./../../');
|
|
10
9
|
|
|
11
10
|
const interval = 100;
|
|
@@ -8,8 +8,8 @@ const {createChainAddress} = require('./../../');
|
|
|
8
8
|
const {getChainBalance} = require('./../../');
|
|
9
9
|
const {getChainFeeEstimate} = require('./../../');
|
|
10
10
|
|
|
11
|
-
const expectedFee =
|
|
12
|
-
const expectedFeeRate =
|
|
11
|
+
const expectedFee = 4625;
|
|
12
|
+
const expectedFeeRate = 25;
|
|
13
13
|
const format = 'np2wpkh';
|
|
14
14
|
const size = 2;
|
|
15
15
|
const times = 200;
|
|
@@ -44,11 +44,18 @@ test(`Get chain fee estimate`, async () => {
|
|
|
44
44
|
// LND 0.15.4 and below uses P2WPKH as change
|
|
45
45
|
if (estimate.fee === 8650) {
|
|
46
46
|
strictEqual(estimate.fee, 8650, 'Total fee is estimated');
|
|
47
|
+
} else if (estimate.fee === 9250) { // LND 0.18.5 and below fee rate
|
|
48
|
+
strictEqual(estimate.fee, 9250, 'Total fee is estimated');
|
|
47
49
|
} else {
|
|
48
50
|
strictEqual(estimate.fee, expectedFee, 'Total fee is estimated');
|
|
49
51
|
}
|
|
50
52
|
|
|
51
|
-
|
|
53
|
+
// LND 0.18.5 and below fee rate is higher
|
|
54
|
+
if (estimate.tokens_per_vbyte === 50) {
|
|
55
|
+
strictEqual(estimate.tokens_per_vbyte, 50, 'Got fee/vbyte');
|
|
56
|
+
} else {
|
|
57
|
+
strictEqual(estimate.tokens_per_vbyte, expectedFeeRate, 'Got fee/vbyte');
|
|
58
|
+
}
|
|
52
59
|
|
|
53
60
|
await kill({});
|
|
54
61
|
|
|
@@ -14,7 +14,7 @@ const {getPendingPayments} = require('./../../');
|
|
|
14
14
|
const {payViaPaymentRequest} = require('./../../');
|
|
15
15
|
const {subscribeToForwardRequests} = require('./../../');
|
|
16
16
|
const {subscribeToPayViaRequest} = require('./../../');
|
|
17
|
-
const
|
|
17
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
18
18
|
|
|
19
19
|
const size = 3;
|
|
20
20
|
const tokens = 100;
|
|
@@ -150,7 +150,7 @@ test('Subscribe to channels', async () => {
|
|
|
150
150
|
|
|
151
151
|
const final = closeEvent.final_local_balance;
|
|
152
152
|
|
|
153
|
-
equal([897190, 846655, 863366].includes(final), true, 'Close final');
|
|
153
|
+
equal([897190, 846655, 863366, 875633].includes(final), true, 'Close final');
|
|
154
154
|
|
|
155
155
|
equal(closeEvent.capacity, channelCapacityTokens, 'Channel close capacity');
|
|
156
156
|
equal(!!closeEvent.close_confirm_height, true, 'Close confirm height');
|
|
@@ -4,12 +4,12 @@ const {exit} = require('node:process');
|
|
|
4
4
|
const test = require('node:test');
|
|
5
5
|
|
|
6
6
|
const asyncRetry = require('async/retry');
|
|
7
|
+
const {setupChannel} = require('ln-docker-daemons');
|
|
7
8
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
8
9
|
|
|
9
10
|
const {addPeer} = require('./../../');
|
|
10
11
|
const {closeChannel} = require('./../../');
|
|
11
12
|
const {getChannel} = require('./../../');
|
|
12
|
-
const {setupChannel} = require('./../macros');
|
|
13
13
|
const {subscribeToGraph} = require('./../../');
|
|
14
14
|
|
|
15
15
|
const capacity = 1e6;
|
|
@@ -6,7 +6,6 @@ const asyncRetry = require('async/retry');
|
|
|
6
6
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
7
7
|
|
|
8
8
|
const {addPeer} = require('./../../');
|
|
9
|
-
const {createCluster} = require('./../macros');
|
|
10
9
|
const {removePeer} = require('./../../');
|
|
11
10
|
const {subscribeToPeers} = require('./../../');
|
|
12
11
|
|
|
@@ -71,9 +71,12 @@ test(`Subscribe to chain transactions`, async () => {
|
|
|
71
71
|
if (tx.fee === 7050) {
|
|
72
72
|
equal(tx.fee, 7050, 'Transaction has a chain fee');
|
|
73
73
|
equal(tx.tokens, 1007050, 'Tx tokens is fee + tokens sent');
|
|
74
|
-
} else {
|
|
74
|
+
} else if (tx.fee === 7650) { // LND 0.18.5 and below fee rate
|
|
75
75
|
equal(tx.fee, 7650, 'Transaction has a chain fee');
|
|
76
76
|
equal(tx.tokens, 1007650, 'Tx tokens is fee + tokens sent');
|
|
77
|
+
} else {
|
|
78
|
+
equal(tx.fee, 3825, 'Transaction has a chain fee');
|
|
79
|
+
equal(tx.tokens, 1003825, 'Tx tokens is fee + tokens sent');
|
|
77
80
|
}
|
|
78
81
|
|
|
79
82
|
if (!!tx.output_addresses.find(n => n.length < 14 || n.length > 74)) {
|
|
@@ -9,7 +9,6 @@ const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
|
9
9
|
|
|
10
10
|
const {closeChannel} = require('./../../');
|
|
11
11
|
const {createHodlInvoice} = require('./../../');
|
|
12
|
-
const {delay} = require('./../macros');
|
|
13
12
|
const {getChainTransactions} = require('./../../');
|
|
14
13
|
const {getClosedChannels} = require('./../../');
|
|
15
14
|
const {getInvoice} = require('./../../');
|
|
@@ -85,8 +85,10 @@ test(`Subscribe to settled invoice`, async () => {
|
|
|
85
85
|
if (!!payments.length) {
|
|
86
86
|
const [payment] = payments;
|
|
87
87
|
|
|
88
|
-
|
|
89
|
-
|
|
88
|
+
const messages = payment.messages.filter(n => n.type === tlvType);
|
|
89
|
+
|
|
90
|
+
if (!!messages.filter(n => n.type === tlvType).length) {
|
|
91
|
+
const [{type, value}] = messages;
|
|
90
92
|
|
|
91
93
|
equal(type, tlvType, 'Payment message TLV type returned');
|
|
92
94
|
equal(value, tlvValue, 'Payment message TLV value returned');
|
|
@@ -12,7 +12,7 @@ const {getForwardingReputations} = require('./../../');
|
|
|
12
12
|
const {getNetworkGraph} = require('./../../');
|
|
13
13
|
const {payViaPaymentRequest} = require('./../../');
|
|
14
14
|
const {probeForRoute} = require('./../../');
|
|
15
|
-
const
|
|
15
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
16
16
|
|
|
17
17
|
const flatten = arr => [].concat(...arr);
|
|
18
18
|
const interval = 10;
|
|
@@ -11,7 +11,7 @@ const {getForwardingConfidence} = require('./../../');
|
|
|
11
11
|
const {getForwardingReputations} = require('./../../');
|
|
12
12
|
const {getRouteToDestination} = require('./../../');
|
|
13
13
|
const {probeForRoute} = require('./../../');
|
|
14
|
-
const
|
|
14
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
15
15
|
|
|
16
16
|
const channelCapacityTokens = 1e6;
|
|
17
17
|
const size = 3;
|
|
@@ -11,7 +11,7 @@ const {getChannels} = require('./../../');
|
|
|
11
11
|
const {getForwardingReputations} = require('./../../');
|
|
12
12
|
const {getNetworkGraph} = require('./../../');
|
|
13
13
|
const {probeForRoute} = require('./../../');
|
|
14
|
-
const
|
|
14
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
15
15
|
|
|
16
16
|
const chain = '0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b1a11466e2206';
|
|
17
17
|
const channelCapacityTokens = 1e6;
|
|
@@ -14,7 +14,7 @@ const {getHeight} = require('./../../');
|
|
|
14
14
|
const {getPayment} = require('./../../');
|
|
15
15
|
const {getWalletInfo} = require('./../../');
|
|
16
16
|
const {payViaPaymentRequest} = require('./../../');
|
|
17
|
-
const
|
|
17
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
18
18
|
|
|
19
19
|
const interval = 50;
|
|
20
20
|
const size = 3;
|
|
@@ -9,7 +9,7 @@ const {addPeer} = require('./../../');
|
|
|
9
9
|
const {getRouteConfidence} = require('./../../');
|
|
10
10
|
const {getWalletInfo} = require('./../../');
|
|
11
11
|
const {probeForRoute} = require('./../../');
|
|
12
|
-
const
|
|
12
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
13
13
|
|
|
14
14
|
const channelCapacityTokens = 1e6;
|
|
15
15
|
const interval = 50;
|
|
@@ -15,7 +15,7 @@ const {getRouteThroughHops} = require('./../../');
|
|
|
15
15
|
const {getRouteToDestination} = require('./../../');
|
|
16
16
|
const {getWalletInfo} = require('./../../');
|
|
17
17
|
const {payViaRoutes} = require('./../../');
|
|
18
|
-
const
|
|
18
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
19
19
|
|
|
20
20
|
const confirmationCount = 6;
|
|
21
21
|
const flatten = arr => [].concat(...arr);
|
|
@@ -132,9 +132,11 @@ test(`Get route through hops`, async () => {
|
|
|
132
132
|
|
|
133
133
|
const [payment] = payments;
|
|
134
134
|
|
|
135
|
+
const paymentMessages = payment.messages.filter(n => n.type !== '106823');
|
|
136
|
+
|
|
135
137
|
equal(payment.total_mtokens, invoice.mtokens, 'Got MPP total mtokens');
|
|
136
138
|
|
|
137
|
-
deepEqual(
|
|
139
|
+
deepEqual(paymentMessages, route.messages, 'Remote got TLV messages');
|
|
138
140
|
|
|
139
141
|
await kill({});
|
|
140
142
|
|
|
@@ -10,7 +10,7 @@ const {createInvoice} = require('./../../');
|
|
|
10
10
|
const {getRoutingFeeEstimate} = require('./../../');
|
|
11
11
|
const {getWalletInfo} = require('./../../');
|
|
12
12
|
const {probeForRoute} = require('./../../');
|
|
13
|
-
const
|
|
13
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
14
14
|
|
|
15
15
|
const channelCapacityTokens = 1e6;
|
|
16
16
|
const interval = 50;
|
|
@@ -14,7 +14,7 @@ const {getRouteToDestination} = require('./../../');
|
|
|
14
14
|
const {parsePaymentRequest} = require('./../../');
|
|
15
15
|
const {payViaPaymentRequest} = require('./../../');
|
|
16
16
|
const {payViaRoutes} = require('./../../');
|
|
17
|
-
const
|
|
17
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
18
18
|
|
|
19
19
|
const all = promise => Promise.all(promise);
|
|
20
20
|
const capacity = 1e6;
|
|
@@ -12,7 +12,7 @@ const {getHeight} = require('./../../');
|
|
|
12
12
|
const {getInvoice} = require('./../../');
|
|
13
13
|
const {getInvoices} = require('./../../');
|
|
14
14
|
const {payViaPaymentDetails} = require('./../../');
|
|
15
|
-
const
|
|
15
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
16
16
|
|
|
17
17
|
const size = 3;
|
|
18
18
|
const start = new Date().toISOString();
|
|
@@ -137,8 +137,10 @@ test(`Pay via payment details`, async () => {
|
|
|
137
137
|
if (!!payments) {
|
|
138
138
|
const [payment] = payments;
|
|
139
139
|
|
|
140
|
-
|
|
141
|
-
|
|
140
|
+
const messages = payment.messages.filter(n => n.type !== '106823');
|
|
141
|
+
|
|
142
|
+
if (!!payment && !!messages.length) {
|
|
143
|
+
const [message] = messages;
|
|
142
144
|
|
|
143
145
|
equal(message.type, tlvType, 'Got TLV type');
|
|
144
146
|
equal(message.value, tlvData, 'Got TLV value');
|
|
@@ -154,8 +156,10 @@ test(`Pay via payment details`, async () => {
|
|
|
154
156
|
if (!!payments.length) {
|
|
155
157
|
const [payment] = payments;
|
|
156
158
|
|
|
157
|
-
|
|
158
|
-
|
|
159
|
+
const messages = payment.messages.filter(n => n.type !== '106823');
|
|
160
|
+
|
|
161
|
+
if (!!payment && !!messages.length) {
|
|
162
|
+
const [message] = messages;
|
|
159
163
|
|
|
160
164
|
equal(message.type, tlvType, 'Got TLV type');
|
|
161
165
|
equal(message.value, tlvData, 'Got TLV value');
|
|
@@ -8,12 +8,11 @@ const {setupChannel} = require('ln-docker-daemons');
|
|
|
8
8
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
9
9
|
|
|
10
10
|
const {addPeer} = require('./../../');
|
|
11
|
-
const {createCluster} = require('./../macros');
|
|
12
11
|
const {createInvoice} = require('./../../');
|
|
13
12
|
const {getInvoice} = require('./../../');
|
|
14
13
|
const {getWalletInfo} = require('./../../');
|
|
15
14
|
const {payViaPaymentRequest} = require('./../../');
|
|
16
|
-
const
|
|
15
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
17
16
|
|
|
18
17
|
const interval = 50;
|
|
19
18
|
const size = 3;
|
|
@@ -132,8 +131,10 @@ test(`Pay via payment request`, async () => {
|
|
|
132
131
|
if (!!payments.length) {
|
|
133
132
|
const [payment] = payments;
|
|
134
133
|
|
|
135
|
-
|
|
136
|
-
|
|
134
|
+
const messages = payment.messages.filter(n => n.type !== '106823');
|
|
135
|
+
|
|
136
|
+
if (!!messages.length) {
|
|
137
|
+
const [message] = messages;
|
|
137
138
|
|
|
138
139
|
equal(message.type, tlvType, 'Got TLV message type');
|
|
139
140
|
equal(message.value, tlvValue, 'Got TLV message value');
|
|
@@ -18,7 +18,7 @@ const {openChannel} = require('./../../');
|
|
|
18
18
|
const {payViaRoutes} = require('./../../');
|
|
19
19
|
const {routeFromChannels} = require('./../../');
|
|
20
20
|
const {subscribeToForwardRequests} = require('./../../');
|
|
21
|
-
const
|
|
21
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
22
22
|
|
|
23
23
|
const channelCapacityTokens = 1e6;
|
|
24
24
|
const confirmationCount = 6;
|
|
@@ -205,8 +205,10 @@ test(`Pay via routes`, async () => {
|
|
|
205
205
|
if (!!paidInvoice.payments.length) {
|
|
206
206
|
const [payment] = paidInvoice.payments;
|
|
207
207
|
|
|
208
|
-
|
|
209
|
-
|
|
208
|
+
const messages = payment.messages.filter(n => n.type !== '106823');
|
|
209
|
+
|
|
210
|
+
if (!!messages.length) {
|
|
211
|
+
const [message] = messages;
|
|
210
212
|
|
|
211
213
|
equal(message.type, tlvType, 'Got message type');
|
|
212
214
|
equal(message.value, tlvValue, 'Got message value');
|
|
@@ -9,7 +9,6 @@ const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
|
9
9
|
const {addPeer} = require('./../../');
|
|
10
10
|
const {createChainAddress} = require('./../../');
|
|
11
11
|
const {createInvoice} = require('./../../');
|
|
12
|
-
const {delay} = require('./../macros');
|
|
13
12
|
const {deleteForwardingReputations} = require('./../../');
|
|
14
13
|
const {getChainBalance} = require('./../../');
|
|
15
14
|
const {getFailedPayments} = require('./../../');
|
|
@@ -18,13 +17,14 @@ const {getWalletVersion} = require('./../../');
|
|
|
18
17
|
const {payViaRoutes} = require('./../../');
|
|
19
18
|
const {probeForRoute} = require('./../../');
|
|
20
19
|
const {sendToChainAddress} = require('./../../');
|
|
21
|
-
const
|
|
20
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
22
21
|
|
|
23
22
|
const chain = '0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b1a11466e2206';
|
|
24
23
|
const channelCapacityTokens = 1e6;
|
|
25
24
|
const confirmationCount = 20;
|
|
26
25
|
const count = 100;
|
|
27
26
|
const defaultFee = 1e3;
|
|
27
|
+
const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
|
|
28
28
|
const interval = 50;
|
|
29
29
|
const size = 3;
|
|
30
30
|
const times = 1000;
|
|
@@ -17,7 +17,7 @@ const {getWalletInfo} = require('./../../');
|
|
|
17
17
|
const {payViaRoutes} = require('./../../');
|
|
18
18
|
const {routeFromChannels} = require('./../../');
|
|
19
19
|
const {updateRoutingFees} = require('./../../');
|
|
20
|
-
const
|
|
20
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
21
21
|
|
|
22
22
|
const baseFee = '1000';
|
|
23
23
|
const confirmationCount = 6;
|
|
@@ -16,7 +16,7 @@ const {getWalletInfo} = require('./../../');
|
|
|
16
16
|
const {payViaRoutes} = require('./../../');
|
|
17
17
|
const {routeFromChannels} = require('./../../');
|
|
18
18
|
const {updateRoutingFees} = require('./../../');
|
|
19
|
-
const
|
|
19
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
20
20
|
|
|
21
21
|
const baseFee = '1000';
|
|
22
22
|
const confirmationCount = 6;
|
|
@@ -8,7 +8,6 @@ const {setupChannel} = require('ln-docker-daemons');
|
|
|
8
8
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
9
9
|
|
|
10
10
|
const {addPeer} = require('./../../');
|
|
11
|
-
const {createCluster} = require('./../macros');
|
|
12
11
|
const {createInvoice} = require('./../../');
|
|
13
12
|
const {deleteForwardingReputations} = require('./../../');
|
|
14
13
|
const {getHeight} = require('./../../');
|
|
@@ -17,7 +16,7 @@ const {getPayment} = require('./../../');
|
|
|
17
16
|
const {payViaPaymentRequest} = require('./../../');
|
|
18
17
|
const {subscribeToForwardRequests} = require('./../../');
|
|
19
18
|
const {subscribeToPayViaRequest} = require('./../../');
|
|
20
|
-
const
|
|
19
|
+
const waitForRoute = require('./../macros/wait_for_route');
|
|
21
20
|
|
|
22
21
|
const size = 3;
|
|
23
22
|
const tokens = 100;
|
|
@@ -9,9 +9,7 @@ const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
|
9
9
|
|
|
10
10
|
const {addPeer} = require('./../../');
|
|
11
11
|
const {cancelHodlInvoice} = require('./../../');
|
|
12
|
-
const {createCluster} = require('./../macros');
|
|
13
12
|
const {createInvoice} = require('./../../');
|
|
14
|
-
const {delay} = require('./../macros');
|
|
15
13
|
const {getChannels} = require('./../../');
|
|
16
14
|
const {getHeight} = require('./../../');
|
|
17
15
|
const {getLockedUtxos} = require('./../../');
|
|
@@ -20,6 +18,7 @@ const {payViaPaymentRequest} = require('./../../');
|
|
|
20
18
|
const {subscribeToForwards} = require('./../../');
|
|
21
19
|
|
|
22
20
|
const anchorsFeatureBit = 23;
|
|
21
|
+
const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
|
|
23
22
|
const interval = 10;
|
|
24
23
|
const size = 3;
|
|
25
24
|
const times = 1000;
|
|
@@ -6,13 +6,11 @@ const {setupChannel} = require('ln-docker-daemons');
|
|
|
6
6
|
const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
7
7
|
|
|
8
8
|
const {createInvoice} = require('./../../');
|
|
9
|
-
const {delay} = require('./../macros');
|
|
10
9
|
const {getPayment} = require('./../../');
|
|
11
10
|
const {getWalletInfo} = require('./../../');
|
|
12
11
|
const {payViaPaymentRequest} = require('./../../');
|
|
13
12
|
const {subscribeToForwards} = require('./../../');
|
|
14
13
|
const {subscribeToPastPayments} = require('./../../');
|
|
15
|
-
const {waitForRoute} = require('./../macros');
|
|
16
14
|
|
|
17
15
|
const interval = 1000;
|
|
18
16
|
const size = 2;
|
|
@@ -11,7 +11,6 @@ const {getWalletInfo} = require('./../../');
|
|
|
11
11
|
const {payViaPaymentRequest} = require('./../../');
|
|
12
12
|
const {subscribeToForwards} = require('./../../');
|
|
13
13
|
const {subscribeToPayments} = require('./../../');
|
|
14
|
-
const {waitForRoute} = require('./../macros');
|
|
15
14
|
|
|
16
15
|
const interval = 1000;
|
|
17
16
|
const size = 2;
|
|
@@ -10,6 +10,7 @@ const {getTowerServerInfo} = require('./../../');
|
|
|
10
10
|
const {getWalletInfo} = require('./../../');
|
|
11
11
|
|
|
12
12
|
const conf = ['--watchtower.active', '--wtclient.active'];
|
|
13
|
+
const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
|
|
13
14
|
const interval = 50;
|
|
14
15
|
const size = 2;
|
|
15
16
|
const times = 5000;
|
|
@@ -38,6 +39,9 @@ test(`Connect watchtower`, async () => {
|
|
|
38
39
|
|
|
39
40
|
const [socket] = tower.sockets;
|
|
40
41
|
|
|
42
|
+
// LND 0.19.0 requires a wait before connecting
|
|
43
|
+
await delay(5000);
|
|
44
|
+
|
|
41
45
|
await connectWatchtower({lnd, socket, public_key: tower.public_key});
|
|
42
46
|
|
|
43
47
|
const [watcher] = (await getConnectedWatchtowers({lnd})).towers;
|
|
@@ -10,6 +10,7 @@ const {getTowerServerInfo} = require('./../../');
|
|
|
10
10
|
const {getWalletInfo} = require('./../../');
|
|
11
11
|
|
|
12
12
|
const conf = ['--watchtower.active', '--wtclient.active'];
|
|
13
|
+
const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
|
|
13
14
|
const interval = 50;
|
|
14
15
|
const size = 2;
|
|
15
16
|
const times = 3000;
|
|
@@ -38,6 +39,9 @@ test(`Get connected watchtowers`, async () => {
|
|
|
38
39
|
|
|
39
40
|
const [socket] = tower.sockets;
|
|
40
41
|
|
|
42
|
+
// LND 0.19.0 requires a wait before connecting
|
|
43
|
+
await delay(5000);
|
|
44
|
+
|
|
41
45
|
await connectWatchtower({lnd, socket, public_key: tower.public_key});
|
|
42
46
|
|
|
43
47
|
const res = (await getConnectedWatchtowers({lnd}));
|
|
@@ -97,9 +97,12 @@ test(`Fund PSBT`, async () => {
|
|
|
97
97
|
if (change.output_script.length === 44) {
|
|
98
98
|
equal(change.output_script.length, 44, 'Change address is returned');
|
|
99
99
|
equal(change.tokens, 4998992950, 'Got change output value');
|
|
100
|
-
} else {
|
|
100
|
+
} else if (change.tokens === 4998992350) { // LND 0.18.5 and below
|
|
101
101
|
equal(change.output_script.length, 68, 'Change address is returned');
|
|
102
102
|
equal(change.tokens, 4998992350, 'Got change output value');
|
|
103
|
+
} else {
|
|
104
|
+
equal(change.output_script.length, 68, 'Change address is returned');
|
|
105
|
+
equal(change.tokens, 4998996175, 'Got change output value');
|
|
103
106
|
}
|
|
104
107
|
|
|
105
108
|
equal(output.tokens, tokens, 'Got expected tokens output');
|
|
@@ -11,7 +11,12 @@ test(`Get chain fee rate`, async () => {
|
|
|
11
11
|
|
|
12
12
|
const feeRate = await getChainFeeRate({lnd});
|
|
13
13
|
|
|
14
|
-
|
|
14
|
+
// LND 0.18.5 and below return 50
|
|
15
|
+
if (feeRate.tokens_per_vbyte === 50) {
|
|
16
|
+
equal(feeRate.tokens_per_vbyte, 50, 'Fee rate is returned');
|
|
17
|
+
} else {
|
|
18
|
+
equal(feeRate.tokens_per_vbyte, 25, 'Fee rate is returned');
|
|
19
|
+
}
|
|
15
20
|
|
|
16
21
|
await kill({});
|
|
17
22
|
|
|
@@ -9,7 +9,6 @@ const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
|
9
9
|
|
|
10
10
|
const {closeChannel} = require('./../../');
|
|
11
11
|
const {createHodlInvoice} = require('./../../');
|
|
12
|
-
const {delay} = require('./../macros');
|
|
13
12
|
const {getChainTransactions} = require('./../../');
|
|
14
13
|
const {getClosedChannels} = require('./../../');
|
|
15
14
|
const {getInvoice} = require('./../../');
|
|
@@ -7,7 +7,6 @@ const {spawnLightningCluster} = require('ln-docker-daemons');
|
|
|
7
7
|
|
|
8
8
|
const {broadcastChainTransaction} = require('./../../');
|
|
9
9
|
const {createChainAddress} = require('./../../');
|
|
10
|
-
const {delay} = require('./../macros');
|
|
11
10
|
const {fundPsbt} = require('./../../');
|
|
12
11
|
const {getPendingSweeps} = require('./../../');
|
|
13
12
|
const {getUtxos} = require('./../../');
|
|
@@ -35,16 +35,18 @@ test(`Request chain fee increase`, async () => {
|
|
|
35
35
|
|
|
36
36
|
const bump = (await getUtxos({lnd})).utxos.find(n => n.tokens === tokens);
|
|
37
37
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
38
|
+
// // LND 0.19.0 does not support this error
|
|
39
|
+
// try {
|
|
40
|
+
// await requestChainFeeIncrease({
|
|
41
|
+
// lnd,
|
|
42
|
+
// transaction_id: bump.transaction_id,
|
|
43
|
+
// transaction_vout: bump.transaction_vout + 1,
|
|
44
|
+
// });
|
|
45
|
+
//
|
|
46
|
+
// fail('Expected chain fee increase rejected');
|
|
47
|
+
// } catch (err) {
|
|
48
|
+
// deepEqual(err, [404, 'SpecifiedOutpointNotFoundInWalletUtxos'], '404');
|
|
49
|
+
// }
|
|
48
50
|
|
|
49
51
|
await requestChainFeeIncrease({
|
|
50
52
|
lnd,
|
|
@@ -53,9 +55,9 @@ test(`Request chain fee increase`, async () => {
|
|
|
53
55
|
});
|
|
54
56
|
} catch (err) {
|
|
55
57
|
equal(err, null, 'Expected no error');
|
|
58
|
+
} finally {
|
|
59
|
+
await kill({});
|
|
56
60
|
}
|
|
57
61
|
|
|
58
|
-
await kill({});
|
|
59
|
-
|
|
60
62
|
return;
|
|
61
63
|
});
|