|
@ -178,7 +178,7 @@ class MockLNWallet(Logger, NetworkRetryManager[LNPeerAddr]): |
|
|
create_routes_from_invoice = LNWallet.create_routes_from_invoice |
|
|
create_routes_from_invoice = LNWallet.create_routes_from_invoice |
|
|
_check_invoice = staticmethod(LNWallet._check_invoice) |
|
|
_check_invoice = staticmethod(LNWallet._check_invoice) |
|
|
pay_to_route = LNWallet.pay_to_route |
|
|
pay_to_route = LNWallet.pay_to_route |
|
|
_pay = LNWallet._pay |
|
|
pay_invoice = LNWallet.pay_invoice |
|
|
force_close_channel = LNWallet.force_close_channel |
|
|
force_close_channel = LNWallet.force_close_channel |
|
|
try_force_closing = LNWallet.try_force_closing |
|
|
try_force_closing = LNWallet.try_force_closing |
|
|
get_first_timestamp = lambda self: 0 |
|
|
get_first_timestamp = lambda self: 0 |
|
@ -422,7 +422,7 @@ class TestPeer(ElectrumTestCase): |
|
|
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) |
|
|
pay_req = run(self.prepare_invoice(w2)) |
|
|
pay_req = run(self.prepare_invoice(w2)) |
|
|
async def pay(): |
|
|
async def pay(): |
|
|
result, log = await w1._pay(pay_req) |
|
|
result, log = await w1.pay_invoice(pay_req) |
|
|
self.assertEqual(result, True) |
|
|
self.assertEqual(result, True) |
|
|
gath.cancel() |
|
|
gath.cancel() |
|
|
gath = asyncio.gather(pay(), p1._message_loop(), p2._message_loop(), p1.htlc_switch(), p2.htlc_switch()) |
|
|
gath = asyncio.gather(pay(), p1._message_loop(), p2._message_loop(), p1.htlc_switch(), p2.htlc_switch()) |
|
@ -454,7 +454,7 @@ class TestPeer(ElectrumTestCase): |
|
|
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) |
|
|
async def pay(pay_req): |
|
|
async def pay(pay_req): |
|
|
result, log = await w1._pay(pay_req) |
|
|
result, log = await w1.pay_invoice(pay_req) |
|
|
self.assertTrue(result) |
|
|
self.assertTrue(result) |
|
|
raise PaymentDone() |
|
|
raise PaymentDone() |
|
|
async def f(): |
|
|
async def f(): |
|
@ -547,7 +547,7 @@ class TestPeer(ElectrumTestCase): |
|
|
max_htlcs_in_flight = asyncio.Semaphore(5) |
|
|
max_htlcs_in_flight = asyncio.Semaphore(5) |
|
|
async def single_payment(pay_req): |
|
|
async def single_payment(pay_req): |
|
|
async with max_htlcs_in_flight: |
|
|
async with max_htlcs_in_flight: |
|
|
await w1._pay(pay_req) |
|
|
await w1.pay_invoice(pay_req) |
|
|
async def many_payments(): |
|
|
async def many_payments(): |
|
|
async with TaskGroup() as group: |
|
|
async with TaskGroup() as group: |
|
|
pay_reqs_tasks = [await group.spawn(self.prepare_invoice(w2, amount_msat=payment_value_msat)) |
|
|
pay_reqs_tasks = [await group.spawn(self.prepare_invoice(w2, amount_msat=payment_value_msat)) |
|
@ -572,7 +572,7 @@ class TestPeer(ElectrumTestCase): |
|
|
graph = self.prepare_chans_and_peers_in_square() |
|
|
graph = self.prepare_chans_and_peers_in_square() |
|
|
peers = graph.all_peers() |
|
|
peers = graph.all_peers() |
|
|
async def pay(pay_req): |
|
|
async def pay(pay_req): |
|
|
result, log = await graph.w_a._pay(pay_req) |
|
|
result, log = await graph.w_a.pay_invoice(pay_req) |
|
|
self.assertTrue(result) |
|
|
self.assertTrue(result) |
|
|
raise PaymentDone() |
|
|
raise PaymentDone() |
|
|
async def f(): |
|
|
async def f(): |
|
@ -595,15 +595,15 @@ class TestPeer(ElectrumTestCase): |
|
|
path = [PathEdge(node_id=graph.w_c.node_keypair.pubkey, short_channel_id=graph.chan_ab.short_channel_id), |
|
|
path = [PathEdge(node_id=graph.w_c.node_keypair.pubkey, short_channel_id=graph.chan_ab.short_channel_id), |
|
|
PathEdge(node_id=graph.w_d.node_keypair.pubkey, short_channel_id=graph.chan_bd.short_channel_id)] |
|
|
PathEdge(node_id=graph.w_d.node_keypair.pubkey, short_channel_id=graph.chan_bd.short_channel_id)] |
|
|
with self.assertRaises(LNPathInconsistent): |
|
|
with self.assertRaises(LNPathInconsistent): |
|
|
await graph.w_a._pay(pay_req, full_path=path) |
|
|
await graph.w_a.pay_invoice(pay_req, full_path=path) |
|
|
with self.subTest(msg="bad path: last node id differs from invoice pubkey"): |
|
|
with self.subTest(msg="bad path: last node id differs from invoice pubkey"): |
|
|
path = [PathEdge(node_id=graph.w_b.node_keypair.pubkey, short_channel_id=graph.chan_ab.short_channel_id)] |
|
|
path = [PathEdge(node_id=graph.w_b.node_keypair.pubkey, short_channel_id=graph.chan_ab.short_channel_id)] |
|
|
with self.assertRaises(LNPathInconsistent): |
|
|
with self.assertRaises(LNPathInconsistent): |
|
|
await graph.w_a._pay(pay_req, full_path=path) |
|
|
await graph.w_a.pay_invoice(pay_req, full_path=path) |
|
|
with self.subTest(msg="good path"): |
|
|
with self.subTest(msg="good path"): |
|
|
path = [PathEdge(node_id=graph.w_b.node_keypair.pubkey, short_channel_id=graph.chan_ab.short_channel_id), |
|
|
path = [PathEdge(node_id=graph.w_b.node_keypair.pubkey, short_channel_id=graph.chan_ab.short_channel_id), |
|
|
PathEdge(node_id=graph.w_d.node_keypair.pubkey, short_channel_id=graph.chan_bd.short_channel_id)] |
|
|
PathEdge(node_id=graph.w_d.node_keypair.pubkey, short_channel_id=graph.chan_bd.short_channel_id)] |
|
|
result, log = await graph.w_a._pay(pay_req, full_path=path) |
|
|
result, log = await graph.w_a.pay_invoice(pay_req, full_path=path) |
|
|
self.assertTrue(result) |
|
|
self.assertTrue(result) |
|
|
self.assertEqual( |
|
|
self.assertEqual( |
|
|
[edge.short_channel_id for edge in path], |
|
|
[edge.short_channel_id for edge in path], |
|
@ -627,7 +627,7 @@ class TestPeer(ElectrumTestCase): |
|
|
graph.w_c.network.config.set_key('test_fail_htlcs_with_temp_node_failure', True) |
|
|
graph.w_c.network.config.set_key('test_fail_htlcs_with_temp_node_failure', True) |
|
|
peers = graph.all_peers() |
|
|
peers = graph.all_peers() |
|
|
async def pay(pay_req): |
|
|
async def pay(pay_req): |
|
|
result, log = await graph.w_a._pay(pay_req) |
|
|
result, log = await graph.w_a.pay_invoice(pay_req) |
|
|
self.assertFalse(result) |
|
|
self.assertFalse(result) |
|
|
self.assertEqual(OnionFailureCode.TEMPORARY_NODE_FAILURE, log[0].failure_msg.code) |
|
|
self.assertEqual(OnionFailureCode.TEMPORARY_NODE_FAILURE, log[0].failure_msg.code) |
|
|
raise PaymentDone() |
|
|
raise PaymentDone() |
|
|