|
@ -236,7 +236,7 @@ class MockLNWallet(Logger, NetworkRetryManager[LNPeerAddr]): |
|
|
on_peer_successfully_established = LNWallet.on_peer_successfully_established |
|
|
on_peer_successfully_established = LNWallet.on_peer_successfully_established |
|
|
get_channel_by_id = LNWallet.get_channel_by_id |
|
|
get_channel_by_id = LNWallet.get_channel_by_id |
|
|
channels_for_peer = LNWallet.channels_for_peer |
|
|
channels_for_peer = LNWallet.channels_for_peer |
|
|
_calc_routing_hints_for_invoice = LNWallet._calc_routing_hints_for_invoice |
|
|
calc_routing_hints_for_invoice = LNWallet.calc_routing_hints_for_invoice |
|
|
handle_error_code_from_failed_htlc = LNWallet.handle_error_code_from_failed_htlc |
|
|
handle_error_code_from_failed_htlc = LNWallet.handle_error_code_from_failed_htlc |
|
|
is_trampoline_peer = LNWallet.is_trampoline_peer |
|
|
is_trampoline_peer = LNWallet.is_trampoline_peer |
|
|
wait_for_received_pending_htlcs_to_get_removed = LNWallet.wait_for_received_pending_htlcs_to_get_removed |
|
|
wait_for_received_pending_htlcs_to_get_removed = LNWallet.wait_for_received_pending_htlcs_to_get_removed |
|
@ -469,7 +469,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
return graph |
|
|
return graph |
|
|
|
|
|
|
|
|
@staticmethod |
|
|
@staticmethod |
|
|
async def prepare_invoice( |
|
|
def prepare_invoice( |
|
|
w2: MockLNWallet, # receiver |
|
|
w2: MockLNWallet, # receiver |
|
|
*, |
|
|
*, |
|
|
amount_msat=100_000_000, |
|
|
amount_msat=100_000_000, |
|
@ -482,7 +482,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
w2.save_preimage(RHASH, payment_preimage) |
|
|
w2.save_preimage(RHASH, payment_preimage) |
|
|
w2.save_payment_info(info) |
|
|
w2.save_payment_info(info) |
|
|
if include_routing_hints: |
|
|
if include_routing_hints: |
|
|
routing_hints = await w2._calc_routing_hints_for_invoice(amount_msat) |
|
|
routing_hints = w2.calc_routing_hints_for_invoice(amount_msat) |
|
|
else: |
|
|
else: |
|
|
routing_hints = [] |
|
|
routing_hints = [] |
|
|
trampoline_hints = [] |
|
|
trampoline_hints = [] |
|
@ -532,7 +532,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
alice_channel, bob_channel = create_test_channels(random_seed=random_seed) |
|
|
alice_channel, bob_channel = create_test_channels(random_seed=random_seed) |
|
|
alice_channel_0, bob_channel_0 = create_test_channels(random_seed=random_seed) # these are identical |
|
|
alice_channel_0, bob_channel_0 = create_test_channels(random_seed=random_seed) # these are identical |
|
|
p1, p2, w1, w2, _q1, _q2 = self.prepare_peers(alice_channel, bob_channel) |
|
|
p1, p2, w1, w2, _q1, _q2 = self.prepare_peers(alice_channel, bob_channel) |
|
|
lnaddr, pay_req = run(self.prepare_invoice(w2)) |
|
|
lnaddr, pay_req = self.prepare_invoice(w2) |
|
|
async def pay(): |
|
|
async def pay(): |
|
|
result, log = await w1.pay_invoice(pay_req) |
|
|
result, log = await w1.pay_invoice(pay_req) |
|
|
self.assertEqual(result, True) |
|
|
self.assertEqual(result, True) |
|
@ -575,7 +575,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(p2._message_loop()) |
|
|
await group.spawn(p2._message_loop()) |
|
|
await group.spawn(p2.htlc_switch()) |
|
|
await group.spawn(p2.htlc_switch()) |
|
|
await asyncio.sleep(0.01) |
|
|
await asyncio.sleep(0.01) |
|
|
lnaddr, pay_req = await self.prepare_invoice(w2) |
|
|
lnaddr, pay_req = self.prepare_invoice(w2) |
|
|
invoice_features = lnaddr.get_features() |
|
|
invoice_features = lnaddr.get_features() |
|
|
self.assertFalse(invoice_features.supports(LnFeatures.BASIC_MPP_OPT)) |
|
|
self.assertFalse(invoice_features.supports(LnFeatures.BASIC_MPP_OPT)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
@ -597,8 +597,8 @@ class TestPeer(TestCaseForTestnet): |
|
|
# prep |
|
|
# prep |
|
|
_maybe_send_commitment1 = p1.maybe_send_commitment |
|
|
_maybe_send_commitment1 = p1.maybe_send_commitment |
|
|
_maybe_send_commitment2 = p2.maybe_send_commitment |
|
|
_maybe_send_commitment2 = p2.maybe_send_commitment |
|
|
lnaddr2, pay_req2 = await self.prepare_invoice(w2) |
|
|
lnaddr2, pay_req2 = self.prepare_invoice(w2) |
|
|
lnaddr1, pay_req1 = await self.prepare_invoice(w1) |
|
|
lnaddr1, pay_req1 = self.prepare_invoice(w1) |
|
|
# create the htlc queues now (side-effecting defaultdict) |
|
|
# create the htlc queues now (side-effecting defaultdict) |
|
|
q1 = w1.sent_htlcs[lnaddr2.paymenthash] |
|
|
q1 = w1.sent_htlcs[lnaddr2.paymenthash] |
|
|
q2 = w2.sent_htlcs[lnaddr1.paymenthash] |
|
|
q2 = w2.sent_htlcs[lnaddr1.paymenthash] |
|
@ -670,11 +670,8 @@ class TestPeer(TestCaseForTestnet): |
|
|
await w1.pay_invoice(pay_req) |
|
|
await w1.pay_invoice(pay_req) |
|
|
async def many_payments(): |
|
|
async def many_payments(): |
|
|
async with OldTaskGroup() as group: |
|
|
async with OldTaskGroup() as group: |
|
|
pay_reqs_tasks = [await group.spawn(self.prepare_invoice(w2, amount_msat=payment_value_msat)) |
|
|
for i in range(num_payments): |
|
|
for i in range(num_payments)] |
|
|
lnaddr, pay_req = self.prepare_invoice(w2, amount_msat=payment_value_msat) |
|
|
async with OldTaskGroup() as group: |
|
|
|
|
|
for pay_req_task in pay_reqs_tasks: |
|
|
|
|
|
lnaddr, pay_req = pay_req_task.result() |
|
|
|
|
|
await group.spawn(single_payment(pay_req)) |
|
|
await group.spawn(single_payment(pay_req)) |
|
|
gath.cancel() |
|
|
gath.cancel() |
|
|
gath = asyncio.gather(many_payments(), p1._message_loop(), p2._message_loop(), p1.htlc_switch(), p2.htlc_switch()) |
|
|
gath = asyncio.gather(many_payments(), p1._message_loop(), p2._message_loop(), p1.htlc_switch(), p2.htlc_switch()) |
|
@ -703,7 +700,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await asyncio.sleep(0.2) |
|
|
await asyncio.sleep(0.2) |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
with self.assertRaises(PaymentDone): |
|
|
with self.assertRaises(PaymentDone): |
|
|
run(f()) |
|
|
run(f()) |
|
@ -747,7 +744,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await asyncio.sleep(0.2) |
|
|
await asyncio.sleep(0.2) |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
await group.spawn(pay(pay_req)) |
|
|
await group.spawn(pay(pay_req)) |
|
|
with self.assertRaises(PaymentDone): |
|
|
with self.assertRaises(PaymentDone): |
|
|
run(f()) |
|
|
run(f()) |
|
@ -771,7 +768,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await asyncio.sleep(0.2) |
|
|
await asyncio.sleep(0.2) |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
with self.assertRaises(PaymentDone): |
|
|
with self.assertRaises(PaymentDone): |
|
|
run(f()) |
|
|
run(f()) |
|
@ -806,7 +803,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await asyncio.sleep(0.2) |
|
|
await asyncio.sleep(0.2) |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
invoice_features = lnaddr.get_features() |
|
|
invoice_features = lnaddr.get_features() |
|
|
self.assertFalse(invoice_features.supports(LnFeatures.BASIC_MPP_OPT)) |
|
|
self.assertFalse(invoice_features.supports(LnFeatures.BASIC_MPP_OPT)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
@ -869,7 +866,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await asyncio.sleep(0.2) |
|
|
await asyncio.sleep(0.2) |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], amount_msat=amount_to_pay, include_routing_hints=True) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], amount_msat=amount_to_pay, include_routing_hints=True) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
with self.assertRaises(PaymentDone): |
|
|
with self.assertRaises(PaymentDone): |
|
|
run(f()) |
|
|
run(f()) |
|
@ -900,7 +897,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
graph.workers['alice'].network.channel_db = None |
|
|
graph.workers['alice'].network.channel_db = None |
|
|
else: |
|
|
else: |
|
|
assert graph.workers['alice'].network.channel_db is not None |
|
|
assert graph.workers['alice'].network.channel_db is not None |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True, amount_msat=amount_to_pay) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True, amount_msat=amount_to_pay) |
|
|
self.assertEqual(PR_UNPAID, graph.workers['dave'].get_payment_status(lnaddr.paymenthash)) |
|
|
self.assertEqual(PR_UNPAID, graph.workers['dave'].get_payment_status(lnaddr.paymenthash)) |
|
|
result, log = await graph.workers['alice'].pay_invoice(pay_req, attempts=attempts) |
|
|
result, log = await graph.workers['alice'].pay_invoice(pay_req, attempts=attempts) |
|
|
if not bob_forwarding: |
|
|
if not bob_forwarding: |
|
@ -960,7 +957,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer._message_loop()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await group.spawn(peer.htlc_switch()) |
|
|
await asyncio.sleep(0.2) |
|
|
await asyncio.sleep(0.2) |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
await group.spawn(pay(lnaddr, pay_req)) |
|
|
|
|
|
|
|
|
for is_legacy in (True, False): |
|
|
for is_legacy in (True, False): |
|
@ -1035,7 +1032,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
graph.workers['dave'].features |= LnFeatures.BASIC_MPP_OPT |
|
|
graph.workers['dave'].features |= LnFeatures.BASIC_MPP_OPT |
|
|
graph.workers['bob'].enable_htlc_forwarding = False # Bob will hold forwarded HTLCs |
|
|
graph.workers['bob'].enable_htlc_forwarding = False # Bob will hold forwarded HTLCs |
|
|
assert graph.workers['alice'].network.channel_db is not None |
|
|
assert graph.workers['alice'].network.channel_db is not None |
|
|
lnaddr, pay_req = await self.prepare_invoice(graph.workers['dave'], include_routing_hints=True, amount_msat=amount_to_pay) |
|
|
lnaddr, pay_req = self.prepare_invoice(graph.workers['dave'], include_routing_hints=True, amount_msat=amount_to_pay) |
|
|
try: |
|
|
try: |
|
|
async with timeout_after(0.5): |
|
|
async with timeout_after(0.5): |
|
|
result, log = await graph.workers['alice'].pay_invoice(pay_req, attempts=1) |
|
|
result, log = await graph.workers['alice'].pay_invoice(pay_req, attempts=1) |
|
@ -1104,7 +1101,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
else: |
|
|
else: |
|
|
w2.network.config.set_key('test_shutdown_legacy', True) |
|
|
w2.network.config.set_key('test_shutdown_legacy', True) |
|
|
w2.enable_htlc_settle = False |
|
|
w2.enable_htlc_settle = False |
|
|
lnaddr, pay_req = run(self.prepare_invoice(w2)) |
|
|
lnaddr, pay_req = self.prepare_invoice(w2) |
|
|
async def pay(): |
|
|
async def pay(): |
|
|
await asyncio.wait_for(p1.initialized, 1) |
|
|
await asyncio.wait_for(p1.initialized, 1) |
|
|
await asyncio.wait_for(p2.initialized, 1) |
|
|
await asyncio.wait_for(p2.initialized, 1) |
|
@ -1234,7 +1231,7 @@ class TestPeer(TestCaseForTestnet): |
|
|
def test_channel_usage_after_closing(self): |
|
|
def test_channel_usage_after_closing(self): |
|
|
alice_channel, bob_channel = create_test_channels() |
|
|
alice_channel, bob_channel = create_test_channels() |
|
|
p1, p2, w1, w2, q1, q2 = self.prepare_peers(alice_channel, bob_channel) |
|
|
p1, p2, w1, w2, q1, q2 = self.prepare_peers(alice_channel, bob_channel) |
|
|
lnaddr, pay_req = run(self.prepare_invoice(w2)) |
|
|
lnaddr, pay_req = self.prepare_invoice(w2) |
|
|
|
|
|
|
|
|
lnaddr = w1._check_invoice(pay_req) |
|
|
lnaddr = w1._check_invoice(pay_req) |
|
|
route, amount_msat = run(w1.create_routes_from_invoice(lnaddr.get_amount_msat(), decoded_invoice=lnaddr))[0][0:2] |
|
|
route, amount_msat = run(w1.create_routes_from_invoice(lnaddr.get_amount_msat(), decoded_invoice=lnaddr))[0][0:2] |
|
|