mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-18 10:32:53 +00:00
tests: simplify adding new account from seed test
This commit is contained in:
parent
c9b7d9eab6
commit
cc1e185080
@ -1,18 +1,13 @@
|
|||||||
import random
|
|
||||||
import string
|
|
||||||
import time
|
import time
|
||||||
|
|
||||||
import allure
|
import allure
|
||||||
import pytest
|
import pytest
|
||||||
from allure import step
|
from allure import step
|
||||||
|
|
||||||
from constants import UserAccount, RandomUser
|
from constants import RandomUser
|
||||||
from scripts.utils.generators import random_name_string, random_password_string
|
|
||||||
from constants.wallet import WalletAccountPopup
|
|
||||||
from tests.wallet_main_screen import marks
|
from tests.wallet_main_screen import marks
|
||||||
|
|
||||||
import constants
|
import constants
|
||||||
import driver
|
|
||||||
from gui.components.signing_phrase_popup import SigningPhrasePopup
|
from gui.components.signing_phrase_popup import SigningPhrasePopup
|
||||||
from gui.components.authenticate_popup import AuthenticatePopup
|
from gui.components.authenticate_popup import AuthenticatePopup
|
||||||
from gui.main_window import MainWindow
|
from gui.main_window import MainWindow
|
||||||
@ -24,15 +19,12 @@ pytestmark = marks
|
|||||||
'Manage an account created from the generated seed phrase')
|
'Manage an account created from the generated seed phrase')
|
||||||
@pytest.mark.case(703036)
|
@pytest.mark.case(703036)
|
||||||
@pytest.mark.parametrize('user_account', [RandomUser()])
|
@pytest.mark.parametrize('user_account', [RandomUser()])
|
||||||
@pytest.mark.parametrize('name, color, emoji, emoji_unicode, '
|
@pytest.mark.parametrize('name, color, emoji, emoji_unicode, keypair_name', [
|
||||||
'new_name, new_color, new_emoji, new_emoji_unicode, keypair_name', [
|
|
||||||
pytest.param('SPAcc', '#2a4af5', 'sunglasses', '1f60e',
|
pytest.param('SPAcc', '#2a4af5', 'sunglasses', '1f60e',
|
||||||
'SPAccedited', '#216266', 'thumbsup', '1f44d', 'SPKeyPair')])
|
'SPKeyPair')])
|
||||||
def test_plus_button_manage_account_added_for_new_seed(main_screen: MainWindow, user_account,
|
def test_plus_button_manage_account_added_for_new_seed(main_screen: MainWindow, user_account,
|
||||||
name: str, color: str, emoji: str,
|
name: str, color: str, emoji: str,
|
||||||
emoji_unicode: str,
|
emoji_unicode: str,
|
||||||
new_name: str, new_color: str, new_emoji: str,
|
|
||||||
new_emoji_unicode: str,
|
|
||||||
keypair_name: str):
|
keypair_name: str):
|
||||||
with step('Create generated seed phrase wallet account'):
|
with step('Create generated seed phrase wallet account'):
|
||||||
wallet = main_screen.left_panel.open_wallet()
|
wallet = main_screen.left_panel.open_wallet()
|
||||||
@ -57,32 +49,3 @@ def test_plus_button_manage_account_added_for_new_seed(main_screen: MainWindow,
|
|||||||
if time.monotonic() - started_at > 15:
|
if time.monotonic() - started_at > 15:
|
||||||
raise LookupError(f'Account {expected_account} not found in {wallet.left_panel.accounts}')
|
raise LookupError(f'Account {expected_account} not found in {wallet.left_panel.accounts}')
|
||||||
|
|
||||||
with step('Edit wallet account'):
|
|
||||||
account_popup = wallet.left_panel.open_edit_account_popup_from_context_menu(name)
|
|
||||||
|
|
||||||
with step('Verify that error appears when name consists of less then 5 characters'):
|
|
||||||
account_popup.set_name(''.join(random.choices(string.ascii_letters +
|
|
||||||
string.digits, k=4)))
|
|
||||||
assert account_popup.get_error_message() == WalletAccountPopup.WALLET_ACCOUNT_NAME_MIN.value
|
|
||||||
|
|
||||||
account_popup.set_name(new_name).set_emoji(new_emoji).set_color(new_color).save_changes()
|
|
||||||
|
|
||||||
with step('Verify that the account is correctly displayed in accounts list'):
|
|
||||||
expected_account = constants.user.account_list_item(new_name, new_color.lower(), new_emoji_unicode)
|
|
||||||
started_at = time.monotonic()
|
|
||||||
while expected_account not in wallet.left_panel.accounts:
|
|
||||||
time.sleep(1)
|
|
||||||
if time.monotonic() - started_at > 15:
|
|
||||||
raise LookupError(f'Account {expected_account} not found in {wallet.left_panel.accounts}')
|
|
||||||
|
|
||||||
with step('Delete wallet account with agreement'):
|
|
||||||
wallet.left_panel.delete_account_from_context_menu(new_name).agree_and_confirm()
|
|
||||||
|
|
||||||
with step('Verify toast message notification when removing account'):
|
|
||||||
messages = main_screen.wait_for_notification()
|
|
||||||
assert f'"{new_name}" successfully removed' in messages, \
|
|
||||||
f"Toast message about account removal is not correct or not present. Current list of messages: {messages}"
|
|
||||||
|
|
||||||
with step('Verify that the account is not displayed in accounts list'):
|
|
||||||
assert driver.waitFor(lambda: new_name not in [account.name for account in wallet.left_panel.accounts], 10000), \
|
|
||||||
f'Account with {new_name} is still displayed even it should not be'
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user