2019-06-26 22:28:13 +02:00
|
|
|
import asyncio
|
|
|
|
|
2019-12-31 20:52:57 +01:00
|
|
|
import lbry
|
2019-07-23 18:45:10 +02:00
|
|
|
import lbry.wallet
|
2020-02-21 16:05:46 +01:00
|
|
|
from lbry.error import ServerPaymentFeeAboveMaxAllowedError
|
2020-01-03 08:40:37 +01:00
|
|
|
from lbry.wallet.network import ClientSession
|
2021-01-16 22:27:42 +01:00
|
|
|
from lbry.wallet.server.session import LBRYElectrumX
|
2020-02-21 04:04:37 +01:00
|
|
|
from lbry.testcase import IntegrationTestCase, CommandTestCase
|
2020-01-06 05:29:48 +01:00
|
|
|
from lbry.wallet.orchstr8.node import SPVNode
|
2019-06-26 22:28:13 +02:00
|
|
|
|
|
|
|
|
2019-11-08 16:52:39 +01:00
|
|
|
class TestSessions(IntegrationTestCase):
|
2019-06-26 22:28:13 +02:00
|
|
|
"""
|
2019-07-16 11:23:44 +02:00
|
|
|
Tests that server cleans up stale connections after session timeout and client times out too.
|
2019-06-26 22:28:13 +02:00
|
|
|
"""
|
|
|
|
|
|
|
|
LEDGER = lbry.wallet
|
|
|
|
|
|
|
|
async def test_session_bloat_from_socket_timeout(self):
|
2019-07-16 11:23:44 +02:00
|
|
|
await self.conductor.stop_spv()
|
2019-07-22 04:26:49 +02:00
|
|
|
await self.ledger.stop()
|
2019-07-16 11:23:44 +02:00
|
|
|
self.conductor.spv_node.session_timeout = 1
|
|
|
|
await self.conductor.start_spv()
|
2019-09-03 16:28:30 +02:00
|
|
|
session = ClientSession(
|
|
|
|
network=None, server=(self.conductor.spv_node.hostname, self.conductor.spv_node.port), timeout=0.2
|
|
|
|
)
|
2019-07-16 11:23:44 +02:00
|
|
|
await session.create_connection()
|
|
|
|
await session.send_request('server.banner', ())
|
|
|
|
self.assertEqual(len(self.conductor.spv_node.server.session_mgr.sessions), 1)
|
|
|
|
self.assertFalse(session.is_closing())
|
|
|
|
await asyncio.sleep(1.1)
|
|
|
|
with self.assertRaises(asyncio.TimeoutError):
|
|
|
|
await session.send_request('server.banner', ())
|
|
|
|
self.assertTrue(session.is_closing())
|
|
|
|
self.assertEqual(len(self.conductor.spv_node.server.session_mgr.sessions), 0)
|
2019-07-23 18:45:10 +02:00
|
|
|
|
2019-11-08 16:52:39 +01:00
|
|
|
async def test_proper_version(self):
|
|
|
|
info = await self.ledger.network.get_server_features()
|
2019-12-31 20:52:57 +01:00
|
|
|
self.assertEqual(lbry.__version__, info['server_version'])
|
2019-11-08 16:52:39 +01:00
|
|
|
|
2019-11-18 16:19:16 +01:00
|
|
|
async def test_client_errors(self):
|
|
|
|
# Goal is ensuring thsoe are raised and not trapped accidentally
|
|
|
|
with self.assertRaisesRegex(Exception, 'not a valid address'):
|
|
|
|
await self.ledger.network.get_history('of the world')
|
|
|
|
with self.assertRaisesRegex(Exception, 'rejected by network rules.*TX decode failed'):
|
|
|
|
await self.ledger.network.broadcast('13370042004200')
|
|
|
|
|
2019-07-23 18:45:10 +02:00
|
|
|
|
2020-01-06 05:29:48 +01:00
|
|
|
class TestUsagePayment(CommandTestCase):
|
2021-01-22 01:29:59 +01:00
|
|
|
async def _test_single_server_payment(self):
|
2020-02-18 17:50:41 +01:00
|
|
|
wallet_pay_service = self.daemon.component_manager.get_component('wallet_server_payments')
|
|
|
|
wallet_pay_service.payment_period = 1
|
2020-02-21 18:15:17 +01:00
|
|
|
# only starts with a positive max key fee
|
|
|
|
wallet_pay_service.max_fee = "0.0"
|
|
|
|
await wallet_pay_service.start(ledger=self.ledger, wallet=self.wallet)
|
|
|
|
self.assertFalse(wallet_pay_service.running)
|
|
|
|
wallet_pay_service.max_fee = "1.0"
|
|
|
|
await wallet_pay_service.start(ledger=self.ledger, wallet=self.wallet)
|
|
|
|
self.assertTrue(wallet_pay_service.running)
|
2020-02-18 17:50:41 +01:00
|
|
|
await wallet_pay_service.stop()
|
|
|
|
await wallet_pay_service.start(ledger=self.ledger, wallet=self.wallet)
|
2020-02-12 02:05:49 +01:00
|
|
|
|
2020-02-21 21:25:12 +01:00
|
|
|
address = await self.blockchain.get_raw_change_address()
|
2020-01-06 09:07:37 +01:00
|
|
|
_, history = await self.ledger.get_local_status_and_history(address)
|
|
|
|
self.assertEqual(history, [])
|
2020-01-06 05:29:48 +01:00
|
|
|
|
|
|
|
node = SPVNode(self.conductor.spv_module, node_number=2)
|
2020-01-06 09:07:37 +01:00
|
|
|
await node.start(self.blockchain, extraconf={"PAYMENT_ADDRESS": address, "DAILY_FEE": "1.1"})
|
2020-02-21 18:18:44 +01:00
|
|
|
self.addCleanup(node.stop)
|
2020-02-17 17:35:46 +01:00
|
|
|
self.daemon.jsonrpc_settings_set('lbryum_servers', [f"{node.hostname}:{node.port}"])
|
2021-01-21 23:52:57 +01:00
|
|
|
await self.daemon.jsonrpc_wallet_reconnect()
|
2021-01-16 22:27:42 +01:00
|
|
|
LBRYElectrumX.set_server_features(node.server.env)
|
2020-02-21 04:04:37 +01:00
|
|
|
features = await self.ledger.network.get_server_features()
|
|
|
|
self.assertEqual(features["payment_address"], address)
|
|
|
|
self.assertEqual(features["daily_fee"], "1.1")
|
2020-02-21 16:05:46 +01:00
|
|
|
with self.assertRaises(ServerPaymentFeeAboveMaxAllowedError):
|
2021-01-21 23:52:57 +01:00
|
|
|
await asyncio.wait_for(wallet_pay_service.on_payment.first, timeout=30)
|
2021-01-16 22:27:42 +01:00
|
|
|
node.server.env.daily_fee = "1.0"
|
|
|
|
node.server.env.payment_address = address
|
|
|
|
LBRYElectrumX.set_server_features(node.server.env)
|
|
|
|
# self.daemon.jsonrpc_settings_set('lbryum_servers', [f"{node.hostname}:{node.port}"])
|
2020-01-06 09:07:37 +01:00
|
|
|
await self.daemon.jsonrpc_wallet_reconnect()
|
2020-01-06 05:29:48 +01:00
|
|
|
features = await self.ledger.network.get_server_features()
|
2020-01-06 09:07:37 +01:00
|
|
|
self.assertEqual(features["payment_address"], address)
|
2020-02-17 17:35:46 +01:00
|
|
|
self.assertEqual(features["daily_fee"], "1.0")
|
2021-01-16 22:27:42 +01:00
|
|
|
tx = await asyncio.wait_for(wallet_pay_service.on_payment.first, timeout=30)
|
2020-02-21 21:25:12 +01:00
|
|
|
self.assertIsNotNone(await self.blockchain.get_raw_transaction(tx.id)) # verify its broadcasted
|
2020-02-21 20:41:23 +01:00
|
|
|
self.assertEqual(tx.outputs[0].amount, 100000000)
|
|
|
|
self.assertEqual(tx.outputs[0].get_address(self.ledger), address)
|