mirror of
https://gitlab.com/pulsechaincom/staking-deposit-cli.git
synced 2025-01-20 10:21:11 +00:00
Normalize input bls_withdrawal_credentials
and add test_existing_mnemonic_bls_withdrawal_interactive
This commit is contained in:
parent
f5e2803274
commit
245ee7b63a
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user