Normalize input bls_withdrawal_credentials and add test_existing_mnemonic_bls_withdrawal_interactive

This commit is contained in:
Hsiao-Wei Wang 2023-01-22 13:33:53 +01:00
parent f5e2803274
commit 245ee7b63a
No known key found for this signature in database
GPG Key ID: AE3D6B174F971DE4
3 changed files with 67 additions and 11 deletions

View File

@ -203,8 +203,17 @@ def validate_bls_to_execution_change(btec_dict: Dict[str, Any],
return True return True
def validate_bls_withdrawal_credentials(bls_withdrawal_credentials: str) -> bytes: def normalize_bls_withdrawal_credentials_to_bytes(bls_withdrawal_credentials: str) -> bytes:
if bls_withdrawal_credentials.startswith('0x'):
bls_withdrawal_credentials = bls_withdrawal_credentials[2:]
bls_withdrawal_credentials_bytes = bytes.fromhex(bls_withdrawal_credentials) bls_withdrawal_credentials_bytes = bytes.fromhex(bls_withdrawal_credentials)
return bls_withdrawal_credentials_bytes
def validate_bls_withdrawal_credentials(bls_withdrawal_credentials: str) -> bytes:
bls_withdrawal_credentials_bytes = normalize_bls_withdrawal_credentials_to_bytes(bls_withdrawal_credentials)
try: try:
assert len(bls_withdrawal_credentials_bytes) == 32 assert len(bls_withdrawal_credentials_bytes) == 32
assert bls_withdrawal_credentials_bytes[:1] == BLS_WITHDRAWAL_PREFIX assert bls_withdrawal_credentials_bytes[:1] == BLS_WITHDRAWAL_PREFIX

View File

@ -35,3 +35,17 @@ def get_uuid(key_file: str) -> str:
def get_permissions(path: str, file_name: str) -> str: def get_permissions(path: str, file_name: str) -> str:
return oct(os.stat(os.path.join(path, file_name)).st_mode & 0o777) return oct(os.stat(os.path.join(path, file_name)).st_mode & 0o777)
def verify_file_permission(os_ref, folder_path, files):
if os_ref.name == 'posix':
for file_name in files:
assert get_permissions(folder_path, file_name) == '0o440'
def prepare_testing_folder(os_ref, testing_folder_name='TESTING_TEMP_FOLDER'):
my_folder_path = os_ref.path.join(os_ref.getcwd(), testing_folder_name)
clean_btec_folder(my_folder_path)
if not os_ref.path.exists(my_folder_path):
os_ref.mkdir(my_folder_path)
return my_folder_path

View File

@ -6,19 +6,17 @@ from staking_deposit.deposit import cli
from staking_deposit.utils.constants import DEFAULT_BLS_TO_EXECUTION_CHANGES_FOLDER_NAME from staking_deposit.utils.constants import DEFAULT_BLS_TO_EXECUTION_CHANGES_FOLDER_NAME
from .helpers import ( from .helpers import (
clean_btec_folder, clean_btec_folder,
get_permissions, prepare_testing_folder,
verify_file_permission,
) )
def test_existing_mnemonic_bls_withdrawal() -> None: def test_existing_mnemonic_bls_withdrawal() -> None:
# Prepare folder # Prepare folder
my_folder_path = os.path.join(os.getcwd(), 'TESTING_TEMP_FOLDER') my_folder_path = prepare_testing_folder(os)
clean_btec_folder(my_folder_path)
if not os.path.exists(my_folder_path):
os.mkdir(my_folder_path)
runner = CliRunner() runner = CliRunner()
inputs = ['0'] # confirm `validator_start_index` inputs = []
data = '\n'.join(inputs) data = '\n'.join(inputs)
arguments = [ arguments = [
'--language', 'english', '--language', 'english',
@ -26,7 +24,7 @@ def test_existing_mnemonic_bls_withdrawal() -> None:
'--bls_to_execution_changes_folder', my_folder_path, '--bls_to_execution_changes_folder', my_folder_path,
'--chain', 'mainnet', '--chain', 'mainnet',
'--mnemonic', 'sister protect peanut hill ready work profit fit wish want small inflict flip member tail between sick setup bright duck morning sell paper worry', # noqa: E501 '--mnemonic', 'sister protect peanut hill ready work profit fit wish want small inflict flip member tail between sick setup bright duck morning sell paper worry', # noqa: E501
'--bls_withdrawal_credentials', '00bd0b5a34de5fb17df08410b5e615dda87caf4fb72d0aac91ce5e52fc6aa8de', '--bls_withdrawal_credentials', '0x00bd0b5a34de5fb17df08410b5e615dda87caf4fb72d0aac91ce5e52fc6aa8de',
'--validator_start_index', '0', '--validator_start_index', '0',
'--validator_index', '1', '--validator_index', '1',
'--execution_address', '3434343434343434343434343434343434343434', '--execution_address', '3434343434343434343434343434343434343434',
@ -42,9 +40,44 @@ def test_existing_mnemonic_bls_withdrawal() -> None:
assert len(set(btec_files)) == 1 assert len(set(btec_files)) == 1
# Verify file permissions # Verify file permissions
if os.name == 'posix': verify_file_permission(os, folder_path=bls_to_execution_changes_folder_path, files=btec_files)
for file_name in btec_files:
assert get_permissions(bls_to_execution_changes_folder_path, file_name) == '0o440' # Clean up
clean_btec_folder(my_folder_path)
def test_existing_mnemonic_bls_withdrawal_interactive() -> None:
# Prepare folder
my_folder_path = prepare_testing_folder(os)
runner = CliRunner()
inputs = [
'mainnet', # network/chain
'sister protect peanut hill ready work profit fit wish want small inflict flip member tail between sick setup bright duck morning sell paper worry', # noqa: E501
'0', # validator_start_index
'1', # validator_index
'0x00bd0b5a34de5fb17df08410b5e615dda87caf4fb72d0aac91ce5e52fc6aa8de',
'0x3434343434343434343434343434343434343434',
]
data = '\n'.join(inputs)
arguments = [
'--language', 'english',
'generate-bls-to-execution-change',
'--bls_to_execution_changes_folder', my_folder_path,
]
result = runner.invoke(cli, arguments, input=data)
assert result.exit_code == 0
# Check files
bls_to_execution_changes_folder_path = os.path.join(my_folder_path, DEFAULT_BLS_TO_EXECUTION_CHANGES_FOLDER_NAME)
_, _, btec_files = next(os.walk(bls_to_execution_changes_folder_path))
# TODO verify file content
assert len(set(btec_files)) == 1
# Verify file permissions
verify_file_permission(os, folder_path=bls_to_execution_changes_folder_path, files=btec_files)
# Clean up # Clean up
clean_btec_folder(my_folder_path) clean_btec_folder(my_folder_path)