2024-01-09 17:43:56 +03:00
|
|
|
import random
|
|
|
|
import string
|
|
|
|
|
2023-09-14 10:52:27 +07:00
|
|
|
import allure
|
|
|
|
import pytest
|
|
|
|
from allure import step
|
2024-01-09 18:24:54 +03:00
|
|
|
|
|
|
|
from gui.components.toast_message import ToastMessage
|
2023-12-07 16:47:34 +00:00
|
|
|
from . import marks
|
2023-09-14 10:52:27 +07:00
|
|
|
|
|
|
|
import configs
|
|
|
|
import driver
|
|
|
|
from gui.components.signing_phrase_popup import SigningPhrasePopup
|
|
|
|
from gui.main_window import MainWindow
|
|
|
|
|
2023-12-07 16:47:34 +00:00
|
|
|
pytestmark = marks
|
2024-01-09 17:43:56 +03:00
|
|
|
|
|
|
|
|
2023-09-14 10:52:27 +07:00
|
|
|
@allure.testcase('https://ethstatus.testrail.net/index.php?/cases/view/703021', 'Manage a saved address')
|
|
|
|
@pytest.mark.case(703021)
|
2024-01-09 17:43:56 +03:00
|
|
|
@pytest.mark.parametrize('name, address, new_name',
|
|
|
|
[
|
|
|
|
pytest.param(
|
|
|
|
''.join(random.choices(string.ascii_letters, k=24)),
|
|
|
|
'0x8397bc3c5a60a1883174f722403d63a8833312b7',
|
|
|
|
''.join(random.choices(string.ascii_letters, k=24))),
|
|
|
|
pytest.param(
|
|
|
|
''.join(random.choices(string.ascii_letters, k=24)),
|
|
|
|
'nastya.stateofus.eth',
|
|
|
|
''.join(random.choices(string.ascii_letters, k=24)))
|
|
|
|
])
|
2023-09-14 10:52:27 +07:00
|
|
|
def test_manage_saved_address(main_screen: MainWindow, name: str, address: str, new_name: str):
|
|
|
|
with step('Add new address'):
|
|
|
|
wallet = main_screen.left_panel.open_wallet()
|
2024-01-09 17:43:56 +03:00
|
|
|
SigningPhrasePopup().confirm_phrase()
|
2023-09-14 10:52:27 +07:00
|
|
|
wallet.left_panel.open_saved_addresses().open_add_address_popup().add_saved_address(name, address)
|
|
|
|
|
2024-01-09 18:24:54 +03:00
|
|
|
with step('Verify toast message when adding saved address'):
|
|
|
|
messages = ToastMessage().get_toast_messages
|
|
|
|
assert f'{name} successfully added to your saved addresses' in messages, \
|
|
|
|
f"Toast message about adding saved address is not correct or not present. Current list of messages: {messages}"
|
|
|
|
|
2023-09-14 10:52:27 +07:00
|
|
|
with step('Verify that saved address is in the list of saved addresses'):
|
|
|
|
assert driver.waitFor(
|
|
|
|
lambda: name in wallet.left_panel.open_saved_addresses().address_names,
|
|
|
|
configs.timeouts.UI_LOAD_TIMEOUT_MSEC), f'Address: {name} not found'
|
|
|
|
|
|
|
|
with step('Edit saved address to new name'):
|
|
|
|
wallet.left_panel.open_saved_addresses().open_edit_address_popup(name).edit_saved_address(new_name, address)
|
|
|
|
|
2024-01-09 18:24:54 +03:00
|
|
|
with step('Verify toast message when editing saved address'):
|
|
|
|
messages = ToastMessage().get_toast_messages
|
|
|
|
assert f'{new_name} saved address successfully edited' in messages, \
|
|
|
|
f"Toast message about editing saved address is not correct or not present. Current list of messages: {messages}"
|
|
|
|
|
2023-09-14 10:52:27 +07:00
|
|
|
with step('Verify that saved address with new name is in the list of saved addresses'):
|
|
|
|
assert driver.waitFor(
|
|
|
|
lambda: new_name in wallet.left_panel.open_saved_addresses().address_names,
|
|
|
|
configs.timeouts.UI_LOAD_TIMEOUT_MSEC), f'Address: {new_name} not found'
|
|
|
|
|
|
|
|
with step('Delete address with new name'):
|
|
|
|
wallet.left_panel.open_saved_addresses().delete_saved_address(new_name)
|
|
|
|
|
2024-01-09 18:24:54 +03:00
|
|
|
with step('Verify toast message when deleting saved address'):
|
|
|
|
messages = ToastMessage().get_toast_messages
|
|
|
|
assert f'{new_name} was successfully removed from your saved addresses' in messages, \
|
|
|
|
f"Toast message about deleting saved address is not correct or not present. Current list of messages: {messages}"
|
|
|
|
|
2023-09-14 10:52:27 +07:00
|
|
|
with step('Verify that saved address with new name is not in the list of saved addresses'):
|
2023-10-30 13:00:34 +03:00
|
|
|
assert not driver.waitFor(
|
|
|
|
lambda: new_name in wallet.left_panel.open_saved_addresses().address_names,
|
|
|
|
configs.timeouts.UI_LOAD_TIMEOUT_MSEC), f'Address: {new_name} is still present'
|