2019-01-07 02:52:53 -05:00
|
|
|
import asyncio
|
2019-12-31 15:30:13 -05:00
|
|
|
from lbry.testcase import AsyncioTestCase, AdvanceTimeTestCase
|
2018-07-24 12:44:37 -04:00
|
|
|
|
2019-06-20 21:02:58 -04:00
|
|
|
from lbry.conf import Config
|
2020-01-03 01:42:54 -05:00
|
|
|
from lbry.extras.daemon.componentmanager import ComponentManager
|
2021-09-19 21:38:09 -04:00
|
|
|
from lbry.extras.daemon.components import DATABASE_COMPONENT, DISK_SPACE_COMPONENT, DHT_COMPONENT
|
2020-01-03 01:42:54 -05:00
|
|
|
from lbry.extras.daemon.components import HASH_ANNOUNCER_COMPONENT, UPNP_COMPONENT
|
|
|
|
from lbry.extras.daemon.components import PEER_PROTOCOL_SERVER_COMPONENT, EXCHANGE_RATE_MANAGER_COMPONENT
|
|
|
|
from lbry.extras.daemon import components
|
2018-07-24 12:44:37 -04:00
|
|
|
|
|
|
|
|
2019-01-23 20:57:56 -05:00
|
|
|
class TestComponentManager(AsyncioTestCase):
|
2019-01-23 20:26:29 -05:00
|
|
|
|
2018-07-24 12:44:37 -04:00
|
|
|
def setUp(self):
|
|
|
|
self.default_components_sort = [
|
2018-08-02 15:54:43 -04:00
|
|
|
[
|
2020-01-03 01:42:54 -05:00
|
|
|
components.DatabaseComponent,
|
|
|
|
components.ExchangeRateManagerComponent,
|
2020-01-29 13:49:14 -03:00
|
|
|
components.TorrentComponent,
|
2020-01-03 01:42:54 -05:00
|
|
|
components.UPnPComponent
|
2018-08-02 15:54:43 -04:00
|
|
|
],
|
|
|
|
[
|
2020-01-03 01:42:54 -05:00
|
|
|
components.BlobComponent,
|
|
|
|
components.DHTComponent,
|
|
|
|
components.WalletComponent
|
2018-08-02 15:54:43 -04:00
|
|
|
],
|
|
|
|
[
|
2021-09-19 21:38:09 -04:00
|
|
|
components.DiskSpaceComponent,
|
2020-01-29 13:49:14 -03:00
|
|
|
components.FileManagerComponent,
|
2020-01-03 01:42:54 -05:00
|
|
|
components.HashAnnouncerComponent,
|
|
|
|
components.PeerProtocolServerComponent,
|
2020-02-18 13:50:41 -03:00
|
|
|
components.WalletServerPaymentsComponent
|
2018-08-02 15:54:43 -04:00
|
|
|
]
|
2018-07-24 12:44:37 -04:00
|
|
|
]
|
2019-01-21 15:55:50 -05:00
|
|
|
self.component_manager = ComponentManager(Config())
|
2018-07-24 12:44:37 -04:00
|
|
|
|
|
|
|
def test_sort_components(self):
|
|
|
|
stages = self.component_manager.sort_components()
|
|
|
|
for stage_list, sorted_stage_list in zip(stages, self.default_components_sort):
|
|
|
|
self.assertEqual([type(stage) for stage in stage_list], sorted_stage_list)
|
|
|
|
|
|
|
|
def test_sort_components_reverse(self):
|
|
|
|
rev_stages = self.component_manager.sort_components(reverse=True)
|
|
|
|
reverse_default_components_sort = reversed(self.default_components_sort)
|
|
|
|
for stage_list, sorted_stage_list in zip(rev_stages, reverse_default_components_sort):
|
|
|
|
self.assertEqual([type(stage) for stage in stage_list], sorted_stage_list)
|
|
|
|
|
|
|
|
def test_get_component_not_exists(self):
|
|
|
|
with self.assertRaises(NameError):
|
|
|
|
self.component_manager.get_component("random_component")
|
|
|
|
|
|
|
|
|
2019-01-23 20:57:56 -05:00
|
|
|
class TestComponentManagerOverrides(AsyncioTestCase):
|
2019-01-23 20:26:29 -05:00
|
|
|
|
2018-07-24 12:44:37 -04:00
|
|
|
def test_init_with_overrides(self):
|
2018-10-18 13:42:45 +03:00
|
|
|
class FakeWallet:
|
2018-07-24 12:44:37 -04:00
|
|
|
component_name = "wallet"
|
|
|
|
depends_on = []
|
|
|
|
|
|
|
|
def __init__(self, component_manager):
|
|
|
|
self.component_manager = component_manager
|
|
|
|
|
|
|
|
@property
|
|
|
|
def component(self):
|
|
|
|
return self
|
|
|
|
|
2019-01-21 15:55:50 -05:00
|
|
|
new_component_manager = ComponentManager(Config(), wallet=FakeWallet)
|
2018-07-24 12:44:37 -04:00
|
|
|
fake_wallet = new_component_manager.get_component("wallet")
|
2020-01-03 01:42:54 -05:00
|
|
|
# wallet should be an instance of FakeWallet and not WalletComponent from components.py
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertIsInstance(fake_wallet, FakeWallet)
|
2020-01-03 01:42:54 -05:00
|
|
|
self.assertNotIsInstance(fake_wallet, components.WalletComponent)
|
2018-07-24 12:44:37 -04:00
|
|
|
|
|
|
|
def test_init_with_wrong_overrides(self):
|
2018-10-18 13:42:45 +03:00
|
|
|
class FakeRandomComponent:
|
2018-07-24 12:44:37 -04:00
|
|
|
component_name = "someComponent"
|
|
|
|
depends_on = []
|
|
|
|
|
|
|
|
with self.assertRaises(SyntaxError):
|
2019-01-21 15:55:50 -05:00
|
|
|
ComponentManager(Config(), randomComponent=FakeRandomComponent)
|
2018-07-24 12:44:37 -04:00
|
|
|
|
|
|
|
|
2019-01-23 20:26:29 -05:00
|
|
|
class FakeComponent:
|
|
|
|
depends_on = []
|
|
|
|
component_name = None
|
|
|
|
|
|
|
|
def __init__(self, component_manager):
|
|
|
|
self.component_manager = component_manager
|
|
|
|
self._running = False
|
|
|
|
|
|
|
|
@property
|
|
|
|
def running(self):
|
|
|
|
return self._running
|
|
|
|
|
|
|
|
async def start(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
async def stop(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
@property
|
|
|
|
def component(self):
|
|
|
|
return self
|
|
|
|
|
|
|
|
async def _setup(self):
|
|
|
|
result = await self.start()
|
|
|
|
self._running = True
|
|
|
|
return result
|
|
|
|
|
|
|
|
async def _stop(self):
|
|
|
|
result = await self.stop()
|
|
|
|
self._running = False
|
|
|
|
return result
|
|
|
|
|
|
|
|
async def get_status(self):
|
|
|
|
return {}
|
|
|
|
|
|
|
|
def __lt__(self, other):
|
|
|
|
return self.component_name < other.component_name
|
|
|
|
|
|
|
|
|
|
|
|
class FakeDelayedWallet(FakeComponent):
|
|
|
|
component_name = "wallet"
|
|
|
|
depends_on = []
|
2020-05-25 10:21:36 -04:00
|
|
|
ledger = None
|
|
|
|
default_wallet = None
|
2019-01-23 20:26:29 -05:00
|
|
|
|
|
|
|
async def stop(self):
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
|
|
|
|
|
|
class FakeDelayedBlobManager(FakeComponent):
|
|
|
|
component_name = "blob_manager"
|
|
|
|
depends_on = [FakeDelayedWallet.component_name]
|
|
|
|
|
|
|
|
async def start(self):
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
|
|
async def stop(self):
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
|
|
|
2020-01-29 13:49:14 -03:00
|
|
|
class FakeDelayedFileManager(FakeComponent):
|
|
|
|
component_name = "file_manager"
|
2019-01-23 20:26:29 -05:00
|
|
|
depends_on = [FakeDelayedBlobManager.component_name]
|
|
|
|
|
|
|
|
async def start(self):
|
|
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
|
|
|
2019-01-07 02:52:53 -05:00
|
|
|
class TestComponentManagerProperStart(AdvanceTimeTestCase):
|
2019-01-23 20:26:29 -05:00
|
|
|
|
2018-07-24 12:44:37 -04:00
|
|
|
def setUp(self):
|
|
|
|
self.component_manager = ComponentManager(
|
2019-01-21 15:55:50 -05:00
|
|
|
Config(),
|
2019-01-23 20:26:29 -05:00
|
|
|
skip_components=[
|
2021-09-19 21:38:09 -04:00
|
|
|
DATABASE_COMPONENT, DISK_SPACE_COMPONENT, DHT_COMPONENT, HASH_ANNOUNCER_COMPONENT,
|
2019-01-23 20:26:29 -05:00
|
|
|
PEER_PROTOCOL_SERVER_COMPONENT, UPNP_COMPONENT,
|
2019-09-27 09:26:35 -03:00
|
|
|
EXCHANGE_RATE_MANAGER_COMPONENT],
|
2019-01-23 20:26:29 -05:00
|
|
|
wallet=FakeDelayedWallet,
|
2020-01-29 13:49:14 -03:00
|
|
|
file_manager=FakeDelayedFileManager,
|
2019-01-23 20:26:29 -05:00
|
|
|
blob_manager=FakeDelayedBlobManager
|
2018-07-24 12:44:37 -04:00
|
|
|
)
|
|
|
|
|
2019-01-07 02:52:53 -05:00
|
|
|
async def test_proper_starting_of_components(self):
|
2019-01-23 20:26:29 -05:00
|
|
|
asyncio.create_task(self.component_manager.start())
|
2018-07-24 12:44:37 -04:00
|
|
|
|
2019-01-07 02:52:53 -05:00
|
|
|
await self.advance(0)
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('wallet').running)
|
2018-08-02 15:54:43 -04:00
|
|
|
self.assertFalse(self.component_manager.get_component('blob_manager').running)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertFalse(self.component_manager.get_component('file_manager').running)
|
2018-07-24 12:44:37 -04:00
|
|
|
|
2019-01-07 02:52:53 -05:00
|
|
|
await self.advance(1)
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('wallet').running)
|
2018-08-02 15:54:43 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('blob_manager').running)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertFalse(self.component_manager.get_component('file_manager').running)
|
2018-07-24 12:44:37 -04:00
|
|
|
|
2019-01-07 02:52:53 -05:00
|
|
|
await self.advance(1)
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('wallet').running)
|
2018-08-02 15:54:43 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('blob_manager').running)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertTrue(self.component_manager.get_component('file_manager').running)
|
2018-07-24 12:44:37 -04:00
|
|
|
|
2019-01-07 02:52:53 -05:00
|
|
|
async def test_proper_stopping_of_components(self):
|
2019-01-23 20:26:29 -05:00
|
|
|
asyncio.create_task(self.component_manager.start())
|
2019-01-07 02:52:53 -05:00
|
|
|
await self.advance(0)
|
|
|
|
await self.advance(1)
|
|
|
|
await self.advance(1)
|
|
|
|
self.assertTrue(self.component_manager.get_component('wallet').running)
|
|
|
|
self.assertTrue(self.component_manager.get_component('blob_manager').running)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertTrue(self.component_manager.get_component('file_manager').running)
|
2019-01-07 02:52:53 -05:00
|
|
|
|
|
|
|
asyncio.create_task(self.component_manager.stop())
|
|
|
|
await self.advance(0)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertFalse(self.component_manager.get_component('file_manager').running)
|
2018-08-02 15:54:43 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('blob_manager').running)
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('wallet').running)
|
2019-01-07 02:52:53 -05:00
|
|
|
await self.advance(1)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertFalse(self.component_manager.get_component('file_manager').running)
|
2018-08-02 15:54:43 -04:00
|
|
|
self.assertFalse(self.component_manager.get_component('blob_manager').running)
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertTrue(self.component_manager.get_component('wallet').running)
|
2019-01-07 02:52:53 -05:00
|
|
|
await self.advance(1)
|
2020-01-29 13:49:14 -03:00
|
|
|
self.assertFalse(self.component_manager.get_component('file_manager').running)
|
2018-08-02 15:54:43 -04:00
|
|
|
self.assertFalse(self.component_manager.get_component('blob_manager').running)
|
2018-07-24 12:44:37 -04:00
|
|
|
self.assertFalse(self.component_manager.get_component('wallet').running)
|