2018-08-05 02:49:10 +05:30
|
|
|
import contextlib
|
|
|
|
from io import StringIO
|
2019-01-23 21:59:26 -05:00
|
|
|
from unittest import TestCase
|
|
|
|
|
|
|
|
import docopt
|
|
|
|
from torba.testcase import AsyncioTestCase
|
2018-08-05 02:49:10 +05:30
|
|
|
|
2018-11-04 15:10:49 -05:00
|
|
|
from lbrynet.extras.cli import normalize_value, main
|
2018-11-09 13:06:02 -05:00
|
|
|
from lbrynet.extras.system_info import get_platform
|
2019-01-23 21:59:26 -05:00
|
|
|
from lbrynet.extras.daemon.Daemon import Daemon
|
2018-08-05 02:49:10 +05:30
|
|
|
|
|
|
|
|
2019-01-23 19:02:11 -05:00
|
|
|
class CLITest(AsyncioTestCase):
|
2018-08-05 02:49:10 +05:30
|
|
|
|
2019-01-23 13:00:58 -05:00
|
|
|
@staticmethod
|
|
|
|
def shell(argv):
|
|
|
|
actual_output = StringIO()
|
|
|
|
with contextlib.redirect_stdout(actual_output):
|
|
|
|
with contextlib.redirect_stderr(actual_output):
|
|
|
|
try:
|
|
|
|
main(argv)
|
|
|
|
except SystemExit as e:
|
|
|
|
print(e.args[0])
|
|
|
|
return actual_output.getvalue().strip()
|
|
|
|
|
2018-08-05 02:49:10 +05:30
|
|
|
def test_guess_type(self):
|
|
|
|
self.assertEqual('0.3.8', normalize_value('0.3.8'))
|
2018-08-06 00:28:11 -04:00
|
|
|
self.assertEqual('0.3', normalize_value('0.3'))
|
2018-08-05 02:49:10 +05:30
|
|
|
self.assertEqual(3, normalize_value('3'))
|
|
|
|
self.assertEqual(3, normalize_value(3))
|
|
|
|
|
|
|
|
self.assertEqual(
|
|
|
|
'VdNmakxFORPSyfCprAD/eDDPk5TY9QYtSA==',
|
|
|
|
normalize_value('VdNmakxFORPSyfCprAD/eDDPk5TY9QYtSA==')
|
|
|
|
)
|
|
|
|
|
2018-10-18 14:41:33 +03:00
|
|
|
self.assertTrue(normalize_value('TRUE'))
|
|
|
|
self.assertTrue(normalize_value('true'))
|
|
|
|
self.assertTrue(normalize_value('TrUe'))
|
|
|
|
self.assertFalse(normalize_value('FALSE'))
|
|
|
|
self.assertFalse(normalize_value('false'))
|
|
|
|
self.assertFalse(normalize_value('FaLsE'))
|
|
|
|
self.assertTrue(normalize_value(True))
|
2018-08-05 02:49:10 +05:30
|
|
|
|
|
|
|
self.assertEqual('3', normalize_value('3', key="uri"))
|
|
|
|
self.assertEqual('0.3', normalize_value('0.3', key="uri"))
|
|
|
|
self.assertEqual('True', normalize_value('True', key="uri"))
|
|
|
|
self.assertEqual('False', normalize_value('False', key="uri"))
|
|
|
|
|
|
|
|
self.assertEqual('3', normalize_value('3', key="file_name"))
|
|
|
|
self.assertEqual('3', normalize_value('3', key="name"))
|
|
|
|
self.assertEqual('3', normalize_value('3', key="download_directory"))
|
|
|
|
self.assertEqual('3', normalize_value('3', key="channel_name"))
|
|
|
|
|
|
|
|
self.assertEqual(3, normalize_value('3', key="some_other_thing"))
|
|
|
|
|
2019-01-23 13:00:58 -05:00
|
|
|
def test_help(self):
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('lbrynet [-v] [--api HOST:PORT]', self.shell(['--help']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# start is special command, with separate help handling
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('--share-usage-data', self.shell(['start', '--help']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# publish is ungrouped command, returns usage only implicitly
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('publish (<name> | --name=<name>)', self.shell(['publish']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# publish is ungrouped command, with explicit --help
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('Make a new name claim and publish', self.shell(['publish', '--help']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# account is a group, returns help implicitly
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('Return the balance of an account', self.shell(['account']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# account is a group, with explicit --help
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('Return the balance of an account', self.shell(['account', '--help']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# account add is a grouped command, returns usage implicitly
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('account_add (<account_name> | --account_name=<account_name>)', self.shell(['account', 'add']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# account add is a grouped command, with explicit --help
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('Add a previously created account from a seed,', self.shell(['account', 'add', '--help']))
|
|
|
|
|
|
|
|
def test_help_error_handling(self):
|
|
|
|
# person tries `help` command, then they get help even though that's invalid command
|
|
|
|
self.assertIn('--config FILE', self.shell(['help']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# help for invalid command, with explicit --help
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('--config FILE', self.shell(['nonexistant', '--help']))
|
2019-01-23 13:00:58 -05:00
|
|
|
# help for invalid command, implicit
|
2019-01-25 19:58:43 -05:00
|
|
|
self.assertIn('--config FILE', self.shell(['nonexistant']))
|
2018-08-05 02:49:10 +05:30
|
|
|
|
|
|
|
def test_version_command(self):
|
|
|
|
self.assertEqual(
|
2019-01-23 13:00:58 -05:00
|
|
|
"lbrynet {lbrynet_version}".format(**get_platform()), self.shell(['--version'])
|
2018-08-05 02:49:10 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
def test_valid_command_daemon_not_started(self):
|
|
|
|
self.assertEqual(
|
2019-01-23 13:00:58 -05:00
|
|
|
"Could not connect to daemon. Are you sure it's running?",
|
|
|
|
self.shell(["publish", '--name=asd', '--bid=99'])
|
2018-08-05 02:49:10 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
def test_deprecated_command_daemon_not_started(self):
|
|
|
|
actual_output = StringIO()
|
|
|
|
with contextlib.redirect_stdout(actual_output):
|
2019-01-23 13:00:58 -05:00
|
|
|
main(["wallet", "balance"])
|
2018-08-05 02:49:10 +05:30
|
|
|
self.assertEqual(
|
|
|
|
actual_output.getvalue().strip(),
|
2018-08-25 23:50:48 -04:00
|
|
|
"wallet_balance is deprecated, using account_balance.\n"
|
2018-08-05 02:49:10 +05:30
|
|
|
"Could not connect to daemon. Are you sure it's running?"
|
|
|
|
)
|
2019-01-23 21:59:26 -05:00
|
|
|
|
|
|
|
|
|
|
|
class DaemonDocsTests(TestCase):
|
|
|
|
|
|
|
|
def test_can_parse_api_method_docs(self):
|
|
|
|
failures = []
|
|
|
|
for name, fn in Daemon.callable_methods.items():
|
|
|
|
try:
|
|
|
|
docopt.docopt(fn.__doc__, ())
|
|
|
|
except docopt.DocoptLanguageError as err:
|
|
|
|
failures.append(f"invalid docstring for {name}, {err.message}")
|
|
|
|
except docopt.DocoptExit:
|
|
|
|
pass
|
|
|
|
if failures:
|
|
|
|
self.fail("\n" + "\n".join(failures))
|