test(suite_wallet): Created `bdd_hook` for each `suite_wallet` test case

- Created `bdd_hooks` that contain the sing up steps just only once in the feature start and the needed start steps depending on the test case.

- Updated feature files removing sign up steps and given/when/then reorganization.

Closes #8026
This commit is contained in:
Noelia 2022-10-21 09:17:48 +02:00 committed by Anthony Laibe
parent a2e6bc00dd
commit e9f84b2973
26 changed files with 366 additions and 152 deletions

View File

@ -124,10 +124,6 @@ class SettingsScreen:
click_obj_by_name(AdvancedOptionScreen.I_UNDERSTAND_POP_UP.value) click_obj_by_name(AdvancedOptionScreen.I_UNDERSTAND_POP_UP.value)
verify_object_enabled(SidebarComponents.WALLET_OPTION.value) verify_object_enabled(SidebarComponents.WALLET_OPTION.value)
def activate_open_wallet_settings(self):
self.activate_wallet_option()
self.open_wallet_settings()
def activate_open_wallet_section(self): def activate_open_wallet_section(self):
self.activate_wallet_option() self.activate_wallet_option()
click_obj_by_name(MainScreenComponents.WALLET_BUTTON.value) click_obj_by_name(MainScreenComponents.WALLET_BUTTON.value)

View File

@ -13,10 +13,12 @@ import time
from enum import Enum from enum import Enum
from drivers.SquishDriver import * from drivers.SquishDriver import *
from drivers.SquishDriverVerification import * from drivers.SquishDriverVerification import *
from drivers.SDKeyboardCommands import *
from utils.ObjectAccess import * from utils.ObjectAccess import *
import time import time
class MainScreenComponents(Enum): class MainScreenComponents(Enum):
MAIN_WINDOW = "statusDesktop_mainWindow"
PUBLIC_CHAT_ICON = "mainWindow_public_chat_icon_StatusIcon" PUBLIC_CHAT_ICON = "mainWindow_public_chat_icon_StatusIcon"
CHAT_NAVBAR_ICON = "navBarListView_Chat_navbar_StatusNavBarTabButton" CHAT_NAVBAR_ICON = "navBarListView_Chat_navbar_StatusNavBarTabButton"
COMMUNITY_PORTAL_BUTTON = "navBarListView_Communities_Portal_navbar_StatusNavBarTabButton" COMMUNITY_PORTAL_BUTTON = "navBarListView_Communities_Portal_navbar_StatusNavBarTabButton"
@ -37,6 +39,7 @@ class MainScreenComponents(Enum):
USERSTATUSMENU_AUTOMATIC_ACTION = "userContextmenu_AutomaticButton" USERSTATUSMENU_AUTOMATIC_ACTION = "userContextmenu_AutomaticButton"
USERSTATUSMENU_OPEN_PROFILE_POPUP = "userContextMenu_ViewMyProfileAction" USERSTATUSMENU_OPEN_PROFILE_POPUP = "userContextMenu_ViewMyProfileAction"
SPLASH_SCREEN = "splashScreen" SPLASH_SCREEN = "splashScreen"
TOOLBAR_BACK_BUTTON = "main_toolBar_back_button"
class ProfilePopup(Enum): class ProfilePopup(Enum):
USER_IMAGE = "ProfileHeader_userImage" USER_IMAGE = "ProfileHeader_userImage"
@ -72,7 +75,7 @@ class StatusMainScreen:
sleep_test(0.5) sleep_test(0.5)
verify_equal(loaded, False, "Checking splash screen animation has ended.") verify_equal(loaded, False, "Checking splash screen animation has ended.")
# It closes all existing banner and waits them to disappear # It closes all existing banner and waits them to disappear:
def close_banners(self): def close_banners(self):
self.wait_for_banner_to_disappear(MainScreenComponents.CONNECTION_INFO_BANNER.value) self.wait_for_banner_to_disappear(MainScreenComponents.CONNECTION_INFO_BANNER.value)
self.wait_for_banner_to_disappear(MainScreenComponents.UPDATE_APP_BANNER.value) self.wait_for_banner_to_disappear(MainScreenComponents.UPDATE_APP_BANNER.value)
@ -195,3 +198,9 @@ class StatusMainScreen:
name_changed = setText(DisplayNamePopup.DISPLAY_NAME_INPUT.value, display_name) name_changed = setText(DisplayNamePopup.DISPLAY_NAME_INPUT.value, display_name)
verify(name_changed, "set display name") verify(name_changed, "set display name")
click_obj_by_name(DisplayNamePopup.DISPLAY_NAME_OK_BUTTON.value) click_obj_by_name(DisplayNamePopup.DISPLAY_NAME_OK_BUTTON.value)
def click_escape(self):
press_escape(MainScreenComponents.MAIN_WINDOW.value)
def click_tool_bar_back_button(self):
click_obj_by_name(MainScreenComponents.TOOLBAR_BACK_BUTTON.value)

View File

@ -23,6 +23,7 @@ class MainWalletScreen(Enum):
RIGHT_SIDE_TABBAR: str = "mainWallet_Right_Side_Tab_Bar" RIGHT_SIDE_TABBAR: str = "mainWallet_Right_Side_Tab_Bar"
MAILSERVER_DIALOG: str = "mailserver_dialog" MAILSERVER_DIALOG: str = "mailserver_dialog"
MAILSERVER_RETRY: str = "mailserver_retry" MAILSERVER_RETRY: str = "mailserver_retry"
FIRST_ACCOUNT_ITEM: str = "firstWalletAccount_Item"
class AssetView(Enum): class AssetView(Enum):
LIST: str = "mainWallet_Assets_View_List" LIST: str = "mainWallet_Assets_View_List"
@ -92,6 +93,10 @@ class TransactionsView(Enum):
class StatusWalletScreen: class StatusWalletScreen:
#####################################
### Screen actions region:
#####################################
def accept_signing_phrase(self): def accept_signing_phrase(self):
click_obj_by_name(SigningPhrasePopUp.OK_GOT_IT_BUTTON.value) click_obj_by_name(SigningPhrasePopUp.OK_GOT_IT_BUTTON.value)
@ -173,11 +178,12 @@ class StatusWalletScreen:
wait_for_object_and_type(SharedPopup.PASSWORD_INPUT.value, password) wait_for_object_and_type(SharedPopup.PASSWORD_INPUT.value, password)
click_obj_by_name(SharedPopup.PRIMARY_BUTTON.value) click_obj_by_name(SharedPopup.PRIMARY_BUTTON.value)
time.sleep(5) time.sleep(5)
def verify_account_name_is_present(self, account_name: str): def verify_account_name_is_present(self, account_name: str):
verify_text_matching(MainWalletScreen.ACCOUNT_NAME.value, account_name) verify_text_matching(MainWalletScreen.ACCOUNT_NAME.value, account_name)
type(AddAccountPopup.ACCOUNT_NAME_INPUT.value, account_name)
click_obj_by_name(AddAccountPopup.ADD_ACCOUNT_BUTTON.value)
def send_transaction(self, account_name, amount, token, chain_name, password): def send_transaction(self, account_name, amount, token, chain_name, password):
# TODO wait for balance to update # TODO wait for balance to update
@ -292,8 +298,19 @@ class StatusWalletScreen:
assert False, "network name not found" assert False, "network name not found"
def click_first_account(self):
click_obj_by_name(MainWalletScreen.FIRST_ACCOUNT_ITEM.value)
#####################################
### Verifications region:
#####################################
def verify_account_name_is_present(self, account_name: str):
verify_text_matching(MainWalletScreen.ACCOUNT_NAME.value, account_name)
def verify_positive_balance(self, symbol: str): def verify_positive_balance(self, symbol: str):
time.sleep(5) # TODO: remove when it is faster @alaibe!
list = get_obj(AssetView.LIST.value) list = get_obj(AssetView.LIST.value)
reset = 0 reset = 0
while (reset < 3): while (reset < 3):

View File

@ -15,7 +15,8 @@ mainWindow_ProfileNavBarButton = {"container": statusDesktop_mainWindow, "object
settings_navbar_settings_icon_StatusIcon = {"container": mainWindow_navBarListView_ListView, "objectName": "settings-icon", "type": "StatusIcon", "visible": True} settings_navbar_settings_icon_StatusIcon = {"container": mainWindow_navBarListView_ListView, "objectName": "settings-icon", "type": "StatusIcon", "visible": True}
splashScreen = {"container": statusDesktop_mainWindow, "objectName": "splashScreen", "type": "SplashScreen"} splashScreen = {"container": statusDesktop_mainWindow, "objectName": "splashScreen", "type": "SplashScreen"}
navBarListView_Chat_navbar_StatusNavBarTabButton = {"checkable": True, "container": mainWindow_navBarListView_ListView, "objectName": "Chat-navbar", "type": "StatusNavBarTabButton", "visible": True} navBarListView_Chat_navbar_StatusNavBarTabButton = {"checkable": True, "container": mainWindow_navBarListView_ListView, "objectName": "Chat-navbar", "type": "StatusNavBarTabButton", "visible": True}
mainWindow_StatusToolBar = {"container": statusDesktop_mainWindow, "objectName": "statusToolBar", "type": "StatusToolBar", "visible": True}
main_toolBar_back_button = {"container": mainWindow_StatusToolBar, "objectName": "toolBarBackButton", "type": "StatusFlatButton", "visible": True}
# main right panel # main right panel
mainWindow_RighPanel= {"container": statusDesktop_mainWindow, "type": "ColumnLayout", "objectName": "mainRightView", "visible": True} mainWindow_RighPanel= {"container": statusDesktop_mainWindow, "type": "ColumnLayout", "objectName": "mainRightView", "visible": True}

View File

@ -1,3 +1,5 @@
import steps.startupSteps as common_init_steps
import steps.walletInitSteps as wallet_init_steps
from screens.StatusMainScreen import StatusMainScreen from screens.StatusMainScreen import StatusMainScreen
from screens.SettingsScreen import SettingsScreen from screens.SettingsScreen import SettingsScreen
@ -23,6 +25,22 @@ def step(context: any):
def step(context: any): def step(context: any):
_settingsScreen.check_tenor_gif_preview_is_enabled() _settingsScreen.check_tenor_gif_preview_is_enabled()
@Given("the user activates wallet and opens the wallet section")
def step(context: any):
wallet_init_steps.the_user_activates_wallet_and_opens_the_wallet_section()
@Given("the user toggles test networks")
def step(context: any):
wallet_init_steps.the_user_toggles_test_networks()
@Given("the user activates wallet")
def step(context: any):
the_user_activates_wallet()
@Given("the user opens the wallet settings")
def step(context: any):
the_user_opens_the_wallet_settings()
######################### #########################
### ACTIONS region: ### ACTIONS region:
######################### #########################
@ -31,10 +49,6 @@ def step(context: any):
def step(context: any): def step(context: any):
the_user_opens_app_settings_screen() the_user_opens_app_settings_screen()
@When("the user opens the wallet settings")
def step(context: any):
_settingsScreen.open_wallet_settings()
@When("the user opens the messaging settings") @When("the user opens the messaging settings")
def step(context: any): def step(context: any):
the_user_opens_the_messaging_settings() the_user_opens_the_messaging_settings()
@ -47,32 +61,28 @@ def step(context: any):
def step(context: any): def step(context: any):
_settingsScreen.activate_image_unfurling() _settingsScreen.activate_image_unfurling()
@When("the user activates wallet and opens the wallet settings") @When("the user activates wallet")
def step(context: any): def step(context: any):
_settingsScreen.activate_open_wallet_settings() the_user_activates_wallet()
@When("the user activates wallet and opens the wallet section") @When("the user opens the wallet settings")
def step(context: any): def step(context: any):
_settingsScreen.activate_open_wallet_section() the_user_opens_the_wallet_settings()
@When("the user deletes the account |any|") @When("the user deletes the account \"|any|\"")
def step(context: any, account_name: str): def step(context: any, account_name: str):
_statusMain.open_settings() _statusMain.open_settings()
_settingsScreen.delete_account(account_name) _settingsScreen.delete_account(account_name)
@When("the user toggles test networks")
def step(context: any):
_settingsScreen.toggle_test_networks()
@When("the user selects the default account") @When("the user selects the default account")
def step(context: any): def step(context: any):
_settingsScreen.select_default_account() _settingsScreen.select_default_account()
@When("the user edits default account to |any| name and |any| color") @When("the user edits default account to \"|any|\" name and \"|any|\" color")
def step(context: any, account_name: str, account_color: str): def step(context: any, account_name: str, account_color: str):
_settingsScreen.edit_account(account_name, account_color) _settingsScreen.edit_account(account_name, account_color)
@When("the user registers a random ens name with password |any|") @When("the user registers a random ens name with password \"|any|\"")
def step(context, password): def step(context, password):
_statusMain.open_settings() _statusMain.open_settings()
_settingsScreen.register_random_ens_name(password) _settingsScreen.register_random_ens_name(password)
@ -160,11 +170,11 @@ def step(context: any, oldPassword: str, newPassword: str):
def step(context: any, address: str): def step(context: any, address: str):
_settingsScreen.verify_address(address) _settingsScreen.verify_address(address)
@Then("the account |any| is not in the list of accounts") @Then("the account \"|any|\" is not in the list of accounts")
def step(context: any, account_name): def step(context: any, account_name):
_settingsScreen.verify_no_account(account_name) _settingsScreen.verify_no_account(account_name)
@Then("the new account with name |any| and color |any| is updated") @Then("the default account is updated to be named \"|any|\" with color \"|any|\"")
def step(context, new_name: str, new_color: str): def step(context, new_name: str, new_color: str):
_settingsScreen.verify_editedAccount(new_name, new_color) _settingsScreen.verify_editedAccount(new_name, new_color)
@ -223,7 +233,13 @@ def step(context, display_name):
########################################################################### ###########################################################################
def the_user_opens_app_settings_screen(): def the_user_opens_app_settings_screen():
_statusMain.open_settings() common_init_steps.the_user_opens_app_settings_screen()
def the_user_opens_the_messaging_settings(): def the_user_opens_the_messaging_settings():
_settingsScreen.open_messaging_settings() _settingsScreen.open_messaging_settings()
def the_user_activates_wallet():
wallet_init_steps.the_user_activates_wallet()
def the_user_opens_the_wallet_settings():
wallet_init_steps.the_user_opens_the_wallet_settings()

View File

@ -63,32 +63,46 @@ def a_first_time_user_lands_on_and_generates_new_key(context):
welcome_screen = StatusWelcomeScreen() welcome_screen = StatusWelcomeScreen()
welcome_screen.agree_terms_conditions_and_generate_new_key() welcome_screen.agree_terms_conditions_and_generate_new_key()
def given_a_first_time_user_lands_on_and_navigates_to_import_seed_phrase(context): def a_first_time_user_lands_on_and_navigates_to_import_seed_phrase(context):
erase_directory(context.userData[_status_data_folder]) erase_directory(context.userData[_status_data_folder])
start_application(context.userData[_aut_name]) start_application(context.userData[_aut_name])
welcome_screen = StatusWelcomeScreen() welcome_screen = StatusWelcomeScreen()
welcome_screen.agree_terms_conditions_and_navigate_to_import_seed_phrase() welcome_screen.agree_terms_conditions_and_navigate_to_import_seed_phrase()
def when_the_user_signs_up(user, password): def the_user_signs_up(user, password):
welcome_screen = StatusWelcomeScreen() welcome_screen = StatusWelcomeScreen()
welcome_screen.input_username_and_password_and_finalize_sign_up(user, password) welcome_screen.input_username_and_password_and_finalize_sign_up(user, password)
def when_the_user_lands_on_the_signed_in_app(): def the_user_lands_on_the_signed_in_app():
main_screen = StatusMainScreen() main_screen = StatusMainScreen()
main_screen.is_ready() main_screen.is_ready()
def signs_up_process_steps(context, user, password): def signs_up_process_steps(context, user, password):
a_first_time_user_lands_on_and_generates_new_key(context) a_first_time_user_lands_on_and_generates_new_key(context)
when_the_user_signs_up(user, password) the_user_signs_up(user, password)
when_the_user_lands_on_the_signed_in_app() the_user_lands_on_the_signed_in_app()
def when_the_user_joins_chat_room(_chat_room): def the_user_inputs_the_seed_phrase(seed_phrase: str):
welcome_screen = StatusWelcomeScreen()
welcome_screen.input_seed_phrase(seed_phrase)
def the_user_clicks_on_the_following_ui_component(component: str):
click_on_an_object(component)
def signs_up_with_seed_phrase_process_steps(context, seed_phrase, user, password):
a_first_time_user_lands_on_and_navigates_to_import_seed_phrase(context)
the_user_inputs_the_seed_phrase(seed_phrase)
the_user_clicks_on_the_following_ui_component("seedPhraseView_Submit_Button")
the_user_signs_up(user, password)
the_user_lands_on_the_signed_in_app()
def the_user_joins_chat_room(_chat_room):
main_screen = StatusMainScreen() main_screen = StatusMainScreen()
main_screen.join_chat_room(_chat_room) main_screen.join_chat_room(_chat_room)
chat_screen = StatusChatScreen() chat_screen = StatusChatScreen()
chat_screen.verify_chat_title(_chat_room) chat_screen.verify_chat_title(_chat_room)
def when_the_user_opens_the_chat_section(): def the_user_opens_the_chat_section():
main_screen = StatusMainScreen() main_screen = StatusMainScreen()
main_screen.open_chat_section() main_screen.open_chat_section()
@ -122,5 +136,8 @@ def the_user_logs_in(username: str, password: str):
def login_process_steps(context, user, password, data_dir_path): def login_process_steps(context, user, password, data_dir_path):
a_user_starts_the_application_with_a_specific_data_folder(context, data_dir_path) a_user_starts_the_application_with_a_specific_data_folder(context, data_dir_path)
the_user_logs_in(user, password) the_user_logs_in(user, password)
when_the_user_lands_on_the_signed_in_app() the_user_lands_on_the_signed_in_app()
def the_user_opens_app_settings_screen():
main_screen = StatusMainScreen()
main_screen.open_settings()

View File

@ -39,6 +39,10 @@ def step(context):
def step(context, room): def step(context, room):
the_user_joins_chat_room(room) the_user_joins_chat_room(room)
@Given("the user clicks on escape key")
def step(context):
_statusMain.click_escape()
######################### #########################
### ACTIONS region: ### ACTIONS region:
######################### #########################
@ -52,8 +56,8 @@ def step(context, text, obj):
input_text(text, obj) input_text(text, obj)
@When("user clicks on the following ui-component |any|") @When("user clicks on the following ui-component |any|")
def step(context, obj): def step(context: any, obj: str):
click_on_an_object(obj) the_user_clicks_on_the_following_ui_component(obj)
@When("the user joins chat room \"|any|\"") @When("the user joins chat room \"|any|\"")
def step(context, room): def step(context, room):
@ -77,4 +81,4 @@ def the_user_restarts_the_app(context: any):
startApplication(context.userData["aut_name"]) startApplication(context.userData["aut_name"])
def the_user_joins_chat_room(room: str): def the_user_joins_chat_room(room: str):
when_the_user_joins_chat_room(room) the_user_joins_chat_room(room)

View File

@ -0,0 +1,48 @@
"""It defines wallet specific starting-up or driving-the-app-into-an-idle-state static methods outside bdd context
that can be reused in different `hooks` as well as in specific bdd steps files."""
import steps.startupSteps as common_init_steps
from screens.StatusMainScreen import StatusMainScreen
from screens.SettingsScreen import SettingsScreen
from screens.StatusWalletScreen import StatusWalletScreen
def the_user_activates_wallet_and_opens_the_wallet_section():
settings_screen = SettingsScreen()
settings_screen.activate_open_wallet_section()
def the_user_accepts_the_signing_phrase():
wallet_screen = StatusWalletScreen()
wallet_screen.accept_signing_phrase()
def activate_and_open_wallet():
common_init_steps.the_user_opens_app_settings_screen()
the_user_activates_wallet_and_opens_the_wallet_section()
the_user_accepts_the_signing_phrase()
def the_user_activates_wallet():
settings_screen = SettingsScreen()
settings_screen.activate_wallet_option()
def the_user_opens_the_wallet_settings():
settings_screen = SettingsScreen()
settings_screen.open_wallet_settings()
def enable_wallet_section():
common_init_steps.the_user_opens_app_settings_screen()
the_user_activates_wallet()
def the_user_toggles_test_networks():
settings_screen = SettingsScreen()
settings_screen.toggle_test_networks()
main_screen = StatusMainScreen()
main_screen.click_tool_bar_back_button()
def the_user_opens_wallet_screen():
main_screen = StatusMainScreen()
main_screen.open_wallet()
def toggle_test_networks():
the_user_opens_the_wallet_settings()
the_user_toggles_test_networks()
the_user_opens_wallet_screen()
the_user_accepts_the_signing_phrase()

View File

@ -23,8 +23,8 @@ _method = "bottom_menu"
def hook(context): def hook(context):
init_steps.context_init(context) init_steps.context_init(context)
init_steps.signs_up_process_steps(context, _user, _password) init_steps.signs_up_process_steps(context, _user, _password)
init_steps.when_the_user_joins_chat_room(_chat_room1) init_steps.the_user_joins_chat_room(_chat_room1)
init_steps.when_the_user_joins_chat_room(_chat_room2) init_steps.the_user_joins_chat_room(_chat_room2)
init_steps.the_user_opens_the_community_portal_section() init_steps.the_user_opens_the_community_portal_section()
init_steps.the_user_lands_on_the_community_portal_section() init_steps.the_user_lands_on_the_community_portal_section()
init_steps.the_user_creates_a_community(_community_name, _community_description, _community_intro, _community_outro) init_steps.the_user_creates_a_community(_community_name, _community_description, _community_intro, _community_outro)

View File

@ -258,7 +258,7 @@ def the_group_chat_is_created():
_statusChat = StatusChatScreen() _statusChat = StatusChatScreen()
def the_user_opens_the_chat_section(): def the_user_opens_the_chat_section():
when_the_user_opens_the_chat_section() the_user_opens_the_chat_section()
def the_user_sends_a_random_chat_message(context): def the_user_sends_a_random_chat_message(context):
random_int = randint(0, 10000) random_int = randint(0, 10000)

View File

@ -13,7 +13,7 @@ _chat_room = "test"
def hook(context): def hook(context):
context_init(context) context_init(context)
signs_up_process_steps(context, _user, _password) signs_up_process_steps(context, _user, _password)
when_the_user_joins_chat_room(_chat_room) the_user_joins_chat_room(_chat_room)
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
@ -22,7 +22,7 @@ def hook(context):
@OnScenarioStart @OnScenarioStart
def hook(context): def hook(context):
when_the_user_opens_the_chat_section() the_user_opens_the_chat_section()
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -4,7 +4,7 @@
sys.path.append(os.path.join(os.path.dirname(__file__), "../../../testSuites/global_shared/")) sys.path.append(os.path.join(os.path.dirname(__file__), "../../../testSuites/global_shared/"))
sys.path.append(os.path.join(os.path.dirname(__file__), "../../../src/")) sys.path.append(os.path.join(os.path.dirname(__file__), "../../../src/"))
# from steps.chatSteps import * import steps.startupSteps as init_steps
# Global properties for the specific feature # Global properties for the specific feature
_user = "tester123" _user = "tester123"
@ -13,8 +13,8 @@ _data_folder_path = "../../../fixtures/mutual_contacts"
@OnFeatureStart @OnFeatureStart
def hook(context): def hook(context):
context_init(context) init_steps,context_init(context)
login_process_steps(context, _user, _password, _data_folder_path) init_steps.login_process_steps(context, _user, _password, _data_folder_path)
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
@ -23,7 +23,7 @@ def hook(context):
@OnScenarioStart @OnScenarioStart
def hook(context): def hook(context):
when_the_user_opens_the_chat_section() init_steps.the_user_opens_the_chat_section()
@OnScenarioEnd @OnScenarioEnd
def hook(context): def hook(context):

View File

@ -15,11 +15,11 @@ def step(context):
@Given("A first time user lands on the status desktop and navigates to import seed phrase") @Given("A first time user lands on the status desktop and navigates to import seed phrase")
def step(context): def step(context):
given_a_first_time_user_lands_on_and_navigates_to_import_seed_phrase(context) a_first_time_user_lands_on_and_navigates_to_import_seed_phrase(context)
@Given("the user lands on the signed in app") @Given("the user lands on the signed in app")
def step(context): def step(context):
when_the_user_lands_on_the_signed_in_app() the_user_lands_on_the_signed_in_app()
######################### #########################
### ACTIONS region: ### ACTIONS region:
@ -27,15 +27,15 @@ def step(context):
@When("user signs up with username \"|any|\" and password \"|any|\"") @When("user signs up with username \"|any|\" and password \"|any|\"")
def step(context, username, password): def step(context, username, password):
when_the_user_signs_up(username, password) the_user_signs_up(username, password)
@When("the user inputs username |any|") @When("the user inputs username |any|")
def step(context, username): def step(context, username):
_welcomeScreen.input_username(username) _welcomeScreen.input_username(username)
@When("The user inputs the seed phrase |any|") @When("The user inputs the seed phrase \"|any|\"")
def step(context, seed_phrase): def step(context, seed_phrase):
_welcomeScreen.input_seed_phrase(seed_phrase) the_user_inputs_the_seed_phrase(seed_phrase)
@When("the user logs in with password |any|") @When("the user logs in with password |any|")
def step(context, password: str): def step(context, password: str):
@ -55,7 +55,7 @@ def step(context):
@Then("the user lands on the signed in app") @Then("the user lands on the signed in app")
def step(context): def step(context):
when_the_user_lands_on_the_signed_in_app() the_user_lands_on_the_signed_in_app()
@Then("the invalid seed text is visible") @Then("the invalid seed text is visible")
def step(context): def step(context):

View File

@ -120,7 +120,7 @@ Feature: Status Desktop Sign Up
Scenario Outline: User signs up with imported seed phrase Scenario Outline: User signs up with imported seed phrase
Given A first time user lands on the status desktop and navigates to import seed phrase Given A first time user lands on the status desktop and navigates to import seed phrase
When The user inputs the seed phrase <seed> When The user inputs the seed phrase "<seed>"
And user clicks on the following ui-component seedPhraseView_Submit_Button And user clicks on the following ui-component seedPhraseView_Submit_Button
When user signs up with username "tester123" and password "TesTEr16843/!@00" When user signs up with username "tester123" and password "TesTEr16843/!@00"
Then the user lands on the signed in app Then the user lands on the signed in app
@ -134,7 +134,7 @@ Feature: Status Desktop Sign Up
Scenario: User signs up with wrong imported seed phrase Scenario: User signs up with wrong imported seed phrase
Given A first time user lands on the status desktop and navigates to import seed phrase Given A first time user lands on the status desktop and navigates to import seed phrase
When The user inputs the seed phrase truth gold urban vital rose market legal release border gospel leave potato When The user inputs the seed phrase "truth gold urban vital rose market legal release border gospel leave potato"
And user clicks on the following ui-component seedPhraseView_Submit_Button And user clicks on the following ui-component seedPhraseView_Submit_Button
Then the following ui-component seedPhraseView_Submit_Button is not enabled Then the following ui-component seedPhraseView_Submit_Button is not enabled
And the invalid seed text is visible And the invalid seed text is visible

View File

@ -16,7 +16,8 @@ Feature: Status Desktop Settings Menu
@merge @mayfail @merge @mayfail
Scenario: User can backup seed phrase Scenario: User can backup seed phrase
When the user activates wallet and opens the wallet settings When the user activates wallet
And the user opens the wallet settings
And the user backs up the wallet seed phrase And the user backs up the wallet seed phrase
Then the backup seed phrase indicator is not displayed Then the backup seed phrase indicator is not displayed

View File

@ -14,6 +14,10 @@ mainWallet_Right_Side_Tab_Bar = {"container": statusDesktop_mainWindow, "objectN
mailserver_dialog = {"container": statusDesktop_mainWindow_overlay, "objectName": "mailserverConnectionDialog", "type": "StatusDialog"} mailserver_dialog = {"container": statusDesktop_mainWindow_overlay, "objectName": "mailserverConnectionDialog", "type": "StatusDialog"}
mailserver_retry = {"container": mailserver_dialog, "objectName": "mailserverConnectionDialog_retryButton", "type": "StatusButton"} mailserver_retry = {"container": mailserver_dialog, "objectName": "mailserverConnectionDialog_retryButton", "type": "StatusButton"}
accounts_StatusListView = {"container": statusDesktop_mainWindow, "objectName": "walletAccountsListView", "type": "StatusListView", "visible": True}
firstWalletAccount_Item = {"container": accounts_StatusListView, "index": 0, "objectName": "walletAccountItem", "type": "StatusListItem", "visible": True}
# Assets view: # Assets view:
mainWallet_Assets_View_List = {"container": statusDesktop_mainWindow, "objectName": "assetViewStatusListView", "type": "StatusListView"} mainWallet_Assets_View_List = {"container": statusDesktop_mainWindow, "objectName": "assetViewStatusListView", "type": "StatusListView"}

View File

@ -1,3 +1,5 @@
import steps.walletInitSteps as wallet_init_steps
from screens.StatusMainScreen import StatusMainScreen from screens.StatusMainScreen import StatusMainScreen
from screens.StatusWalletScreen import StatusWalletScreen from screens.StatusWalletScreen import StatusWalletScreen
from scripts.decorators import verify_screenshot from scripts.decorators import verify_screenshot
@ -6,64 +8,77 @@ from common.Common import str_to_bool
_statusMain = StatusMainScreen() _statusMain = StatusMainScreen()
_walletScreen = StatusWalletScreen() _walletScreen = StatusWalletScreen()
@When("the user opens wallet screen") #########################
def step(context): ### PRECONDITIONS region:
_statusMain.open_wallet() #########################
@When("the user accepts the signing phrase") @Given("the user accepts the signing phrase")
def step(context): def step(context):
_walletScreen.accept_signing_phrase() the_user_accepts_the_signing_phrase()
@When("the user adds watch only account with |any| and |any|") @Given("the user clicks on the first account")
def step(context):
_walletScreen.click_first_account()
@Given("the user opens wallet screen")
def step(context):
wallet_init_steps.the_user_opens_wallet_screen()
#########################
### ACTIONS region:
#########################
@When("the user adds watch only account \"|any|\" named \"|any|\"")
@verify_screenshot @verify_screenshot
def step(context, account_name, address): def step(context, address, account_name):
_walletScreen.add_watch_only_account(account_name, address) _walletScreen.add_watch_only_account(account_name, address)
@When("the user generates a new account with |any| and |any|") @When("an account named \"|any|\" is generated and authenticated using password \"|any|\"")
def step(context, account_name, password): def step(context, account_name, password):
_walletScreen.generate_new_account(account_name, password) _walletScreen.generate_new_account(account_name, password)
@When("the user imports a private key with |any| and |any| and |any|") @When("an account named \"|any|\" is added via private key \"|any|\" and authenticated using password \"|any|\"")
def step(context, account_name, password, private_key): def step(context, account_name, private_key, password):
_walletScreen.import_private_key(account_name, password, private_key) _walletScreen.import_private_key(account_name, password, private_key)
@When("the user imports a seed phrase with |any| and |any| and |any|") @When("an account named \"|any|\" is added via imported seed phrase \"|any|\" and authenticated using password \"|any|\"")
def step(context, account_name, password, mnemonic): def step(context, account_name, mnemonic, password):
_walletScreen.import_seed_phrase(account_name, password, mnemonic) _walletScreen.import_seed_phrase(account_name, password, mnemonic)
@When("the user sends a transaction to himself from account |any| of |any| |any| on |any| with password |any|") @When("the user sends a transaction to himself from account \"|any|\" of \"|any|\" \"|any|\" on \"|any|\" with password \"|any|\"")
def step(context, account_name, amount, token, chain_name, password): def step(context, account_name, amount, token, chain_name, password):
_walletScreen.send_transaction(account_name, amount, token, chain_name, password) _walletScreen.send_transaction(account_name, amount, token, chain_name, password)
@When("the user adds a saved address named |any| and address |any|") @When("the user adds a saved address named \"|any|\" and address \"|any|\"")
def step(context, name, address): def step(context, name, address):
_walletScreen.add_saved_address(name, address) _walletScreen.add_saved_address(name, address)
@When("the user edits a saved address with name |any| to |any|") @When("the user edits a saved address with name \"|any|\" to \"|any|\"")
def step(context, name, new_name): def step(context, name, new_name):
_walletScreen.edit_saved_address(name, new_name) _walletScreen.edit_saved_address(name, new_name)
@When("the user deletes the saved address with name |any|") @When("the user deletes the saved address with name \"|any|\"")
def step(context, name): def step(context, name):
_walletScreen.delete_saved_address(name) _walletScreen.delete_saved_address(name)
@When("the user toggles favourite for the saved address with name |any|") @When("the user toggles favourite for the saved address with name \"|any|\"")
def step(context, name): def step(context, name):
_walletScreen.toggle_favourite_for_saved_address(name) _walletScreen.toggle_favourite_for_saved_address(name)
@Then("the saved address |any| has favourite status |any|")
def step(context, name, favourite):
_walletScreen.check_favourite_status_for_saved_address(name, str_to_bool(favourite))
@When("the user toggles the network |any|") @When("the user toggles the network |any|")
def step(context, network_name): def step(context, network_name):
_walletScreen.toggle_network(network_name) _walletScreen.toggle_network(network_name)
@Then("the user has a positive balance of |any|")
#########################
### VERIFICATIONS region:
#########################
@Then("the user has a positive balance of \"|any|\"")
def step(context, symbol): def step(context, symbol):
_walletScreen.verify_positive_balance(symbol) _walletScreen.verify_positive_balance(symbol)
@Then("the new account |any| is added") @Then("the new account \"|any|\" is added")
def step(context, account_name): def step(context, account_name):
_walletScreen.verify_account_name_is_present(account_name) _walletScreen.verify_account_name_is_present(account_name)
@ -71,11 +86,11 @@ def step(context, account_name):
def step(context): def step(context):
_walletScreen.verify_transaction() _walletScreen.verify_transaction()
@Then("the name |any| is in the list of saved addresses") @Then("the name \"|any|\" is in the list of saved addresses")
def step(context, name: str): def step(context, name: str):
_walletScreen.verify_saved_address_exists(name) _walletScreen.verify_saved_address_exists(name)
@Then("the name |any| is not in the list of saved addresses") @Then("the name \"|any|\" is not in the list of saved addresses")
def step(context, name: str): def step(context, name: str):
_walletScreen.verify_saved_address_doesnt_exist(name) _walletScreen.verify_saved_address_doesnt_exist(name)
@ -86,3 +101,11 @@ def step(context, account_name: str):
@Then("the transactions are listed for the added account") @Then("the transactions are listed for the added account")
def step(context): def step(context):
_walletScreen.verify_transactions_exist() _walletScreen.verify_transactions_exist()
@Then("the saved address \"|any|\" has favourite status \"|any|\"")
def step(context, name, favourite):
_walletScreen.check_favourite_status_for_saved_address(name, str_to_bool(favourite))
###########################################################################
### COMMON methods used in different steps given/when/then region:
###########################################################################

View File

@ -0,0 +1,29 @@
# -*- coding: utf-8 -*-
# This file contains hook functions to run as the .feature file is executed
sys.path.append(os.path.join(os.path.dirname(__file__), "../../../testSuites/global_shared/"))
sys.path.append(os.path.join(os.path.dirname(__file__), "../../../src/"))
import steps.startupSteps as common_init_steps
import steps.walletInitSteps as wallet_init_steps
# Global properties for the specific feature
_user = "tester123"
_password = "qqqqqqqqqq"
_seed_phrase = "pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial"
@OnFeatureStart
def hook(context):
common_init_steps.context_init(context)
common_init_steps.signs_up_with_seed_phrase_process_steps(context, _seed_phrase, _user, _password)
wallet_init_steps.enable_wallet_section()
wallet_init_steps.toggle_test_networks()
@OnFeatureEnd
def hook(context):
currentApplicationContext().detach()
snooze(_app_closure_timeout)
@OnStepEnd
def hook(context):
context.userData["step_name"] = context._data["text"]

View File

@ -1,22 +1,29 @@
Feature: Status Desktop Transaction Feature: Status Desktop Transaction
As a user I want to perform transaction As a user I want to perform transactions
Background: Sign up & Enable wallet section & Toggle test networks The feature start sequence is the following (setup on its own `bdd_hooks`):
Given A first time user lands on the status desktop and navigates to import seed phrase
When The user inputs the seed phrase pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial ** given A first time user lands on the status desktop and navigates to import seed phrase
And user clicks on the following ui-component seedPhraseView_Submit_Button ** and the user inputs the seed phrase "pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial"
When user signs up with username "tester123" and password "qqqqqqqqqq" ** and the user clicks on the following ui-component seedPhraseView_Submit_Button
Then the user lands on the signed in app ** and the user signs up with username "tester123" and password "qqqqqqqqqq"
When the user opens app settings screen ** and the user lands on the signed in app
And the user activates wallet and opens the wallet settings ** and the user opens app settings screen
And the user toggles test networks ** and the user activates wallet
And the user opens wallet screen ** and the user opens the wallet settings
And the user accepts the signing phrase ** and the user toggles test networks
** and the user opens wallet screen
** and the user accepts the signing phrase
Background: Navigation to main wallet screen
Given the user opens wallet screen
And the user clicks on the first account
@mayfail @mayfail
Scenario Outline: User sends a transaction Scenario Outline: The user sends a transaction
When the user sends a transaction to himself from account Status account of <amount> <token> on <chain_name> with password qqqqqqqqqq When the user sends a transaction to himself from account "Status account" of "<amount>" "<token>" on "<chain_name>" with password "qqqqqqqqqq"
Then the transaction is in progress Then the transaction is in progress
Examples: Examples:
@ -27,6 +34,6 @@ Feature: Status Desktop Transaction
| 0 | STT | Goerli | | 0 | STT | Goerli |
@mayfail @mayfail
Scenario: User registers a ENS name Scenario: The user registers an ENS name
When the user registers a random ens name with password qqqqqqqqqq When the user registers a random ens name with password "qqqqqqqqqq"
Then the transaction is in progress Then the transaction is in progress

View File

@ -1,7 +1,7 @@
source(findFile('scripts', 'python/bdd.py')) source(findFile('scripts', 'python/bdd.py'))
setupHooks('../../global_shared/scripts/bdd_hooks.py') setupHooks('bdd_hooks.py')
collectStepDefinitions('./steps', '../shared/steps/', '../../global_shared/steps/', '../../suite_onboarding/shared/steps/') collectStepDefinitions('./steps', '../shared/steps/', '../../global_shared/steps/')
def main(): def main():
testSettings.throwOnFailure = True testSettings.throwOnFailure = True

View File

@ -0,0 +1,27 @@
# -*- coding: utf-8 -*-
# This file contains hook functions to run as the .feature file is executed
sys.path.append(os.path.join(os.path.dirname(__file__), "../../../testSuites/global_shared/"))
sys.path.append(os.path.join(os.path.dirname(__file__), "../../../src/"))
import steps.startupSteps as common_init_steps
import steps.walletInitSteps as wallet_init_steps
# Global properties for the specific feature
_user = "tester123"
_password = "TesTEr16843/!@00"
@OnFeatureStart
def hook(context):
context_init(context)
common_init_steps.signs_up_process_steps(context, _user, _password)
wallet_init_steps.activate_and_open_wallet()
@OnFeatureEnd
def hook(context):
currentApplicationContext().detach()
snooze(_app_closure_timeout)
@OnStepEnd
def hook(context):
context.userData["step_name"] = context._data["text"]

View File

@ -2,56 +2,67 @@ Feature: Status Desktop Wallet
As a user I want to use the wallet As a user I want to use the wallet
Background: Sign up & Enable wallet section The feature start sequence is the following (setup on its own `bdd_hooks`):
Given A first time user lands on the status desktop and generates new key
When user signs up with username "tester123" and password "TesTEr16843/!@00"
Then the user lands on the signed in app
When the user opens app settings screen
When the user activates wallet and opens the wallet section
When the user accepts the signing phrase
** given A first time user lands on the status desktop and generates new key
** when user signs up with username "tester123" and password "TesTEr16843/!@00"
** and the user lands on the signed in app
Scenario: User can observe an account data ** given the user opens app settings screen
When the user opens app settings screen ** and the user activates wallet and opens the wallet section
** and the user accepts the signing phrase
Background: Navigation to main wallet screen
Given the user opens wallet screen
And the user clicks on the first account
Scenario: The user can import seed phrase and observe an account data
Given the user opens app settings screen
And the user opens the wallet settings And the user opens the wallet settings
And the user toggles test networks And the user toggles test networks
And the user opens wallet screen And the user opens wallet screen
And the user imports a seed phrase with one and TesTEr16843/!@00 and pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial When an account named "one" is added via imported seed phrase "pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial" and authenticated using password "TesTEr16843/!@00"
Then the new account one is added Then the new account "one" is added
And the user has a positive balance of ETH And the user has a positive balance of "ETH"
And the user has a positive balance of STT And the user has a positive balance of "STT"
# And the collectibles are listed for the one # And the collectibles are listed for the on
And the transactions are listed for the added account And the transactions are listed for the added account
Scenario: The user can manage a watch only account
When the user adds watch only account "0x8397bc3c5a60a1883174f722403d63a8833312b7" named "AccountWatch"
Then the new account "AccountWatch" is added
Scenario: User can manage a list of accounts Scenario: The user imports a private key
When the user adds watch only account with AccountWatch and 0x8397bc3c5a60a1883174f722403d63a8833312b7 When an account named "AccountPrivate" is added via private key "8da4ef21b864d2cc526dbdb2a120bd2874c36c9d0a1fb7f8c63d7f7a8b41de8f" and authenticated using password "TesTEr16843/!@00"
Then the new account AccountWatch is added Then the new account "AccountPrivate" is added
When the user imports a private key with AccountPrivate and TesTEr16843/!@00 and 8da4ef21b864d2cc526dbdb2a120bd2874c36c9d0a1fb7f8c63d7f7a8b41de8f
Then the new account AccountPrivate is added @mayfail
When the user imports a seed phrase with AccountSeed and TesTEr16843/!@00 and pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial Scenario: The user generates a new account from wallet and deletes it
Then the new account AccountSeed is added When an account named "AccountGenerated" is generated and authenticated using password "TesTEr16843/!@00"
When the user generates a new account with AccountGenerated and TesTEr16843/!@00 Then the new account "AccountGenerated" is added
Then the new account AccountGenerated is added
When the user deletes the account AccountGenerated When the user deletes the account "AccountGenerated"
Then the account AccountGenerated is not in the list of accounts Then the account "AccountGenerated" is not in the list of accounts
When the user opens app settings screen
Scenario: The user edits the default account
Given the user opens app settings screen
And the user opens the wallet settings And the user opens the wallet settings
And the user selects the default account When the user selects the default account
And the user edits default account to Default name and #FFCA0F color And the user edits default account to "Default" name and "#FFCA0F" color
Then the new account with name DefaultStatus account and color #FFCA0F is updated Then the default account is updated to be named "DefaultStatus account" with color "#FFCA0F"
Scenario Outline: The user can manage a saved address
When the user adds a saved address named "<name>" and address "<address>"
And the user toggles favourite for the saved address with name "<name>"
Then the saved address "<name>" has favourite status "true"
Scenario Outline: User can manage a saved address When the user deletes the saved address with name "<name>"
When the user adds a saved address named <name> and address <address> Then the name "<name>" is not in the list of saved addresses
And the user toggles favourite for the saved address with name <name>
Then the saved address <name> has favourite status true
When the user deletes the saved address with name <name>
Then the name <name> is not in the list of saved addresses
When the user adds a saved address named <name> and address <address>
And the user edits a saved address with name <name> to <new_name>
Then the name <new_name><name> is in the list of saved addresses
When the user adds a saved address named "<name>" and address "<address>"
And the user edits a saved address with name "<name>" to "<new_name>"
Then the name "<new_name><name>" is in the list of saved addresses
Examples: Examples:
| name | address | new_name | | name | address | new_name |
| bar | 0x8397bc3c5a60a1883174f722403d63a8833312b7 | foo | | bar | 0x8397bc3c5a60a1883174f722403d63a8833312b7 | foo |

View File

@ -1,7 +1,7 @@
source(findFile('scripts', 'python/bdd.py')) source(findFile('scripts', 'python/bdd.py'))
setupHooks('../../global_shared/scripts/bdd_hooks.py') setupHooks('bdd_hooks.py')
collectStepDefinitions('./steps', '../shared/steps/', '../../global_shared/steps/', '../../suite_onboarding/shared/steps/') collectStepDefinitions('./steps', '../shared/steps/', '../../global_shared/steps/')
def main(): def main():
testSettings.throwOnFailure = True testSettings.throwOnFailure = True

View File

@ -17,6 +17,7 @@ ToolBar {
signal backButtonClicked() signal backButtonClicked()
signal notificationButtonClicked() signal notificationButtonClicked()
objectName: "statusToolBar"
implicitWidth: visible ? 518 : 0 implicitWidth: visible ? 518 : 0
implicitHeight: visible ? 56 : 0 implicitHeight: visible ? 56 : 0
padding: 4 padding: 4
@ -27,6 +28,7 @@ ToolBar {
anchors.rightMargin: 4 anchors.rightMargin: 4
spacing: 0 spacing: 0
StatusFlatButton { StatusFlatButton {
objectName: "toolBarBackButton"
icon.name: "arrow-left" icon.name: "arrow-left"
icon.width: 20 icon.width: 20
icon.height: 20 icon.height: 20

View File

@ -103,6 +103,7 @@ Rectangle {
} }
StatusListView { StatusListView {
objectName: "walletAccountsListView"
spacing: Style.current.smallPadding spacing: Style.current.smallPadding
Layout.fillWidth: true Layout.fillWidth: true
Layout.fillHeight: true Layout.fillHeight: true
@ -111,6 +112,7 @@ Rectangle {
// ScrollBar.horizontal.policy: ScrollBar.AlwaysOff // ScrollBar.horizontal.policy: ScrollBar.AlwaysOff
delegate: StatusListItem { delegate: StatusListItem {
objectName: "walletAccountItem"
width: ListView.view.width width: ListView.view.width
highlighted: RootStore.currentAccount.name === model.name highlighted: RootStore.currentAccount.name === model.name
title: model.name title: model.name