- "id": "edit" removed in object names
- closing app improves via waiting for close context
- attempts added for unstable actions on UI
- detach application with waiting for process close added
This commit is contained in:
Vladimir Druzhinin 2023-06-02 16:34:09 +02:00 committed by GitHub
parent a0a5e6d219
commit a1f3485f98
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
23 changed files with 128 additions and 88 deletions

View File

@ -46,7 +46,7 @@ class ExecutableAut(AbstractAut):
self.fp = fp self.fp = fp
def start(self, *args) -> 'ExecutableAut': def start(self, *args) -> 'ExecutableAut':
cmd = ' '.join([self.fp.name] + [str(arg) for arg in args]) cmd = ' '.join([self.fp.name] + list(args))
self.ctx = squish.startApplication(cmd) self.ctx = squish.startApplication(cmd)
local_system.wait_for_started(self.fp.stem) local_system.wait_for_started(self.fp.stem)
assert squish.waitFor(lambda: self.ctx.isRunning, configs.squish.APP_LOAD_TIMEOUT_MSEC) assert squish.waitFor(lambda: self.ctx.isRunning, configs.squish.APP_LOAD_TIMEOUT_MSEC)

View File

@ -2,9 +2,10 @@ import time
import configs import configs
import squish import squish
import utils
def attach(aut_name: str, timeout_sec: int = 30): def attach(aut_name: str, timeout_sec: int = configs.squish.PROCESS_TIMEOUT_SEC):
print(f'Attaching squish to {aut_name}') print(f'Attaching squish to {aut_name}')
started_at = time.monotonic() started_at = time.monotonic()
while True: while True:
@ -15,13 +16,14 @@ def attach(aut_name: str, timeout_sec: int = 30):
except RuntimeError as err: except RuntimeError as err:
print(err) print(err)
time.sleep(1) time.sleep(1)
assert time.monotonic() - started_at > timeout_sec, f'Attach error: {aut_name}' assert time.monotonic() - started_at < timeout_sec, f'Attach error: {aut_name}'
def detach(): def detach(timeout_sec: int = configs.squish.PROCESS_TIMEOUT_SEC):
for ctx in squish.applicationContextList(): for ctx in squish.applicationContextList():
started_at = time.monotonic()
ctx.detach() ctx.detach()
assert squish.waitFor( while ctx.isRunning and time.monotonic() - started_at < timeout_sec:
lambda: not ctx.isRunning, configs.squish.PROCESS_TIMEOUT_MSEC), 'Detach application failed' time.sleep(1)
# TODO: close by ctx.pid and then detach
time.sleep(5) utils.local_system.kill_process(configs.path.AUT.name)

View File

@ -25,6 +25,10 @@ class BaseElement:
def existent(self): def existent(self):
return squish.waitForObjectExists(self.object_name, configs.squish.UI_LOAD_TIMEOUT_MSEC) return squish.waitForObjectExists(self.object_name, configs.squish.UI_LOAD_TIMEOUT_MSEC)
@property
def exists(self):
return object.exists(self.object_name)
@property @property
def bounds(self) -> squish.UiTypes.ScreenRectangle: def bounds(self) -> squish.UiTypes.ScreenRectangle:
return object.globalBounds(self.object) return object.globalBounds(self.object)
@ -72,6 +76,7 @@ class BaseElement:
def hover(self): def hover(self):
squish.mouseMove(self.center.x, self.center.y) squish.mouseMove(self.center.x, self.center.y)
return self
def open_context_menu( def open_context_menu(
self, self,

View File

@ -3,6 +3,7 @@ import time
import sys import sys
from drivers.SquishDriver import * from drivers.SquishDriver import *
from drivers.SquishDriverVerification import * from drivers.SquishDriverVerification import *
from utils.decorators import attempt
class MainCommunityPortalScreen(Enum): class MainCommunityPortalScreen(Enum):
CREATE_COMMUNITY_BUTTON: str = "communitiesPortalLayoutContainer_createCommunityButton_StatusButton" CREATE_COMMUNITY_BUTTON: str = "communitiesPortalLayoutContainer_createCommunityButton_StatusButton"
@ -22,11 +23,19 @@ class StatusCommunityPortalScreen:
def __init__(self): def __init__(self):
verify_screen(MainCommunityPortalScreen.CREATE_COMMUNITY_BUTTON.value) verify_screen(MainCommunityPortalScreen.CREATE_COMMUNITY_BUTTON.value)
@attempt(2)
def open_create_community_bunner(self):
click_obj_by_name(MainCommunityPortalScreen.CREATE_COMMUNITY_BUTTON.value)
BaseElement(MainCommunityPortalScreen.CREATE_COMMUNITY_BANNER_BUTTON.value).wait_until_appears()
@attempt(2)
def open_create_community_popup(self):
click_obj_by_name(MainCommunityPortalScreen.CREATE_COMMUNITY_BANNER_BUTTON.value)
BaseElement(CreateCommunityPopup.COMMUNITY_NAME_INPUT.value).wait_until_appears()
def create_community(self, communityName: str, communityDescription: str, introMessage: str, outroMessage: str): def create_community(self, communityName: str, communityDescription: str, introMessage: str, outroMessage: str):
click_obj_by_name(MainCommunityPortalScreen.CREATE_COMMUNITY_BUTTON.value) self.open_create_community_bunner()
self.open_create_community_popup()
click_obj_by_name(MainCommunityPortalScreen.CREATE_COMMUNITY_BANNER_BUTTON.value)
type_text(CreateCommunityPopup.COMMUNITY_NAME_INPUT.value, communityName) type_text(CreateCommunityPopup.COMMUNITY_NAME_INPUT.value, communityName)
type_text(CreateCommunityPopup.COMMUNITY_DESCRIPTION_INPUT.value, communityDescription) type_text(CreateCommunityPopup.COMMUNITY_DESCRIPTION_INPUT.value, communityDescription)

View File

@ -160,9 +160,16 @@ class StatusCommunityScreen:
return result return result
def _open_edit_channel_popup(self): def _open_edit_channel_popup(self, attempt: int = 2):
click_obj_by_name(CommunityScreenComponents.CHAT_MORE_OPTIONS_BUTTON.value) click_obj_by_name(CommunityScreenComponents.CHAT_MORE_OPTIONS_BUTTON.value)
click_obj_by_name(CommunityScreenComponents.EDIT_CHANNEL_MENU_ITEM.value) click_obj_by_name(CommunityScreenComponents.EDIT_CHANNEL_MENU_ITEM.value)
try:
TextEdit(CreateOrEditCommunityChannelPopup.COMMUNITY_CHANNEL_NAME_INPUT.value).wait_until_appears()
except:
if attempt:
self._open_edit_channel_popup(attempt-1)
else:
raise err
def _open_category_edit_popup(self, category): def _open_category_edit_popup(self, category):
# For some reason it clicks on a first channel in category instead of category # For some reason it clicks on a first channel in category instead of category
@ -205,8 +212,7 @@ class StatusCommunityScreen:
self._open_edit_channel_popup() self._open_edit_channel_popup()
# Select all text in the input before typing # Select all text in the input before typing
wait_for_object_and_type(CreateOrEditCommunityChannelPopup.COMMUNITY_CHANNEL_NAME_INPUT.value, "<Ctrl+a>") TextEdit(CreateOrEditCommunityChannelPopup.COMMUNITY_CHANNEL_NAME_INPUT.value).text = new_community_channel_name
type_text(CreateOrEditCommunityChannelPopup.COMMUNITY_CHANNEL_NAME_INPUT.value, new_community_channel_name)
click_obj_by_name(CreateOrEditCommunityChannelPopup.COMMUNITY_CHANNEL_SAVE_OR_CREATE_BUTTON.value) click_obj_by_name(CreateOrEditCommunityChannelPopup.COMMUNITY_CHANNEL_SAVE_OR_CREATE_BUTTON.value)
time.sleep(0.5) time.sleep(0.5)
@ -314,10 +320,16 @@ class StatusCommunityScreen:
def go_back_to_community(self): def go_back_to_community(self):
click_obj_by_name(CommunitySettingsComponents.BACK_TO_COMMUNITY_BUTTON.value) click_obj_by_name(CommunitySettingsComponents.BACK_TO_COMMUNITY_BUTTON.value)
def delete_current_community_channel(self): def delete_current_community_channel(self, attempt: int = 2):
click_obj_by_name(CommunityScreenComponents.CHAT_MORE_OPTIONS_BUTTON.value) try:
click_obj_by_name(CommunityScreenComponents.DELETE_CHANNEL_MENU_ITEM.value) BaseElement(CommunityScreenComponents.CHAT_MORE_OPTIONS_BUTTON.value).click()
click_obj_by_name(CommunityScreenComponents.DELETE_CHANNEL_CONFIRMATION_DIALOG_DELETE_BUTTON.value) BaseElement(CommunityScreenComponents.DELETE_CHANNEL_MENU_ITEM.value).click()
BaseElement(CommunityScreenComponents.DELETE_CHANNEL_CONFIRMATION_DIALOG_DELETE_BUTTON.value).click()
except:
if attempt:
delete_current_community_channel(attempt-1)
else:
raise
def check_channel_count(self, count_to_check: int): def check_channel_count(self, count_to_check: int):
chatListObj = get_obj(CommunityScreenComponents.NOT_CATEGORIZED_CHAT_LIST.value) chatListObj = get_obj(CommunityScreenComponents.NOT_CATEGORIZED_CHAT_LIST.value)

View File

@ -142,9 +142,16 @@ class LeftPanel(BaseElement):
else: else:
raise raise
def open_add_account_popup(self): def open_add_account_popup(self, attempt: int = 2):
self._add_account_button.click() self._add_account_button.click()
return AccountPopup().wait_until_appears() try:
return AccountPopup().wait_until_appears()
except AssertionError as err:
if attempt:
self._open_add_account_popup(attempt-1)
else:
raise err
def delete_account(self, account_name: str, attempt: int = 2) -> RemoveWalletAccountPopup: def delete_account(self, account_name: str, attempt: int = 2) -> RemoveWalletAccountPopup:
try: try:
@ -418,15 +425,19 @@ class StatusWalletScreen:
def verify_account_existence(self, name: str, color: str, emoji_unicode: str): def verify_account_existence(self, name: str, color: str, emoji_unicode: str):
expected_account = constants.wallet.account_list_item(name, color.lower(), emoji_unicode) expected_account = constants.wallet.account_list_item(name, color.lower(), emoji_unicode)
started_at = time.monotonic() started_at = time.monotonic()
while not expected_account in self.left_panel.accounts: while expected_account not in self.left_panel.accounts:
time.sleep(1) time.sleep(1)
if time.monotonic() - started_at > 10: if time.monotonic() - started_at > 15:
raise LookupError(f'Account {expected_account} not found in {self.left_panel.accounts}') raise LookupError(f'Account {expected_account} not found in {self.left_panel.accounts}')
def verify_account_doesnt_exist(self, name: str): def verify_account_doesnt_exist(self, name: str):
assert name not in [account.name for account in self.left_panel.accounts], \ assert wait_for(name not in [account.name for account in self.left_panel.accounts], 10000), \
f'Account with {name} is still displayed even it should not be' f'Account with {name} is still displayed even it should not be'
def verify_account_exist(self, name: str):
assert wait_for(name in [account.name for account in self.left_panel.accounts], 10000), \
f'Account with {name} is not displayed even it should be'
def verify_account_address_correct(self, account_name: str, address: str): def verify_account_address_correct(self, account_name: str, address: str):
actual_address = self.left_panel.select_account(account_name).address actual_address = self.left_panel.select_account(account_name).address
assert actual_address.lower() == address.lower(), f'Account {account_name} has unexpected address {actual_address}' assert actual_address.lower() == address.lower(), f'Account {account_name} has unexpected address {actual_address}'

View File

@ -10,10 +10,16 @@ class AuthenticatePopup(BaseElement):
self._primary_button = Button('sharedPopup_Primary_Button') self._primary_button = Button('sharedPopup_Primary_Button')
self._cancel_buttom = Button('sharedPopup_Cancel_Button') self._cancel_buttom = Button('sharedPopup_Cancel_Button')
def authenticate(self, password: str = constants.user_account.PASSWORD): def authenticate(self, password: str = constants.user_account.PASSWORD, attempt: int = 2):
self._password_text_edit.text = password self._password_text_edit.text = password
self._primary_button.click() self._primary_button.click()
self._primary_button.wait_until_hidden() try:
self._primary_button.wait_until_hidden()
except AssertionError as err:
if attempt:
self.authenticate(password, attempt-1)
else:
raise err
def cancel(self): def cancel(self):
self._cancel_buttom.click() self._cancel_buttom.click()

View File

@ -175,7 +175,7 @@ class AccountPopup(BasePopup):
return self return self
def set_derivation_path(self, value: str, index: int): def set_derivation_path(self, value: str, index: int):
self._edit_derivation_path_button.click() self._edit_derivation_path_button.hover().click()
AuthenticatePopup().wait_until_appears().authenticate() AuthenticatePopup().wait_until_appears().authenticate()
if value in [_.value for _ in constants.wallet.DerivationPath]: if value in [_.value for _ in constants.wallet.DerivationPath]:
self._derivation_path_combobox_button.click() self._derivation_path_combobox_button.click()

View File

@ -85,7 +85,7 @@ placeholder_StatusBaseText = {"container": statusDesktop_mainWindow_overlay, "id
o_StatusBackButton = {"container": statusDesktop_mainWindow_overlay, "type": "StatusBackButton", "unnamed": 1, "visible": True} o_StatusBackButton = {"container": statusDesktop_mainWindow_overlay, "type": "StatusBackButton", "unnamed": 1, "visible": True}
add_StatusButton = {"checkable": False, "container": statusDesktop_mainWindow_overlay, "type": "StatusButton", "unnamed": 1, "visible": True} add_StatusButton = {"checkable": False, "container": statusDesktop_mainWindow_overlay, "type": "StatusButton", "unnamed": 1, "visible": True}
linksView = {"container": statusDesktop_mainWindow, "id": "linksView", "type": "StatusListView", "unnamed": 1, "visible": True} linksView = {"container": statusDesktop_mainWindow, "id": "linksView", "type": "StatusListView", "unnamed": 1, "visible": True}
edit_TextEdit = {"container": statusDesktop_mainWindow_overlay, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} edit_TextEdit = {"container": statusDesktop_mainWindow_overlay, "type": "TextEdit", "unnamed": 1, "visible": True}
# Wallet Settings: # Wallet Settings:
mainWallet_Saved_Addreses_More_Edit = {"container": statusDesktop_mainWindow, "objectName": "editroot", "type": "StatusMenuItem"} mainWallet_Saved_Addreses_More_Edit = {"container": statusDesktop_mainWindow, "objectName": "editroot", "type": "StatusMenuItem"}

View File

@ -89,7 +89,7 @@ addAccountPopup_OriginOption_StatusListItem = {"container": statusDesktop_mainWi
mainWallet_AddEditAccountPopup_OriginOptionWatchOnlyAcc = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-OriginOption-LABEL-OPTION-ADD-WATCH-ONLY-ACC", "type": "StatusListItem", "visible": True} mainWallet_AddEditAccountPopup_OriginOptionWatchOnlyAcc = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-OriginOption-LABEL-OPTION-ADD-WATCH-ONLY-ACC", "type": "StatusListItem", "visible": True}
mainWallet_AddEditAccountPopup_AccountWatchOnlyAddressComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-WatchOnlyAddress", "type": "StatusInput", "visible": True} mainWallet_AddEditAccountPopup_AccountWatchOnlyAddressComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-WatchOnlyAddress", "type": "StatusInput", "visible": True}
mainWallet_AddEditAccountPopup_AccountWatchOnlyAddress = {"container": mainWallet_AddEditAccountPopup_AccountWatchOnlyAddressComponent, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} mainWallet_AddEditAccountPopup_AccountWatchOnlyAddress = {"container": mainWallet_AddEditAccountPopup_AccountWatchOnlyAddressComponent, "type": "TextEdit", "unnamed": 1, "visible": True}
mainWallet_AddEditAccountPopup_EditDerivationPathButton = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-EditDerivationPath", "type": "StatusButton", "visible": True} mainWallet_AddEditAccountPopup_EditDerivationPathButton = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-EditDerivationPath", "type": "StatusButton", "visible": True}
mainWallet_AddEditAccountPopup_ResetDerivationPathButton = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-ResetDerivationPath", "type": "StatusLinkText", "enabled": True, "visible": True} mainWallet_AddEditAccountPopup_ResetDerivationPathButton = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-ResetDerivationPath", "type": "StatusLinkText", "enabled": True, "visible": True}
mainWallet_AddEditAccountPopup_DerivationPathInputComponent = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-DerivationPathInput", "type": "DerivationPathInput", "visible": True} mainWallet_AddEditAccountPopup_DerivationPathInputComponent = {"container": statusDesktop_mainWindow, "objectName": "AddAccountPopup-DerivationPathInput", "type": "DerivationPathInput", "visible": True}
@ -107,11 +107,11 @@ mainWallet_AddEditAccountPopup_MasterKey_GenerateSeedPhraseOption = {"container"
mainWallet_AddEditAccountPopup_MasterKey_GoToKeycardSettingsOption = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-GoToKeycardSettings", "type": "StatusButton", "visible": True} mainWallet_AddEditAccountPopup_MasterKey_GoToKeycardSettingsOption = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-GoToKeycardSettings", "type": "StatusButton", "visible": True}
mainWallet_AddEditAccountPopup_PrivateKey = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-PrivateKeyInput", "type": "StatusPasswordInput", "visible": True} mainWallet_AddEditAccountPopup_PrivateKey = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-PrivateKeyInput", "type": "StatusPasswordInput", "visible": True}
mainWallet_AddEditAccountPopup_PrivateKeyNameComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-PrivateKeyName", "type": "StatusInput", "visible": True} mainWallet_AddEditAccountPopup_PrivateKeyNameComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-PrivateKeyName", "type": "StatusInput", "visible": True}
mainWallet_AddEditAccountPopup_PrivateKeyName = {"container": mainWallet_AddEditAccountPopup_PrivateKeyNameComponent, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} mainWallet_AddEditAccountPopup_PrivateKeyName = {"container": mainWallet_AddEditAccountPopup_PrivateKeyNameComponent, "type": "TextEdit", "unnamed": 1, "visible": True}
mainWallet_AddEditAccountPopup_ImportedSeedPhraseKeyNameComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-ImportedSeedPhraseKeyName", "type": "StatusInput", "visible": True} mainWallet_AddEditAccountPopup_ImportedSeedPhraseKeyNameComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-ImportedSeedPhraseKeyName", "type": "StatusInput", "visible": True}
mainWallet_AddEditAccountPopup_ImportedSeedPhraseKeyName = {"container": mainWallet_AddEditAccountPopup_ImportedSeedPhraseKeyNameComponent, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} mainWallet_AddEditAccountPopup_ImportedSeedPhraseKeyName = {"container": mainWallet_AddEditAccountPopup_ImportedSeedPhraseKeyNameComponent, "type": "TextEdit", "unnamed": 1, "visible": True}
mainWallet_AddEditAccountPopup_GeneratedSeedPhraseKeyNameComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-GeneratedSeedPhraseKeyName", "type": "StatusInput", "visible": True} mainWallet_AddEditAccountPopup_GeneratedSeedPhraseKeyNameComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-GeneratedSeedPhraseKeyName", "type": "StatusInput", "visible": True}
mainWallet_AddEditAccountPopup_GeneratedSeedPhraseKeyName = {"container": mainWallet_AddEditAccountPopup_GeneratedSeedPhraseKeyNameComponent, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} mainWallet_AddEditAccountPopup_GeneratedSeedPhraseKeyName = {"container": mainWallet_AddEditAccountPopup_GeneratedSeedPhraseKeyNameComponent, "type": "TextEdit", "unnamed": 1, "visible": True}
mainWallet_AddEditAccountPopup_HavePenAndPaperCheckBox = {"checkable": True, "container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-HavePenAndPaper", "type": "StatusCheckBox", "visible": True} mainWallet_AddEditAccountPopup_HavePenAndPaperCheckBox = {"checkable": True, "container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-HavePenAndPaper", "type": "StatusCheckBox", "visible": True}
mainWallet_AddEditAccountPopup_SeedPhraseWrittenCheckBox = {"checkable": True, "container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-SeedPhraseWritten", "type": "StatusCheckBox", "visible": True} mainWallet_AddEditAccountPopup_SeedPhraseWrittenCheckBox = {"checkable": True, "container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-SeedPhraseWritten", "type": "StatusCheckBox", "visible": True}
mainWallet_AddEditAccountPopup_StoringSeedPhraseConfirmedCheckBox = {"checkable": True, "container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-StoringSeedPhraseConfirmed", "type": "StatusCheckBox", "visible": True} mainWallet_AddEditAccountPopup_StoringSeedPhraseConfirmedCheckBox = {"checkable": True, "container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-StoringSeedPhraseConfirmed", "type": "StatusCheckBox", "visible": True}
@ -119,7 +119,7 @@ mainWallet_AddEditAccountPopup_SeedBackupAknowledgeCheckBox = {"checkable": True
mainWallet_AddEditAccountPopup_RevealSeedPhraseButton = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-RevealSeedPhrase", "type": "StatusButton", "visible": True} mainWallet_AddEditAccountPopup_RevealSeedPhraseButton = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-RevealSeedPhrase", "type": "StatusButton", "visible": True}
mainWallet_AddEditAccountPopup_SeedPhraseWordAtIndex_Placeholder = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "SeedPhraseWordAtIndex-%WORD-INDEX%", "type": "StatusSeedPhraseInput", "visible": True} mainWallet_AddEditAccountPopup_SeedPhraseWordAtIndex_Placeholder = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "SeedPhraseWordAtIndex-%WORD-INDEX%", "type": "StatusSeedPhraseInput", "visible": True}
mainWallet_AddEditAccountPopup_EnterSeedPhraseWordComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-EnterSeedPhraseWord", "type": "StatusInput", "visible": True} mainWallet_AddEditAccountPopup_EnterSeedPhraseWordComponent = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "AddAccountPopup-EnterSeedPhraseWord", "type": "StatusInput", "visible": True}
mainWallet_AddEditAccountPopup_EnterSeedPhraseWord = {"container": mainWallet_AddEditAccountPopup_EnterSeedPhraseWordComponent, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} mainWallet_AddEditAccountPopup_EnterSeedPhraseWord = {"container": mainWallet_AddEditAccountPopup_EnterSeedPhraseWordComponent, "type": "TextEdit", "unnamed": 1, "visible": True}
confirmSeedPhrasePanel_StatusSeedPhraseInput = {"container": statusDesktop_mainWindow, "type": "StatusSeedPhraseInput", "visible": True} confirmSeedPhrasePanel_StatusSeedPhraseInput = {"container": statusDesktop_mainWindow, "type": "StatusSeedPhraseInput", "visible": True}
mainWallet_AddEditAccountPopup_SPWord = {"container": mainWallet_AddEditAccountPopup_Content, "type": "TextEdit", "objectName": RegularExpression("statusSeedPhraseInputField*")} mainWallet_AddEditAccountPopup_SPWord = {"container": mainWallet_AddEditAccountPopup_Content, "type": "TextEdit", "objectName": RegularExpression("statusSeedPhraseInputField*")}
mainWallet_AddEditAccountPopup_12WordsButton = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "12SeedButton", "type": "StatusSwitchTabButton"} mainWallet_AddEditAccountPopup_12WordsButton = {"container": mainWallet_AddEditAccountPopup_Content, "objectName": "12SeedButton", "type": "StatusSwitchTabButton"}
@ -153,7 +153,7 @@ mainWallet_AddEditAccountPopup_SPWord_24 = {"container": mainWallet_AddEditAccou
# Remove account popup: # Remove account popup:
mainWallet_Remove_Account_Popup_Account_Notification = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-Notification", "type": "StatusBaseText", "visible": True} mainWallet_Remove_Account_Popup_Account_Notification = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-Notification", "type": "StatusBaseText", "visible": True}
mainWallet_Remove_Account_Popup_Account_Path_Component = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-DerivationPath", "type": "StatusInput", "visible": True} mainWallet_Remove_Account_Popup_Account_Path_Component = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-DerivationPath", "type": "StatusInput", "visible": True}
mainWallet_Remove_Account_Popup_Account_Path = {"container": mainWallet_Remove_Account_Popup_Account_Path_Component, "id": "edit", "type": "TextEdit", "unnamed": 1, "visible": True} mainWallet_Remove_Account_Popup_Account_Path = {"container": mainWallet_Remove_Account_Popup_Account_Path_Component, "type": "TextEdit", "unnamed": 1, "visible": True}
mainWallet_Remove_Account_Popup_HavePenPaperCheckBox = {"checkable": True, "container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-HavePenPaper", "type": "StatusCheckBox", "visible": True} mainWallet_Remove_Account_Popup_HavePenPaperCheckBox = {"checkable": True, "container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-HavePenPaper", "type": "StatusCheckBox", "visible": True}
mainWallet_Remove_Account_Popup_ConfirmButton = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-ConfirmButton", "type": "StatusButton", "visible": True} mainWallet_Remove_Account_Popup_ConfirmButton = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-ConfirmButton", "type": "StatusButton", "visible": True}
mainWallet_Remove_Account_Popup_CancelButton = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-CancelButton", "type": "StatusFlatButton", "visible": True} mainWallet_Remove_Account_Popup_CancelButton = {"container": statusDesktop_mainWindow, "objectName": "RemoveAccountPopup-CancelButton", "type": "StatusFlatButton", "visible": True}

View File

@ -17,8 +17,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -17,8 +17,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -68,6 +68,7 @@ Feature: Status Desktop community messages
| message | reply | | message | reply |
| Community chat message | This is a reply | | Community chat message | This is a reply |
@mayfail
Scenario Outline: The user can edit a message Scenario Outline: The user can edit a message
Given the user sends a chat message "Edit me" Given the user sends a chat message "Edit me"
# Checking that message can be edited several times # Checking that message can be edited several times
@ -87,6 +88,7 @@ Feature: Status Desktop community messages
| message | | message |
| random chat message | | random chat message |
@mayfail
Scenario: The user can clear chat history Scenario: The user can clear chat history
Given the user sends a chat message "Hi hi" Given the user sends a chat message "Hi hi"
And the user sends a chat message "testing chat" And the user sends a chat message "testing chat"

View File

@ -17,8 +17,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -34,8 +34,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -18,8 +18,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -17,8 +17,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -14,7 +14,7 @@ def hook(context):
@OnScenarioEnd @OnScenarioEnd
def hook(context): def hook(context):
[ctx.detach() for ctx in squish.applicationContextList()] init_steps.driver.detach()
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -74,12 +74,11 @@ def step(context, private_key, name, color, emoji):
@verify_screenshot @verify_screenshot
def step(context, seed_phrase, name, color, emoji): def step(context, seed_phrase, name, color, emoji):
account_popup = _walletScreen.left_panel.open_add_account_popup() account_popup = _walletScreen.left_panel.open_add_account_popup()
account_popup \ account_popup.set_name(name)
.set_name(name) \ account_popup.set_emoji(emoji)
.set_emoji(emoji) \ account_popup.set_color(color)
.set_color(color) \ account_popup.set_origin_seed_phrase(seed_phrase.split())
.set_origin_seed_phrase(seed_phrase.split()) \ account_popup.save()
.save()
AuthenticatePopup().wait_until_appears().authenticate() AuthenticatePopup().wait_until_appears().authenticate()
account_popup.wait_until_hidden() account_popup.wait_until_hidden()
@ -88,36 +87,33 @@ def step(context, seed_phrase, name, color, emoji):
@verify_screenshot @verify_screenshot
def step(context, name, color, emoji, derivation_path, generated_address_index): def step(context, name, color, emoji, derivation_path, generated_address_index):
account_popup = _walletScreen.left_panel.open_add_account_popup() account_popup = _walletScreen.left_panel.open_add_account_popup()
account_popup \ account_popup.set_name(name)
.set_name(name) \ account_popup.set_emoji(emoji)
.set_emoji(emoji) \ account_popup.set_color(color)
.set_color(color) \ account_popup.set_derivation_path(derivation_path, generated_address_index)
.set_derivation_path(derivation_path, generated_address_index) \ account_popup.save()
.save()
@When("the user adds to \"|any|\" a custom generated account with \"|any|\" color \"|any|\" emoji \"|any|\" and derivation \"|any|\" \"|any|\"") @When("the user adds to \"|any|\" a custom generated account with \"|any|\" color \"|any|\" emoji \"|any|\" and derivation \"|any|\" \"|any|\"")
@verify_screenshot @verify_screenshot
def step(context, keypair_name, name, color, emoji, derivation_path, generated_address_index): def step(context, keypair_name, name, color, emoji, derivation_path, generated_address_index):
account_popup = _walletScreen.left_panel.open_add_account_popup() account_popup = _walletScreen.left_panel.open_add_account_popup()
account_popup \ account_popup.set_name(name)
.set_name(name) \ account_popup.set_emoji(emoji)
.set_emoji(emoji) \ account_popup.set_color(color)
.set_color(color) \ account_popup.set_derivation_path(derivation_path, generated_address_index)
.set_derivation_path(derivation_path, generated_address_index) \ account_popup.set_origin_keypair(keypair_name)
.set_origin_keypair(keypair_name) \ account_popup.save()
.save()
@When( @When(
"the user adds a generated seed phrase account with \"|any|\" color \"|any|\" emoji \"|any|\" and keypair \"|any|\"") "the user adds a generated seed phrase account with \"|any|\" color \"|any|\" emoji \"|any|\" and keypair \"|any|\"")
def step(context, name, color, emoji, keypair_name): def step(context, name, color, emoji, keypair_name):
account_popup = _walletScreen.left_panel.open_add_account_popup() account_popup = _walletScreen.left_panel.open_add_account_popup()
account_popup \ account_popup.set_name(name)
.set_name(name) \ account_popup.set_emoji(emoji)
.set_emoji(emoji) \ account_popup.set_color(color)
.set_color(color) \ account_popup.set_origin_new_seed_phrase(keypair_name)
.set_origin_new_seed_phrase(keypair_name) \ account_popup.save()
.save()
AuthenticatePopup().wait_until_appears().authenticate() AuthenticatePopup().wait_until_appears().authenticate()
account_popup.wait_until_hidden() account_popup.wait_until_hidden()
@ -131,7 +127,10 @@ def step(context):
@When("the user edits an account with \"|any|\" to \"|any|\" with color \"|any|\" and emoji \"|any|\"") @When("the user edits an account with \"|any|\" to \"|any|\" with color \"|any|\" and emoji \"|any|\"")
def step(context, name, new_name, new_color, new_emoji): def step(context, name, new_name, new_color, new_emoji):
account_popup = _walletScreen.left_panel.open_edit_account_popup(name) account_popup = _walletScreen.left_panel.open_edit_account_popup(name)
account_popup.set_name(new_name).set_emoji(new_emoji).set_color(new_color).save() account_popup.set_name(new_name)
account_popup.set_emoji(new_emoji)
account_popup.set_color(new_color)
account_popup.save()
@When("the user removes account \"|any|\"") @When("the user removes account \"|any|\"")
@ -190,15 +189,22 @@ def step(context, network_name):
def step(context, name, color, emoji_unicode): def step(context, name, color, emoji_unicode):
_walletScreen.verify_account_existence(name, color, emoji_unicode) _walletScreen.verify_account_existence(name, color, emoji_unicode)
@Then("settings keycard section is opened") @Then("settings keycard section is opened")
def step(context): def step(context):
_walletScreen.verify_keycard_settings_is_opened() _walletScreen.verify_keycard_settings_is_opened()
@Then("the account with \"|any|\" is not displayed") @Then("the account with \"|any|\" is not displayed")
def step(context, name): def step(context, name):
_walletScreen.verify_account_doesnt_exist(name) _walletScreen.verify_account_doesnt_exist(name)
@Then("the account with \"|any|\" is displayed")
def step(context, name):
_walletScreen.verify_account_exist(name)
@Then("the user has a positive balance of \"|any|\"") @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)

View File

@ -21,8 +21,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):

View File

@ -22,8 +22,7 @@ def hook(context):
@OnFeatureEnd @OnFeatureEnd
def hook(context): def hook(context):
currentApplicationContext().detach() init_steps.driver.detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd

View File

@ -1,5 +1,6 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
# This file contains hook functions to run as the .feature file is executed # This file contains hook functions to run as the .feature file is executed
import time
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/"))
@ -17,12 +18,6 @@ def hook(context):
init_steps.context_init(context, testSettings) init_steps.context_init(context, testSettings)
@OnFeatureEnd
def hook(context):
currentApplicationContext().detach()
snooze(_app_closure_timeout)
@OnStepEnd @OnStepEnd
def hook(context): def hook(context):
context.userData["step_name"] = context._data["text"] context.userData["step_name"] = context._data["text"]
@ -35,4 +30,5 @@ def hook(context):
@OnScenarioEnd @OnScenarioEnd
def hook(context): def hook(context):
[ctx.detach() for ctx in squish.applicationContextList()] init_steps.driver.detach()

View File

@ -62,7 +62,6 @@ Feature: Status Desktop Wallet Section Wallet Account Management
| name | color | emoji | emoji_unicode | add_via_context_menu | | name | color | emoji | emoji_unicode | add_via_context_menu |
| GenAcc1 | 2946C4 | sunglasses | 1f60e | yes | | GenAcc1 | 2946C4 | sunglasses | 1f60e | yes |
@mayfail
Scenario Outline: The user manages a custom generated account Scenario Outline: The user manages a custom generated account
When the user adds a custom generated account with "<name>" color "#<color>" emoji "<emoji>" and derivation "<path>" "<address_index>" When the user adds a custom generated account with "<name>" color "#<color>" emoji "<emoji>" and derivation "<path>" "<address_index>"
Then the account is correctly displayed with "<name>" and "#<color>" and emoji unicode "<emoji_unicode>" in accounts list Then the account is correctly displayed with "<name>" and "#<color>" and emoji unicode "<emoji_unicode>" in accounts list
@ -90,7 +89,6 @@ Feature: Status Desktop Wallet Section Wallet Account Management
| private_key | name | color | emoji | emoji_unicode | new_name | new_color | new_emoji | new_emoji_unicode | | private_key | name | color | emoji | emoji_unicode | new_name | new_color | new_emoji | new_emoji_unicode |
| 2daa36a3abe381a9c01610bf10fda272fbc1b8a22179a39f782c512346e3e470 | PrivKeyAcc1 | 2946C4 | sunglasses | 1f60e | PrivKeyAcc1edited | 7CDA00 | thumbsup | 1f44d | | 2daa36a3abe381a9c01610bf10fda272fbc1b8a22179a39f782c512346e3e470 | PrivKeyAcc1 | 2946C4 | sunglasses | 1f60e | PrivKeyAcc1edited | 7CDA00 | thumbsup | 1f44d |
@mayfail
Scenario Outline: The user manages a seed phrase imported account Scenario Outline: The user manages a seed phrase imported account
When the user adds an imported seed phrase account "<seed_phrase>" with "<name>" color "#<color>" and emoji "<emoji>" When the user adds an imported seed phrase account "<seed_phrase>" with "<name>" color "#<color>" and emoji "<emoji>"
Then the account is correctly displayed with "<name>" and "#<color>" and emoji unicode "<emoji_unicode>" in accounts list Then the account is correctly displayed with "<name>" and "#<color>" and emoji unicode "<emoji_unicode>" in accounts list
@ -105,10 +103,10 @@ Feature: Status Desktop Wallet Section Wallet Account Management
| kitten tiny cup admit cactus shrug shuffle accident century faith roof plastic beach police barely vacant sign blossom | SPAcc18 | 2946C4 | sunglasses | 1f60e | SPAcc18edited | 7CDA00 | thumbsup | 1f44d | | kitten tiny cup admit cactus shrug shuffle accident century faith roof plastic beach police barely vacant sign blossom | SPAcc18 | 2946C4 | sunglasses | 1f60e | SPAcc18edited | 7CDA00 | thumbsup | 1f44d |
| pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial | SPAcc12 | 2946C4 | sunglasses | 1f60e | SPAcc12edited | 7CDA00 | thumbsup | 1f44d | | pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial | SPAcc12 | 2946C4 | sunglasses | 1f60e | SPAcc12edited | 7CDA00 | thumbsup | 1f44d |
@mayfail
Scenario Outline: The user manages an account created from the imported seed phrase Scenario Outline: The user manages an account created from the imported seed phrase
When the user adds an imported seed phrase account "pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial" with "SPAcc12" color "#2946C4" and emoji "sunglasses" When the user adds an imported seed phrase account "pelican chief sudden oval media rare swamp elephant lawsuit wheat knife initial" with "SPAcc12" color "#2946C4" and emoji "sunglasses"
And the user adds to "pcsomrselw" a custom generated account with "<name>" color "#<color>" emoji "<emoji>" and derivation "<path>" "<address_index>" Then the account with "SPAcc12" is displayed
When the user adds to "pcsomrselw" a custom generated account with "<name>" color "#<color>" emoji "<emoji>" and derivation "<path>" "<address_index>"
And the user removes account "<name>" with agreement And the user removes account "<name>" with agreement
Then the account with "<name>" is not displayed Then the account with "<name>" is not displayed
@ -133,7 +131,8 @@ Feature: Status Desktop Wallet Section Wallet Account Management
Scenario Outline: The user manages an account created from the generated seed phrase Scenario Outline: The user manages an account created from the generated seed phrase
When the user adds a generated seed phrase account with "SPKeyPair" color "#<color>" emoji "<emoji>" and keypair "<keypair_name>" When the user adds a generated seed phrase account with "SPKeyPair" color "#<color>" emoji "<emoji>" and keypair "<keypair_name>"
And the user adds to "<keypair_name>" a custom generated account with "<name>" color "#<color>" emoji "<emoji>" and derivation "<path>" "<address_index>" Then the account with "SPKeyPair" is displayed
When the user adds to "<keypair_name>" a custom generated account with "<name>" color "#<color>" emoji "<emoji>" and derivation "<path>" "<address_index>"
Then the account is correctly displayed with "<name>" and "#<color>" and emoji unicode "<emoji_unicode>" in accounts list Then the account is correctly displayed with "<name>" and "#<color>" and emoji unicode "<emoji_unicode>" in accounts list
When the user removes account "<name>" with agreement When the user removes account "<name>" with agreement
Then the account with "<name>" is not displayed Then the account with "<name>" is not displayed