lightning 9.7.1 → 9.8.1
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 +4 -0
- package/grpc/protos/chainnotifier.proto +1 -1
- package/grpc/protos/invoices.proto +1 -1
- package/grpc/protos/lightning.proto +27 -12
- package/grpc/protos/walletkit.proto +3 -1
- package/grpc/protos/wtclient.proto +34 -3
- package/lnd_methods/info/constants.json +1 -0
- package/lnd_methods/offchain/get_pending_channels.d.ts +2 -0
- package/lnd_methods/offchain/get_pending_channels.js +3 -0
- package/lnd_responses/pending_as_pending_channels.js +4 -1
- package/package.json +11 -12
- package/test/arrays/test_sort_by.js +5 -3
- package/test/bolt00/test_mtokens_amount.js +5 -3
- package/test/bolt00/test_payment_amounts.js +4 -2
- package/test/bolt00/test_safe_tokens.js +5 -4
- package/test/bolt02/test_chain_id.js +3 -2
- package/test/grpc/test_emit_subscription_error.js +2 -3
- package/test/grpc/test_handle_remove_listener.js +2 -2
- package/test/lnd_gateway/test_bearer_token.js +5 -3
- package/test/lnd_gateway/test_decode_cbor_body.js +7 -4
- package/test/lnd_gateway/test_emit_event.js +6 -4
- package/test/lnd_gateway/test_emit_grpc_events.js +4 -4
- package/test/lnd_gateway/test_encode_response.js +5 -3
- package/test/lnd_gateway/test_gateway_request.js +6 -3
- package/test/lnd_gateway/test_gateway_subscribe.js +50 -45
- package/test/lnd_gateway/test_grpc_response.js +2 -2
- package/test/lnd_gateway/test_grpc_router.js +4 -3
- package/test/lnd_gateway/test_handle_errors.js +3 -2
- package/test/lnd_gateway/test_lnd_gateway.js +6 -3
- package/test/lnd_gateway/test_return_response.js +6 -3
- package/test/lnd_gateway/test_ws_url.js +3 -2
- package/test/lnd_grpc/test_authenticated_lnd_grpc.js +5 -3
- package/test/lnd_grpc/test_decode_serialized.js +3 -2
- package/test/lnd_grpc/test_grpc_credentials.js +4 -2
- package/test/lnd_grpc/test_grpc_ssl.js +3 -2
- package/test/lnd_grpc/test_is_lnd.js +3 -2
- package/test/lnd_grpc/test_unauthenticated_lnd_grpc.js +5 -3
- package/test/lnd_messages/test_close_channel_request.js +5 -3
- package/test/lnd_messages/test_open_channel_request.js +5 -3
- package/test/lnd_messages/test_pay_via_route_request.js +5 -3
- package/test/lnd_methods/address/test_create_chain_address.js +6 -4
- package/test/lnd_methods/address/test_get_public_key.js +5 -3
- package/test/lnd_methods/generic/test_get_height.js +6 -5
- package/test/lnd_methods/info/test_get_autopilot.js +3 -2
- package/test/lnd_methods/info/test_get_channel.js +6 -4
- package/test/lnd_methods/info/test_get_identity.js +6 -4
- package/test/lnd_methods/info/test_get_methods.js +6 -4
- package/test/lnd_methods/info/test_get_network_centrality.js +6 -4
- package/test/lnd_methods/info/test_get_network_graph.js +6 -4
- package/test/lnd_methods/info/test_get_network_info.js +6 -4
- package/test/lnd_methods/info/test_get_node.js +6 -4
- package/test/lnd_methods/info/test_get_route_to_destination.js +6 -4
- package/test/lnd_methods/info/test_get_tower_server_info.js +6 -4
- package/test/lnd_methods/info/test_get_wallet_info.js +6 -4
- package/test/lnd_methods/info/test_get_wallet_version.js +6 -4
- package/test/lnd_methods/info/test_stop_daemon.js +4 -3
- package/test/lnd_methods/info/test_subscribe_to_graph.js +7 -5
- package/test/lnd_methods/invoices/test_cancel_hodl_invoice.js +4 -3
- package/test/lnd_methods/invoices/test_create_hodl_invoice.js +10 -7
- package/test/lnd_methods/invoices/test_create_invoice.js +6 -4
- package/test/lnd_methods/invoices/test_get_invoice.js +4 -3
- package/test/lnd_methods/invoices/test_get_invoices.js +6 -4
- package/test/lnd_methods/invoices/test_settle_hodl_invoice.js +4 -3
- package/test/lnd_methods/invoices/test_subscribe_to_invoice.js +12 -9
- package/test/lnd_methods/invoices/test_subscribe_to_invoices.js +10 -8
- package/test/lnd_methods/macaroon/test_accept_rpc_request.js +4 -3
- package/test/lnd_methods/macaroon/test_get_access_ids.js +6 -4
- package/test/lnd_methods/macaroon/test_grant_access.js +6 -4
- package/test/lnd_methods/macaroon/test_handle_rpc_request_update.js +11 -8
- package/test/lnd_methods/macaroon/test_reject_rpc_request.js +4 -3
- package/test/lnd_methods/macaroon/test_revoke_access.js +4 -3
- package/test/lnd_methods/macaroon/test_subscribe_to_rpc_requests.js +8 -7
- package/test/lnd_methods/macaroon/test_uris_for_method.js +5 -3
- package/test/lnd_methods/macaroon/test_verify_access.js +6 -4
- package/test/lnd_methods/message/test_sign_message.js +6 -4
- package/test/lnd_methods/message/test_verify_message.js +6 -4
- package/test/lnd_methods/offchain/test_connect_watchtower.js +4 -3
- package/test/lnd_methods/offchain/test_decode_payment_request.js +6 -4
- package/test/lnd_methods/offchain/test_delete_failed_pay_attempts.js +4 -3
- package/test/lnd_methods/offchain/test_delete_failed_payments.js +4 -3
- package/test/lnd_methods/offchain/test_delete_forwarding_reputations.js +4 -3
- package/test/lnd_methods/offchain/test_delete_payment.js +4 -3
- package/test/lnd_methods/offchain/test_delete_payments.js +4 -3
- package/test/lnd_methods/offchain/test_delete_pending_channel.js +5 -3
- package/test/lnd_methods/offchain/test_disable_channel.js +4 -3
- package/test/lnd_methods/offchain/test_disconnect_watchtower.js +4 -3
- package/test/lnd_methods/offchain/test_enable_channel.js +4 -3
- package/test/lnd_methods/offchain/test_finished_payment.js +6 -4
- package/test/lnd_methods/offchain/test_get_backup.js +6 -4
- package/test/lnd_methods/offchain/test_get_backups.js +6 -4
- package/test/lnd_methods/offchain/test_get_channel_balance.js +7 -5
- package/test/lnd_methods/offchain/test_get_channels.js +23 -21
- package/test/lnd_methods/offchain/test_get_closed_channels.js +6 -4
- package/test/lnd_methods/offchain/test_get_connected_watchtowers.js +6 -4
- package/test/lnd_methods/offchain/test_get_ephemeral_channel_ids.js +6 -4
- package/test/lnd_methods/offchain/test_get_failed_payments.js +7 -5
- package/test/lnd_methods/offchain/test_get_fee_rates.js +6 -4
- package/test/lnd_methods/offchain/test_get_forwarding_confidence.js +6 -4
- package/test/lnd_methods/offchain/test_get_forwarding_reputations.js +6 -4
- package/test/lnd_methods/offchain/test_get_forwards.js +6 -4
- package/test/lnd_methods/offchain/test_get_pathfinding_settings.js +6 -4
- package/test/lnd_methods/offchain/test_get_payment.js +7 -6
- package/test/lnd_methods/offchain/test_get_payments.js +6 -4
- package/test/lnd_methods/offchain/test_get_pending_channels.js +6 -4
- package/test/lnd_methods/offchain/test_get_pending_payments.js +6 -4
- package/test/lnd_methods/offchain/test_get_route_through_hops.js +7 -5
- package/test/lnd_methods/offchain/test_get_settlement_status.js +6 -4
- package/test/lnd_methods/offchain/test_list_payments.js +6 -4
- package/test/lnd_methods/offchain/test_pay.js +20 -17
- package/test/lnd_methods/offchain/test_pay_via_payment_details.js +7 -6
- package/test/lnd_methods/offchain/test_pay_via_payment_request.js +7 -6
- package/test/lnd_methods/offchain/test_pay_via_routes.js +22 -18
- package/test/lnd_methods/offchain/test_recover_funds_from_channel.js +7 -5
- package/test/lnd_methods/offchain/test_recover_funds_from_channels.js +6 -4
- package/test/lnd_methods/offchain/test_route_failure_keys.js +4 -3
- package/test/lnd_methods/offchain/test_send_message_to_peer.js +4 -3
- package/test/lnd_methods/offchain/test_subscribe_to_backups.js +8 -7
- package/test/lnd_methods/offchain/test_subscribe_to_channels.js +8 -7
- package/test/lnd_methods/offchain/test_subscribe_to_forwards.js +7 -6
- package/test/lnd_methods/offchain/test_subscribe_to_open_requests.js +8 -7
- package/test/lnd_methods/offchain/test_subscribe_to_past_payment.js +3 -2
- package/test/lnd_methods/offchain/test_subscribe_to_past_payments.js +7 -6
- package/test/lnd_methods/offchain/test_subscribe_to_pay.js +3 -4
- package/test/lnd_methods/offchain/test_subscribe_to_pay_via_routes.js +11 -9
- package/test/lnd_methods/offchain/test_subscribe_to_payments.js +8 -7
- package/test/lnd_methods/offchain/test_subscribe_to_peer_messages.js +8 -7
- package/test/lnd_methods/offchain/test_subscribe_to_probe_for_route.js +9 -6
- package/test/lnd_methods/offchain/test_update_connected_watchtower.js +4 -3
- package/test/lnd_methods/offchain/test_update_pathfinding_settings.js +6 -4
- package/test/lnd_methods/offchain/test_update_routing_fees.js +4 -3
- package/test/lnd_methods/offchain/test_verify_backup.js +6 -4
- package/test/lnd_methods/offchain/test_verify_backups.js +6 -4
- package/test/lnd_methods/onchain/test_broadcast_chain_transaction.js +8 -5
- package/test/lnd_methods/onchain/test_cancel_pending_channel.js +5 -4
- package/test/lnd_methods/onchain/test_close_channel.js +7 -6
- package/test/lnd_methods/onchain/test_fund_pending_channels.js +4 -3
- package/test/lnd_methods/onchain/test_fund_psbt.js +6 -4
- package/test/lnd_methods/onchain/test_get_block.js +6 -4
- package/test/lnd_methods/onchain/test_get_chain_addresses.js +6 -4
- package/test/lnd_methods/onchain/test_get_chain_balance.js +7 -5
- package/test/lnd_methods/onchain/test_get_chain_fee_estimate.js +6 -4
- package/test/lnd_methods/onchain/test_get_chain_fee_rate.js +6 -4
- package/test/lnd_methods/onchain/test_get_chain_transactions.js +6 -4
- package/test/lnd_methods/onchain/test_get_locked_utxos.js +6 -4
- package/test/lnd_methods/onchain/test_get_master_public_keys.js +6 -4
- package/test/lnd_methods/onchain/test_get_pending_chain_balance.js +6 -4
- package/test/lnd_methods/onchain/test_get_sweep_transactions.js +7 -4
- package/test/lnd_methods/onchain/test_get_utxos.js +6 -4
- package/test/lnd_methods/onchain/test_lock_utxo.js +6 -4
- package/test/lnd_methods/onchain/test_open_channel.js +7 -6
- package/test/lnd_methods/onchain/test_open_channels.js +9 -8
- package/test/lnd_methods/onchain/test_partially_sign_psbt.js +7 -5
- package/test/lnd_methods/onchain/test_prepare_for_channel_proposal.js +6 -4
- package/test/lnd_methods/onchain/test_propose_channel.js +7 -6
- package/test/lnd_methods/onchain/test_request_chain_fee_increase.js +4 -3
- package/test/lnd_methods/onchain/test_script_from_chain_address.js +4 -3
- package/test/lnd_methods/onchain/test_send_to_chain_address.js +6 -4
- package/test/lnd_methods/onchain/test_send_to_chain_addresses.js +6 -4
- package/test/lnd_methods/onchain/test_send_to_chain_output_scripts.js +7 -4
- package/test/lnd_methods/onchain/test_set_autopilot.js +5 -4
- package/test/lnd_methods/onchain/test_sign_chain_address_message.js +6 -4
- package/test/lnd_methods/onchain/test_sign_psbt.js +6 -4
- package/test/lnd_methods/onchain/test_subscribe_to_blocks.js +9 -8
- package/test/lnd_methods/onchain/test_subscribe_to_chain_address.js +8 -6
- package/test/lnd_methods/onchain/test_subscribe_to_chain_spend.js +8 -6
- package/test/lnd_methods/onchain/test_subscribe_to_transactions.js +8 -7
- package/test/lnd_methods/onchain/test_unlock_utxo.js +4 -3
- package/test/lnd_methods/onchain/test_update_chain_transaction.js +4 -3
- package/test/lnd_methods/onchain/test_verify_chain_address_message.js +6 -4
- package/test/lnd_methods/peers/test_add_external_socket.js +4 -3
- package/test/lnd_methods/peers/test_add_peer.js +4 -3
- package/test/lnd_methods/peers/test_get_peers.js +6 -4
- package/test/lnd_methods/peers/test_remove_external_socket.js +4 -3
- package/test/lnd_methods/peers/test_remove_peer.js +6 -4
- package/test/lnd_methods/peers/test_subscribe_to_peers.js +9 -8
- package/test/lnd_methods/peers/test_update_alias.js +4 -3
- package/test/lnd_methods/peers/test_update_color.js +4 -3
- package/test/lnd_methods/signer/test_begin_group_signing_session.js +6 -4
- package/test/lnd_methods/signer/test_diffie_hellman_compute_secret.js +6 -4
- package/test/lnd_methods/signer/test_end_group_signing_session.js +6 -4
- package/test/lnd_methods/signer/test_input_signing_method.js +4 -3
- package/test/lnd_methods/signer/test_sign_bytes.js +6 -4
- package/test/lnd_methods/signer/test_sign_transaction.js +6 -4
- package/test/lnd_methods/signer/test_update_group_signing_session.js +7 -5
- package/test/lnd_methods/signer/test_verify_bytes_signature.js +6 -4
- package/test/lnd_methods/unauthenticated/test_change_password.js +4 -3
- package/test/lnd_methods/unauthenticated/test_create_seed.js +6 -4
- package/test/lnd_methods/unauthenticated/test_create_wallet.js +4 -3
- package/test/lnd_methods/unauthenticated/test_get_wallet_status.js +6 -4
- package/test/lnd_methods/unauthenticated/test_subscribe_to_wallet_status.js +7 -6
- package/test/lnd_methods/unauthenticated/test_unlock_wallet.js +4 -3
- package/test/lnd_requests/test_destination_custom_records.js +4 -3
- package/test/lnd_requests/test_ignore_as_ignored_nodes.js +7 -4
- package/test/lnd_requests/test_ignore_as_ignored_pairs.js +7 -4
- package/test/lnd_requests/test_route_hint_from_route.js +5 -3
- package/test/lnd_requests/test_rpc_hop_from_hop.js +5 -3
- package/test/lnd_requests/test_rpc_route_from_route.js +5 -3
- package/test/lnd_responses/test_backups_from_snapshot.js +5 -3
- package/test/lnd_responses/test_channel_accept_as_open_request.js +5 -3
- package/test/lnd_responses/test_channel_edge_as_channel.js +5 -3
- package/test/lnd_responses/test_channel_policy_as_policy.js +5 -3
- package/test/lnd_responses/test_confirmed_from_payment.js +5 -3
- package/test/lnd_responses/test_confirmed_from_payment_status.js +5 -3
- package/test/lnd_responses/test_failure_from_payment.js +5 -3
- package/test/lnd_responses/test_forward_from_htlc_event.js +5 -3
- package/test/lnd_responses/test_htlc_as_payment.js +5 -3
- package/test/lnd_responses/test_info_as_wallet_info.js +5 -3
- package/test/lnd_responses/test_node_info_as_node.js +5 -3
- package/test/lnd_responses/test_payment_failure.js +5 -3
- package/test/lnd_responses/test_payment_request_details.js +5 -3
- package/test/lnd_responses/test_pending_as_pending_channels.js +6 -3
- package/test/lnd_responses/test_pending_from_payment.js +5 -3
- package/test/lnd_responses/test_policy_from_channel_update.js +5 -3
- package/test/lnd_responses/test_route_from_route_hint.js +5 -3
- package/test/lnd_responses/test_routes_from_query_routes.js +6 -5
- package/test/lnd_responses/test_routing_failure_from_htlc.js +5 -3
- package/test/lnd_responses/test_rpc_addresses_as_addresses.js +5 -3
- package/test/lnd_responses/test_rpc_attempt_htlc_as_attempt.js +5 -3
- package/test/lnd_responses/test_rpc_channel_as_channel.js +5 -3
- package/test/lnd_responses/test_rpc_channel_closed_as_closed.js +6 -4
- package/test/lnd_responses/test_rpc_channel_update_as_update.js +6 -4
- package/test/lnd_responses/test_rpc_closed_channel_as_closed.js +5 -3
- package/test/lnd_responses/test_rpc_conf_as_confirmation.js +5 -3
- package/test/lnd_responses/test_rpc_failed_policy_as_fail.js +5 -3
- package/test/lnd_responses/test_rpc_fees_as_channel_fees.js +5 -3
- package/test/lnd_responses/test_rpc_forward_as_forward.js +5 -3
- package/test/lnd_responses/test_rpc_forward_as_forward_request.js +5 -3
- package/test/lnd_responses/test_rpc_group_session_as_session.js +5 -3
- package/test/lnd_responses/test_rpc_hop_as_hop.js +5 -3
- package/test/lnd_responses/test_rpc_htlc_as_payment.js +5 -3
- package/test/lnd_responses/test_rpc_invoice_as_invoice.js +5 -3
- package/test/lnd_responses/test_rpc_network_as_network_info.js +5 -3
- package/test/lnd_responses/test_rpc_node_as_node.js +5 -3
- package/test/lnd_responses/test_rpc_outpoint_as_update.js +5 -3
- package/test/lnd_responses/test_rpc_payment_as_payment.js +5 -3
- package/test/lnd_responses/test_rpc_peer_as_peer.js +5 -3
- package/test/lnd_responses/test_rpc_peer_message_as_message.js +5 -3
- package/test/lnd_responses/test_rpc_request_update_as_event.js +5 -3
- package/test/lnd_responses/test_rpc_resolution_as_resolution.js +5 -3
- package/test/lnd_responses/test_rpc_route_as_route.js +11 -9
- package/test/lnd_responses/test_rpc_tx_as_transaction.js +5 -3
- package/test/lnd_responses/test_rpc_utxo_as_utxo.js +5 -3
- package/test/lnd_responses/test_rpc_wallet_state_as_state.js +6 -4
- package/test/protos/protos.json +0 -22
- package/test/protos/test_protos_synced.js +0 -46
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
const EventEmitter = require('events');
|
|
2
2
|
const {promisify} = require('util');
|
|
3
|
-
|
|
4
|
-
const {
|
|
3
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
4
|
+
const {rejects} = require('node:assert').strict;
|
|
5
|
+
const test = require('node:test');
|
|
5
6
|
|
|
6
7
|
const nextTick = promisify(process.nextTick);
|
|
7
8
|
const {subscribeToRpcRequests} = require('./../../../lnd_methods');
|
|
@@ -212,7 +213,7 @@ const tests = [
|
|
|
212
213
|
];
|
|
213
214
|
|
|
214
215
|
tests.forEach(({args, description, error, expected}) => {
|
|
215
|
-
return test(description, async (
|
|
216
|
+
return test(description, async () => {
|
|
216
217
|
if (!!error) {
|
|
217
218
|
await rejects(() => subscribeToRpcRequests(args), error, 'Got err');
|
|
218
219
|
} else {
|
|
@@ -237,13 +238,13 @@ tests.forEach(({args, description, error, expected}) => {
|
|
|
237
238
|
await nextTick();
|
|
238
239
|
|
|
239
240
|
if (!!expected.intercepts) {
|
|
240
|
-
|
|
241
|
+
deepStrictEqual(intercepts, expected.intercepts, 'Got intercepts');
|
|
241
242
|
}
|
|
242
243
|
|
|
243
|
-
|
|
244
|
-
|
|
244
|
+
deepStrictEqual(events, expected.events, 'Got expected events');
|
|
245
|
+
deepStrictEqual(!!res.subscription, true, 'Got subscription');
|
|
245
246
|
}
|
|
246
247
|
|
|
247
|
-
return
|
|
248
|
+
return;
|
|
248
249
|
});
|
|
249
250
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
3
|
+
const {throws} = require('node:assert').strict;
|
|
2
4
|
|
|
3
5
|
const method = require('./../../../lnd_methods/macaroon/uris_for_method');
|
|
4
6
|
const methods = require('./../../../lnd_methods/macaroon/methods');
|
|
@@ -27,13 +29,13 @@ const tests = [
|
|
|
27
29
|
];
|
|
28
30
|
|
|
29
31
|
tests.forEach(({args, description, error, expected}) => {
|
|
30
|
-
return test(description,
|
|
32
|
+
return test(description, (t, end) => {
|
|
31
33
|
if (!!error) {
|
|
32
34
|
throws(() => method(args), new Error(error), 'Got expected error');
|
|
33
35
|
} else {
|
|
34
36
|
const res = method(args);
|
|
35
37
|
|
|
36
|
-
|
|
38
|
+
deepStrictEqual(res, expected, 'Got expected result');
|
|
37
39
|
}
|
|
38
40
|
|
|
39
41
|
// Run through all the methods to make sure they can be derived
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {verifyAccess} = require('./../../../lnd_methods');
|
|
4
6
|
|
|
@@ -87,15 +89,15 @@ const tests = [
|
|
|
87
89
|
];
|
|
88
90
|
|
|
89
91
|
tests.forEach(({args, description, error, expected}) => {
|
|
90
|
-
return test(description, async (
|
|
92
|
+
return test(description, async () => {
|
|
91
93
|
if (!!error) {
|
|
92
94
|
await rejects(() => verifyAccess(args), error, 'Got expected error');
|
|
93
95
|
} else {
|
|
94
96
|
const res = await verifyAccess(args);
|
|
95
97
|
|
|
96
|
-
|
|
98
|
+
deepStrictEqual(res, expected, 'Got expected result');
|
|
97
99
|
}
|
|
98
100
|
|
|
99
|
-
return
|
|
101
|
+
return;
|
|
100
102
|
});
|
|
101
103
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {signMessage} = require('./../../../');
|
|
4
6
|
|
|
@@ -48,13 +50,13 @@ const tests = [
|
|
|
48
50
|
];
|
|
49
51
|
|
|
50
52
|
tests.forEach(({args, description, error, expected}) => {
|
|
51
|
-
return test(description, async (
|
|
53
|
+
return test(description, async () => {
|
|
52
54
|
if (!!error) {
|
|
53
55
|
await rejects(() => signMessage(args), error, 'Got expected error');
|
|
54
56
|
} else {
|
|
55
|
-
|
|
57
|
+
deepStrictEqual(await signMessage(args), expected, 'Got result');
|
|
56
58
|
}
|
|
57
59
|
|
|
58
|
-
return
|
|
60
|
+
return;
|
|
59
61
|
});
|
|
60
62
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {verifyMessage} = require('./../../../');
|
|
4
6
|
|
|
@@ -60,13 +62,13 @@ const tests = [
|
|
|
60
62
|
];
|
|
61
63
|
|
|
62
64
|
tests.forEach(({args, description, error, expected}) => {
|
|
63
|
-
return test(description, async (
|
|
65
|
+
return test(description, async () => {
|
|
64
66
|
if (!!error) {
|
|
65
67
|
await rejects(() => verifyMessage(args), error, 'Got expected error');
|
|
66
68
|
} else {
|
|
67
|
-
|
|
69
|
+
deepStrictEqual(await verifyMessage(args), expected, 'Got result');
|
|
68
70
|
}
|
|
69
71
|
|
|
70
|
-
return
|
|
72
|
+
return;
|
|
71
73
|
});
|
|
72
74
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {connectWatchtower} = require('./../../../');
|
|
4
5
|
|
|
@@ -55,13 +56,13 @@ const tests = [
|
|
|
55
56
|
];
|
|
56
57
|
|
|
57
58
|
tests.forEach(({args, description, error, expected}) => {
|
|
58
|
-
return test(description, async (
|
|
59
|
+
return test(description, async () => {
|
|
59
60
|
if (!!error) {
|
|
60
61
|
await rejects(connectWatchtower(args), error, 'Got expected error');
|
|
61
62
|
} else {
|
|
62
63
|
await connectWatchtower(args);
|
|
63
64
|
}
|
|
64
65
|
|
|
65
|
-
return
|
|
66
|
+
return;
|
|
66
67
|
});
|
|
67
68
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {decodePaymentRequest} = require('./../../../');
|
|
4
6
|
|
|
@@ -79,15 +81,15 @@ const tests = [
|
|
|
79
81
|
];
|
|
80
82
|
|
|
81
83
|
tests.forEach(({args, description, error, expected}) => {
|
|
82
|
-
return test(description, async (
|
|
84
|
+
return test(description, async () => {
|
|
83
85
|
if (!!error) {
|
|
84
86
|
await rejects(decodePaymentRequest(args), error, 'Got expected error');
|
|
85
87
|
} else {
|
|
86
88
|
const details = await decodePaymentRequest(args);
|
|
87
89
|
|
|
88
|
-
|
|
90
|
+
deepStrictEqual(details, expected, 'Got expected details');
|
|
89
91
|
}
|
|
90
92
|
|
|
91
|
-
return
|
|
93
|
+
return;
|
|
92
94
|
});
|
|
93
95
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {deleteFailedPayAttempts} = require('./../../../lnd_methods');
|
|
4
5
|
|
|
@@ -38,13 +39,13 @@ const tests = [
|
|
|
38
39
|
];
|
|
39
40
|
|
|
40
41
|
tests.forEach(({args, description, error, expected}) => {
|
|
41
|
-
return test(description, async (
|
|
42
|
+
return test(description, async () => {
|
|
42
43
|
if (!!error) {
|
|
43
44
|
await rejects(deleteFailedPayAttempts(args), error, 'Got expected err');
|
|
44
45
|
} else {
|
|
45
46
|
await deleteFailedPayAttempts(args);
|
|
46
47
|
}
|
|
47
48
|
|
|
48
|
-
return
|
|
49
|
+
return;
|
|
49
50
|
});
|
|
50
51
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {deleteFailedPayments} = require('./../../../lnd_methods');
|
|
4
5
|
|
|
@@ -20,13 +21,13 @@ const tests = [
|
|
|
20
21
|
];
|
|
21
22
|
|
|
22
23
|
tests.forEach(({args, description, error, expected}) => {
|
|
23
|
-
return test(description, async (
|
|
24
|
+
return test(description, async () => {
|
|
24
25
|
if (!!error) {
|
|
25
26
|
await rejects(deleteFailedPayments(args), error, 'Got expected err');
|
|
26
27
|
} else {
|
|
27
28
|
await deleteFailedPayments(args);
|
|
28
29
|
}
|
|
29
30
|
|
|
30
|
-
return
|
|
31
|
+
return;
|
|
31
32
|
});
|
|
32
33
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {deleteForwardingReputations} = require('./../../../');
|
|
4
5
|
|
|
@@ -20,13 +21,13 @@ const tests = [
|
|
|
20
21
|
];
|
|
21
22
|
|
|
22
23
|
tests.forEach(({args, description, error, expected}) => {
|
|
23
|
-
return test(description, async (
|
|
24
|
+
return test(description, async () => {
|
|
24
25
|
if (!!error) {
|
|
25
26
|
await rejects(deleteForwardingReputations(args), error, 'Got error');
|
|
26
27
|
} else {
|
|
27
28
|
await deleteForwardingReputations(args);
|
|
28
29
|
}
|
|
29
30
|
|
|
30
|
-
return
|
|
31
|
+
return;
|
|
31
32
|
});
|
|
32
33
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {deletePayment} = require('./../../../lnd_methods');
|
|
4
5
|
|
|
@@ -39,13 +40,13 @@ const tests = [
|
|
|
39
40
|
];
|
|
40
41
|
|
|
41
42
|
tests.forEach(({args, description, error, expected}) => {
|
|
42
|
-
return test(description, async (
|
|
43
|
+
return test(description, async () => {
|
|
43
44
|
if (!!error) {
|
|
44
45
|
await rejects(deletePayment(args), error, 'Got expected error');
|
|
45
46
|
} else {
|
|
46
47
|
await deletePayment(args);
|
|
47
48
|
}
|
|
48
49
|
|
|
49
|
-
return
|
|
50
|
+
return;
|
|
50
51
|
});
|
|
51
52
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {deletePayments} = require('./../../../');
|
|
4
5
|
|
|
@@ -20,13 +21,13 @@ const tests = [
|
|
|
20
21
|
];
|
|
21
22
|
|
|
22
23
|
tests.forEach(({args, description, error, expected}) => {
|
|
23
|
-
return test(description, async (
|
|
24
|
+
return test(description, async () => {
|
|
24
25
|
if (!!error) {
|
|
25
26
|
await rejects(deletePayments(args), error, 'Got expected error');
|
|
26
27
|
} else {
|
|
27
28
|
await deletePayments(args);
|
|
28
29
|
}
|
|
29
30
|
|
|
30
|
-
return
|
|
31
|
+
return;
|
|
31
32
|
});
|
|
32
33
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
3
|
+
|
|
2
4
|
const {Transaction} = require('bitcoinjs-lib');
|
|
3
5
|
|
|
4
6
|
const {deletePendingChannel} = require('./../../../lnd_methods');
|
|
@@ -86,13 +88,13 @@ const tests = [
|
|
|
86
88
|
];
|
|
87
89
|
|
|
88
90
|
tests.forEach(({args, description, error, expected}) => {
|
|
89
|
-
return test(description, async (
|
|
91
|
+
return test(description, async () => {
|
|
90
92
|
if (!!error) {
|
|
91
93
|
await rejects(() => deletePendingChannel(args), error, 'Got error');
|
|
92
94
|
} else {
|
|
93
95
|
await deletePendingChannel(args);
|
|
94
96
|
}
|
|
95
97
|
|
|
96
|
-
return
|
|
98
|
+
return;
|
|
97
99
|
});
|
|
98
100
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {disableChannel} = require('./../../../lnd_methods');
|
|
4
5
|
|
|
@@ -53,13 +54,13 @@ const tests = [
|
|
|
53
54
|
];
|
|
54
55
|
|
|
55
56
|
tests.forEach(({args, description, error, expected}) => {
|
|
56
|
-
return test(description, async (
|
|
57
|
+
return test(description, async () => {
|
|
57
58
|
if (!!error) {
|
|
58
59
|
await rejects(disableChannel(args), error, 'Got expected error');
|
|
59
60
|
} else {
|
|
60
61
|
await disableChannel(args);
|
|
61
62
|
}
|
|
62
63
|
|
|
63
|
-
return
|
|
64
|
+
return;
|
|
64
65
|
});
|
|
65
66
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {disconnectWatchtower} = require('./../../../lnd_methods');
|
|
4
5
|
|
|
@@ -53,13 +54,13 @@ const tests = [
|
|
|
53
54
|
];
|
|
54
55
|
|
|
55
56
|
tests.forEach(({args, description, error, expected}) => {
|
|
56
|
-
return test(description, async (
|
|
57
|
+
return test(description, async () => {
|
|
57
58
|
if (!!error) {
|
|
58
59
|
await rejects(disconnectWatchtower(args), error, 'Got expected error');
|
|
59
60
|
} else {
|
|
60
61
|
await disconnectWatchtower(args);
|
|
61
62
|
}
|
|
62
63
|
|
|
63
|
-
return
|
|
64
|
+
return;
|
|
64
65
|
});
|
|
65
66
|
});
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {rejects} = require('node:assert').strict;
|
|
2
|
+
const test = require('node:test');
|
|
2
3
|
|
|
3
4
|
const {enableChannel} = require('./../../../lnd_methods');
|
|
4
5
|
|
|
@@ -71,13 +72,13 @@ const tests = [
|
|
|
71
72
|
];
|
|
72
73
|
|
|
73
74
|
tests.forEach(({args, description, error, expected}) => {
|
|
74
|
-
return test(description, async (
|
|
75
|
+
return test(description, async () => {
|
|
75
76
|
if (!!error) {
|
|
76
77
|
await rejects(enableChannel(args), error, 'Got expected error');
|
|
77
78
|
} else {
|
|
78
79
|
await enableChannel(args);
|
|
79
80
|
}
|
|
80
81
|
|
|
81
|
-
return
|
|
82
|
+
return;
|
|
82
83
|
});
|
|
83
84
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const method = require('./../../../lnd_methods/offchain/finished_payment');
|
|
4
6
|
|
|
@@ -129,13 +131,13 @@ const tests = [
|
|
|
129
131
|
];
|
|
130
132
|
|
|
131
133
|
tests.forEach(({args, description, error, expected}) => {
|
|
132
|
-
return test(description, async (
|
|
134
|
+
return test(description, async () => {
|
|
133
135
|
if (!!error) {
|
|
134
136
|
await rejects(method(args), error, 'Got expected error');
|
|
135
137
|
} else {
|
|
136
|
-
|
|
138
|
+
deepStrictEqual(await method(args), expected, 'Got expected result');
|
|
137
139
|
}
|
|
138
140
|
|
|
139
|
-
return
|
|
141
|
+
return;
|
|
140
142
|
});
|
|
141
143
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {getBackup} = require('./../../../');
|
|
4
6
|
|
|
@@ -66,15 +68,15 @@ const tests = [
|
|
|
66
68
|
];
|
|
67
69
|
|
|
68
70
|
tests.forEach(({args, description, error, expected}) => {
|
|
69
|
-
return test(description, async (
|
|
71
|
+
return test(description, async () => {
|
|
70
72
|
if (!!error) {
|
|
71
73
|
await rejects(getBackup(args), error, 'Got expected error');
|
|
72
74
|
} else {
|
|
73
75
|
const {backup} = await getBackup(args);
|
|
74
76
|
|
|
75
|
-
|
|
77
|
+
deepStrictEqual(backup, expected.backup, 'Got expected backup');
|
|
76
78
|
}
|
|
77
79
|
|
|
78
|
-
return
|
|
80
|
+
return;
|
|
79
81
|
});
|
|
80
82
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {getBackups} = require('./../../../');
|
|
4
6
|
|
|
@@ -58,15 +60,15 @@ const tests = [
|
|
|
58
60
|
];
|
|
59
61
|
|
|
60
62
|
tests.forEach(({args, description, error, expected}) => {
|
|
61
|
-
return test(description, async (
|
|
63
|
+
return test(description, async () => {
|
|
62
64
|
if (!!error) {
|
|
63
65
|
await rejects(getBackups(args), error, 'Got expected error');
|
|
64
66
|
} else {
|
|
65
67
|
const details = await getBackups(args);
|
|
66
68
|
|
|
67
|
-
|
|
69
|
+
deepStrictEqual(details, expected, 'Got expected details');
|
|
68
70
|
}
|
|
69
71
|
|
|
70
|
-
return
|
|
72
|
+
return;
|
|
71
73
|
});
|
|
72
74
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {getChannelBalance} = require('./../../../');
|
|
4
6
|
|
|
@@ -152,15 +154,15 @@ const tests = [
|
|
|
152
154
|
];
|
|
153
155
|
|
|
154
156
|
tests.forEach(({args, description, error, expected}) => {
|
|
155
|
-
return test(description, async (
|
|
157
|
+
return test(description, async () => {
|
|
156
158
|
if (!!error) {
|
|
157
|
-
rejects(() => getChannelBalance(args), error, 'Got
|
|
159
|
+
await rejects(() => getChannelBalance(args), error, 'Got error');
|
|
158
160
|
} else {
|
|
159
161
|
const balances = await getChannelBalance(args);
|
|
160
162
|
|
|
161
|
-
|
|
163
|
+
deepStrictEqual(balances, expected, 'Got channel balances');
|
|
162
164
|
}
|
|
163
165
|
|
|
164
|
-
return
|
|
166
|
+
return;
|
|
165
167
|
});
|
|
166
168
|
});
|
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
const {
|
|
1
|
+
const {deepStrictEqual} = require('node:assert').strict;
|
|
2
|
+
const {rejects} = require('node:assert').strict;
|
|
3
|
+
const test = require('node:test');
|
|
2
4
|
|
|
3
5
|
const {getChannels} = require('./../../../');
|
|
4
6
|
|
|
@@ -149,12 +151,12 @@ const tests = [
|
|
|
149
151
|
{
|
|
150
152
|
args: {lnd: makeLnd({active: undefined})},
|
|
151
153
|
description: 'An active state is expected',
|
|
152
|
-
error: [503, '
|
|
154
|
+
error: [503, 'ExpectedChannelActiveStateInChannelMessage'],
|
|
153
155
|
},
|
|
154
156
|
{
|
|
155
157
|
args: {lnd: makeLnd({capacity: undefined})},
|
|
156
158
|
description: 'Channel capacity is expected',
|
|
157
|
-
error: [503, '
|
|
159
|
+
error: [503, 'ExpectedChannelCapacityInChannelMessage'],
|
|
158
160
|
},
|
|
159
161
|
{
|
|
160
162
|
args: {lnd: makeLnd({chan_id: undefined})},
|
|
@@ -164,17 +166,17 @@ const tests = [
|
|
|
164
166
|
{
|
|
165
167
|
args: {lnd: makeLnd({channel_point: ''})},
|
|
166
168
|
description: 'Channel funding outpoint is expected',
|
|
167
|
-
error: [503, '
|
|
169
|
+
error: [503, 'ExpectedChannelPointInChannelMessage'],
|
|
168
170
|
},
|
|
169
171
|
{
|
|
170
172
|
args: {lnd: makeLnd({commit_fee: undefined})},
|
|
171
173
|
description: 'Channel commit fee is expected',
|
|
172
|
-
error: [503, '
|
|
174
|
+
error: [503, 'ExpectedCommitFeeInChannelMessage'],
|
|
173
175
|
},
|
|
174
176
|
{
|
|
175
177
|
args: {lnd: makeLnd({commit_weight: undefined})},
|
|
176
178
|
description: 'Channel commit weight is expected',
|
|
177
|
-
error: [503, '
|
|
179
|
+
error: [503, 'ExpectedCommitWeightInChannelMessage'],
|
|
178
180
|
},
|
|
179
181
|
{
|
|
180
182
|
args: {lnd: makeLnd({commitment_type: undefined})},
|
|
@@ -184,62 +186,62 @@ const tests = [
|
|
|
184
186
|
{
|
|
185
187
|
args: {lnd: makeLnd({fee_per_kw: undefined})},
|
|
186
188
|
description: 'Channel fee per kw is expected',
|
|
187
|
-
error: [503, '
|
|
189
|
+
error: [503, 'ExpectedFeePerKwInChannelMessage'],
|
|
188
190
|
},
|
|
189
191
|
{
|
|
190
192
|
args: {lnd: makeLnd({local_balance: undefined})},
|
|
191
193
|
description: 'Local balance is expected',
|
|
192
|
-
error: [503, '
|
|
194
|
+
error: [503, 'ExpectedLocalBalanceInChannelMessage'],
|
|
193
195
|
},
|
|
194
196
|
{
|
|
195
197
|
args: {lnd: makeLnd({local_chan_reserve_sat: undefined})},
|
|
196
198
|
description: 'Local chan reserve is expected',
|
|
197
|
-
error: [503, '
|
|
199
|
+
error: [503, 'ExpectedLocalChannelReserveAmountInChannelMessage'],
|
|
198
200
|
},
|
|
199
201
|
{
|
|
200
202
|
args: {lnd: makeLnd({num_updates: undefined})},
|
|
201
203
|
description: 'Number of updates is expected',
|
|
202
|
-
error: [503, '
|
|
204
|
+
error: [503, 'ExpectedNumUpdatesInChannelMessage'],
|
|
203
205
|
},
|
|
204
206
|
{
|
|
205
207
|
args: {lnd: makeLnd({pending_htlcs: undefined})},
|
|
206
208
|
description: 'Pending HTLCs is expected',
|
|
207
|
-
error: [503, '
|
|
209
|
+
error: [503, 'ExpectedChannelPendingHtlcsInChannelMessage'],
|
|
208
210
|
},
|
|
209
211
|
{
|
|
210
212
|
args: {lnd: makeLnd({private: undefined})},
|
|
211
213
|
description: 'Private status is expected',
|
|
212
|
-
error: [503, '
|
|
214
|
+
error: [503, 'ExpectedChannelPrivateStatusInChannelMessage'],
|
|
213
215
|
},
|
|
214
216
|
{
|
|
215
217
|
args: {lnd: makeLnd({remote_balance: undefined})},
|
|
216
218
|
description: 'Remote balance is expected',
|
|
217
|
-
error: [503, '
|
|
219
|
+
error: [503, 'ExpectedRemoteBalanceInChannelMessage'],
|
|
218
220
|
},
|
|
219
221
|
{
|
|
220
222
|
args: {lnd: makeLnd({remote_chan_reserve_sat: undefined})},
|
|
221
223
|
description: 'Remote channel reserve amount is expected',
|
|
222
|
-
error: [503, '
|
|
224
|
+
error: [503, 'ExpectedRemoteChannelReserveAmountInChannelMessage'],
|
|
223
225
|
},
|
|
224
226
|
{
|
|
225
227
|
args: {lnd: makeLnd({remote_pubkey: undefined})},
|
|
226
228
|
description: 'Remote public key is expected',
|
|
227
|
-
error: [503, '
|
|
229
|
+
error: [503, 'ExpectedRemotePubkeyInChannelMessage'],
|
|
228
230
|
},
|
|
229
231
|
{
|
|
230
232
|
args: {lnd: makeLnd({total_satoshis_received: undefined})},
|
|
231
233
|
description: 'Total satoshis received is expected',
|
|
232
|
-
error: [503, '
|
|
234
|
+
error: [503, 'ExpectedTotalSatoshisReceivedInChannelMessage'],
|
|
233
235
|
},
|
|
234
236
|
{
|
|
235
237
|
args: {lnd: makeLnd({total_satoshis_sent: undefined})},
|
|
236
238
|
description: 'Total satoshis sent is expected',
|
|
237
|
-
error: [503, '
|
|
239
|
+
error: [503, 'ExpectedTotalSatoshisSentInChannelMessage'],
|
|
238
240
|
},
|
|
239
241
|
{
|
|
240
242
|
args: {lnd: makeLnd({unsettled_balance: undefined})},
|
|
241
243
|
description: 'Unsettled balance is expected',
|
|
242
|
-
error: [503, '
|
|
244
|
+
error: [503, 'ExpectedUnsettledBalanceInChannelMessage'],
|
|
243
245
|
},
|
|
244
246
|
{
|
|
245
247
|
args: {lnd: makeLnd({})},
|
|
@@ -288,7 +290,7 @@ const tests = [
|
|
|
288
290
|
];
|
|
289
291
|
|
|
290
292
|
tests.forEach(({args, description, error, expected}) => {
|
|
291
|
-
return test(description, async (
|
|
293
|
+
return test(description, async () => {
|
|
292
294
|
if (!!error) {
|
|
293
295
|
await rejects(() => getChannels(args), error, 'Got expected error');
|
|
294
296
|
} else {
|
|
@@ -296,9 +298,9 @@ tests.forEach(({args, description, error, expected}) => {
|
|
|
296
298
|
|
|
297
299
|
const [channel] = channels;
|
|
298
300
|
|
|
299
|
-
|
|
301
|
+
deepStrictEqual(channel, expected.channel, 'Got expected channel');
|
|
300
302
|
}
|
|
301
303
|
|
|
302
|
-
return
|
|
304
|
+
return;
|
|
303
305
|
});
|
|
304
306
|
});
|