staking-deposit-cli/tests/test_cli/test_existing_menmonic.py

99 lines
3.1 KiB
Python
Raw Normal View History

2020-05-12 07:35:56 +00:00
import asyncio
import os
2020-05-12 07:35:56 +00:00
import pytest
from click.testing import CliRunner
2020-09-29 14:24:18 +00:00
from eth2deposit.deposit import cli
from eth2deposit.utils.constants import DEFAULT_VALIDATOR_KEYS_FOLDER_NAME
from.helpers import clean_key_folder, get_permissions, get_uuid
def test_existing_mnemonic() -> None:
# Prepare folder
2020-05-12 08:08:49 +00:00
my_folder_path = os.path.join(os.getcwd(), 'TESTING_TEMP_FOLDER')
clean_key_folder(my_folder_path)
if not os.path.exists(my_folder_path):
os.mkdir(my_folder_path)
runner = CliRunner()
2020-09-29 14:30:57 +00:00
inputs = [
'abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about',
'2', '2', '5', 'mainnet', 'MyPassword', 'MyPassword', 'yes']
data = '\n'.join(inputs)
arguments = ['existing-mnemonic', '--folder', my_folder_path, '--mnemonic-password', 'TREZOR']
result = runner.invoke(cli, arguments, input=data)
assert result.exit_code == 0
# Check files
validator_keys_folder_path = os.path.join(my_folder_path, DEFAULT_VALIDATOR_KEYS_FOLDER_NAME)
_, _, key_files = next(os.walk(validator_keys_folder_path))
2020-05-26 13:00:53 +00:00
all_uuid = [
get_uuid(validator_keys_folder_path + '/' + key_file)
for key_file in key_files
if key_file.startswith('keystore')
]
assert len(set(all_uuid)) == 5
# Verify file permissions
if os.name == 'posix':
for file_name in key_files:
assert get_permissions(validator_keys_folder_path, file_name) == '0o440'
# Clean up
clean_key_folder(my_folder_path)
2020-05-12 07:35:56 +00:00
@pytest.mark.asyncio
async def test_script() -> None:
2020-05-12 08:08:49 +00:00
my_folder_path = os.path.join(os.getcwd(), 'TESTING_TEMP_FOLDER')
if not os.path.exists(my_folder_path):
os.mkdir(my_folder_path)
2020-05-21 19:37:43 +00:00
if os.name == 'nt': # Windows
run_script_cmd = 'sh deposit.sh'
else: # Mac or Linux
run_script_cmd = './deposit.sh'
install_cmd = run_script_cmd + ' install'
proc = await asyncio.create_subprocess_shell(
2020-05-21 19:37:43 +00:00
install_cmd,
)
2020-05-21 19:37:43 +00:00
await proc.wait()
2020-05-12 08:08:49 +00:00
cmd_args = [
run_script_cmd,
'existing-mnemonic',
2020-05-12 08:08:49 +00:00
'--num_validators', '1',
'--mnemonic="abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about"',
'--mnemonic-password', 'TREZOR',
'--validator_start_index', '1',
'--chain', 'mainnet',
2020-09-29 14:24:18 +00:00
'--keystore_password', 'MyPassword',
2020-05-12 08:08:49 +00:00
'--folder', my_folder_path,
]
2020-05-12 07:35:56 +00:00
proc = await asyncio.create_subprocess_shell(
2020-05-12 08:08:49 +00:00
' '.join(cmd_args),
2020-05-12 07:35:56 +00:00
stdin=asyncio.subprocess.PIPE,
stdout=asyncio.subprocess.PIPE,
)
async for out in proc.stdout:
output = out.decode('utf-8').rstrip()
if output.startswith('Running deposit-cli...'):
proc.stdin.write(b'y\n')
2020-05-12 08:08:49 +00:00
# Check files
validator_keys_folder_path = os.path.join(my_folder_path, DEFAULT_VALIDATOR_KEYS_FOLDER_NAME)
_, _, key_files = next(os.walk(validator_keys_folder_path))
# Verify file permissions
if os.name == 'posix':
for file_name in key_files:
assert get_permissions(validator_keys_folder_path, file_name) == '0o440'
2020-05-12 08:08:49 +00:00
# Clean up
2020-05-23 14:32:31 +00:00
clean_key_folder(my_folder_path)