lbry-sdk/tests/integration/cli/test_cli.py

57 lines
1.9 KiB
Python
Raw Normal View History

import contextlib
from io import StringIO
2018-12-15 15:31:36 -05:00
from unittest import skip
2018-12-12 22:32:44 -05:00
from torba.testcase import AsyncioTestCase
from lbrynet import conf
2018-11-07 15:15:05 -05:00
from lbrynet.extras import cli
from lbrynet.extras.daemon.Components import DATABASE_COMPONENT, BLOB_COMPONENT, HEADERS_COMPONENT, WALLET_COMPONENT, \
DHT_COMPONENT, HASH_ANNOUNCER_COMPONENT, FILE_MANAGER_COMPONENT, \
PEER_PROTOCOL_SERVER_COMPONENT, REFLECTOR_COMPONENT, UPNP_COMPONENT, EXCHANGE_RATE_MANAGER_COMPONENT, \
RATE_LIMITER_COMPONENT, PAYMENT_RATE_COMPONENT
from lbrynet.extras.daemon.Daemon import Daemon
2018-08-18 01:37:57 +05:30
class FakeAnalytics:
@property
def is_started(self):
return True
async def send_server_startup_success(self):
2018-08-18 01:37:57 +05:30
pass
async def send_server_startup(self):
2018-09-21 17:32:02 -03:00
pass
2018-08-18 01:37:57 +05:30
def shutdown(self):
pass
2018-12-12 22:32:44 -05:00
class CLIIntegrationTest(AsyncioTestCase):
2018-12-12 22:32:44 -05:00
async def asyncSetUp(self):
skip = [
DATABASE_COMPONENT, BLOB_COMPONENT, HEADERS_COMPONENT, WALLET_COMPONENT,
DHT_COMPONENT, HASH_ANNOUNCER_COMPONENT, FILE_MANAGER_COMPONENT,
PEER_PROTOCOL_SERVER_COMPONENT, REFLECTOR_COMPONENT, UPNP_COMPONENT, EXCHANGE_RATE_MANAGER_COMPONENT,
RATE_LIMITER_COMPONENT, PAYMENT_RATE_COMPONENT
]
conf.initialize_settings(load_conf_file=False)
2018-10-16 21:28:47 -04:00
conf.settings['api_port'] = 5299
conf.settings['components_to_skip'] = skip
conf.settings.initialize_post_conf_load()
Daemon.component_attributes = {}
2018-08-18 01:37:57 +05:30
self.daemon = Daemon(analytics_manager=FakeAnalytics())
2018-12-12 22:32:44 -05:00
await self.daemon.start_listening()
2018-12-12 22:32:44 -05:00
async def asyncTearDown(self):
await self.daemon.shutdown()
def test_cli_status_command_with_auth(self):
actual_output = StringIO()
with contextlib.redirect_stdout(actual_output):
cli.main(["status"])
actual_output = actual_output.getvalue()
self.assertIn("connection_status", actual_output)