e2e: added key pair test

This commit is contained in:
Yevheniia Berdnyk 2024-11-29 16:20:47 +02:00
parent 2b7430e008
commit 1faa2e8f88
No known key found for this signature in database
4 changed files with 153 additions and 4 deletions

View File

@ -9,6 +9,7 @@ from views.sign_in_view import SignInView
@pytest.mark.xdist_group(name="new_six_2") @pytest.mark.xdist_group(name="new_six_2")
@marks.nightly @marks.nightly
@marks.secured
class TestFallbackMultipleDevice(MultipleSharedDeviceTestCase): class TestFallbackMultipleDevice(MultipleSharedDeviceTestCase):
def prepare_devices(self): def prepare_devices(self):
@ -159,6 +160,94 @@ class TestFallbackMultipleDevice(MultipleSharedDeviceTestCase):
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(741054)
def test_fallback_add_key_pair(self):
account_to_add = transaction_senders['ETH_1']
self.home_1.navigate_back_to_home_view()
self.home_2.navigate_back_to_home_view()
wallet_1 = self.home_1.wallet_tab.click()
wallet_2 = self.home_2.wallet_tab.click()
regular_account_name = "New regular account"
key_pair_account_name = "Key pair account"
key_pair_name = "New key pair"
key_pair_account_address = '0x' + account_to_add['address'].lower()
wallet_1.just_fyi("Device 1: add a new regular account")
regular_derivation_path = wallet_1.add_regular_account(account_name=regular_account_name)
regular_account_wallet_address = wallet_1.get_account_address().split(':')[-1]
account_element = wallet_1.get_account_element(account_name=regular_account_name)
wallet_1.close_account_button.click_until_presence_of_element(account_element)
wallet_1.just_fyi("Device 1: add a new key pair account")
account_element.swipe_left_on_element()
key_pair_derivation_path = wallet_1.add_key_pair_account(account_name=key_pair_account_name,
passphrase=account_to_add['passphrase'],
key_pair_name=key_pair_name)
self.home_2.just_fyi("Device 2: check imported accounts are shown before importing key pair")
self.home_2.profile_button.click()
self.profile_2.profile_wallet_button.click()
self.profile_2.key_pairs_and_accounts_button.click()
if not self.profile_2.get_missing_key_pair_by_name(key_pair_name=key_pair_name).is_element_displayed():
self.errors.append("Key pair is not shown in profile as missing before importing")
if not self.profile_2.get_key_pair_account_by_name(account_name=regular_account_name).is_element_displayed():
self.errors.append(
"Newly added regular account is not shown in profile as on device before importing key pair")
self.profile_2.options_button.click()
if not self.profile_2.import_by_entering_recovery_phrase_button.is_element_displayed():
self.errors.append("Can not import key pair account from profile")
self.profile_2.click_system_back_button(times=4)
wallet_2.just_fyi("Device 2: import key pair")
wallet_2.get_account_element(account_name=key_pair_account_name).click()
wallet_2.element_by_translation_id("import-key-pair").click()
self.sign_in_2.passphrase_edit_box.send_keys(account_to_add['passphrase'])
wallet_2.slide_and_confirm_with_password()
self.home_2.just_fyi("Device 2: check imported accounts are shown in profile as added after importing key pair")
self.home_2.profile_button.click()
self.profile_2.profile_wallet_button.click()
self.profile_2.key_pairs_and_accounts_button.click()
if self.profile_2.get_key_pair_account_by_name(account_name=regular_account_name).is_element_displayed():
address_text = self.profile_2.get_key_pair_account_by_name(account_name=regular_account_name).address.text
if address_text != '...'.join((regular_account_wallet_address[:5], regular_account_wallet_address[-3:])):
self.errors.append(
"Incorrect wallet address if shown for regular account after importing: " + address_text)
else:
self.errors.append("Newly added regular account is not shown in profile after importing key pair")
if self.profile_2.get_key_pair_account_by_name(account_name=key_pair_account_name).is_element_displayed():
address_text = self.profile_2.get_key_pair_account_by_name(account_name=key_pair_account_name).address.text
if address_text != '...'.join((key_pair_account_address[:5], key_pair_account_address[-3:])):
self.errors.append(
"Incorrect wallet address if shown for key pair account after importing: " + address_text)
else:
self.errors.append("Key pair account is not shown in profile as on device after importing key pair")
self.profile_2.click_system_back_button(times=3)
wallet_2.just_fyi("Device 2: check wallet balance")
wallet_2.select_network(network_name='Arbitrum')
expected_balance = self.network_api.get_balance(key_pair_account_address)
shown_balance = wallet_2.get_asset(asset_name='Ether').get_amount()
if shown_balance != round(expected_balance, 5):
self.errors.append("Device 2: ETH balance %s doesn't match expected %s" % (shown_balance, expected_balance))
wallet_2.just_fyi("Device 2: check derivation paths of the regular and key pair accounts")
account_element = wallet_2.get_account_element(account_name=regular_account_name)
account_element.click()
wallet_2.about_tab.click()
der_path = wallet_2.account_about_derivation_path_text.text
if der_path != regular_derivation_path:
self.errors.append("Incorrect derivation path %s is shown for the regular account" % der_path)
wallet_2.close_account_button.click_until_presence_of_element(account_element)
account_element.swipe_left_on_element()
wallet_2.get_account_element(account_name=key_pair_account_name).click()
wallet_2.about_tab.click()
der_path = wallet_2.account_about_derivation_path_text.text
if der_path != key_pair_derivation_path:
self.errors.append("Incorrect derivation path %s is shown for the key pair account" % der_path)
self.errors.verify_no_errors()
@marks.testrail_id(740222) @marks.testrail_id(740222)
def test_fallback_validate_seed_phrase(self): def test_fallback_validate_seed_phrase(self):
self.sign_in_2.reopen_app(sign_in=False) self.sign_in_2.reopen_app(sign_in=False)

View File

@ -256,10 +256,7 @@ class TestWalletOneDevice(MultipleSharedDeviceTestCase):
if self.wallet_view.account_name_text.text != new_account_name: if self.wallet_view.account_name_text.text != new_account_name:
pytest.fail("New account is not created") pytest.fail("New account is not created")
self.wallet_view.account_emoji_button.click_until_presence_of_element(self.wallet_view.copy_address_button) new_wallet_address = self.wallet_view.get_account_address()
self.wallet_view.share_address_button.click()
new_wallet_address = self.wallet_view.sharing_text_native.text
self.wallet_view.click_system_back_button()
self.wallet_view.close_account_button.click_until_presence_of_element(self.home_view.show_qr_code_button) self.wallet_view.close_account_button.click_until_presence_of_element(self.home_view.show_qr_code_button)
self.wallet_view.just_fyi("Checking that the new wallet is added to the Share QR Code menu") self.wallet_view.just_fyi("Checking that the new wallet is added to the Share QR Code menu")

View File

@ -360,6 +360,10 @@ class ProfileView(BaseView):
accessibility_id="icon, Legacy settings, label-component, icon") accessibility_id="icon, Legacy settings, label-component, icon")
self.testnet_mode_toggle = Button(self.driver, accessibility_id="icon, Testnet mode, label-component") self.testnet_mode_toggle = Button(self.driver, accessibility_id="icon, Testnet mode, label-component")
self.confirm_testnet_mode_change_button = Button(self.driver, accessibility_id="confirm-testnet-mode-change") self.confirm_testnet_mode_change_button = Button(self.driver, accessibility_id="confirm-testnet-mode-change")
self.key_pairs_and_accounts_button = Button(self.driver,
accessibility_id="Key pairs and accounts, label-component, icon")
self.options_button = Button(self.driver, accessibility_id="options-button")
self.import_by_entering_recovery_phrase_button = Button(self.driver, accessibility_id="import-seed-phrase")
def switch_network(self): def switch_network(self):
self.driver.info("Toggling test mode") self.driver.info("Toggling test mode")
@ -569,3 +573,16 @@ class ProfileView(BaseView):
return Button(self.driver, xpath=self.locator + "//*[@content-desc='Unpair']") return Button(self.driver, xpath=self.locator + "//*[@content-desc='Unpair']")
return PairedDeviceElement(self.driver, device_name) return PairedDeviceElement(self.driver, device_name)
def get_key_pair_account_by_name(self, account_name: str):
class KeyPairAccountElement(BaseElement):
def __init__(self, driver, account_name):
locator = "//*[@content-desc='account-avatar']/following-sibling::*[@text='%s']" % account_name
super().__init__(driver, xpath=locator)
self.address = Text(driver, xpath=locator + "/following-sibling::android.widget.TextView")
return KeyPairAccountElement(self.driver, account_name)
def get_missing_key_pair_by_name(self, key_pair_name: str):
return BaseElement(self.driver,
xpath="//*[@content-desc='missing-keypair-item']//*[@text='%s']" % key_pair_name)

View File

@ -75,6 +75,8 @@ class WalletView(BaseView):
self.account_has_activity_label = Text(self.driver, accessibility_id='account-has-activity') self.account_has_activity_label = Text(self.driver, accessibility_id='account-has-activity')
self.add_account_continue_button = Button(self.driver, accessibility_id='Continue') self.add_account_continue_button = Button(self.driver, accessibility_id='Continue')
self.add_watched_address_button = Button(self.driver, accessibility_id='confirm-button-label') self.add_watched_address_button = Button(self.driver, accessibility_id='confirm-button-label')
self.add_account_derivation_path_text = Text(
self.driver, xpath="//*[contains(@content-desc,'icon, Derivation path')]/android.widget.TextView[2]")
# Account view # Account view
self.close_account_button = Button(self.driver, accessibility_id='top-bar') self.close_account_button = Button(self.driver, accessibility_id='top-bar')
@ -88,8 +90,11 @@ class WalletView(BaseView):
self.share_address_button = Button(self.driver, accessibility_id='share-account') self.share_address_button = Button(self.driver, accessibility_id='share-account')
self.remove_account_button = Button(self.driver, accessibility_id='remove-account') self.remove_account_button = Button(self.driver, accessibility_id='remove-account')
self.derivation_path_note_checkbox = Button(self.driver, accessibility_id='checkbox-off') self.derivation_path_note_checkbox = Button(self.driver, accessibility_id='checkbox-off')
self.account_about_derivation_path_text = Text(
self.driver, xpath="//*[@content-desc='derivation-path-icon']/following-sibling::*[2]")
self.activity_tab = Button(self.driver, accessibility_id='activity-tab') self.activity_tab = Button(self.driver, accessibility_id='activity-tab')
self.about_tab = Button(self.driver, accessibility_id='about')
# Sending transaction # Sending transaction
self.address_text_input = EditBox(self.driver, accessibility_id='address-text-input') self.address_text_input = EditBox(self.driver, accessibility_id='address-text-input')
@ -99,6 +104,15 @@ class WalletView(BaseView):
self.confirm_button = Button(self.driver, accessibility_id='button-one') self.confirm_button = Button(self.driver, accessibility_id='button-one')
self.done_button = Button(self.driver, accessibility_id='done') self.done_button = Button(self.driver, accessibility_id='done')
# Edit key pair
self.edit_key_pair_button = Button(self.driver, accessibility_id="Edit")
self.key_pairs_plus_button = Button(self.driver, accessibility_id="standard-title-action")
self.generate_new_keypair_button = Button(self.driver, accessibility_id="generate-new-keypair")
self.import_using_recovery_phrase_button = Button(self.driver, accessibility_id="import-using-phrase")
self.key_pair_continue_button = Button(self.driver, accessibility_id="Continue")
self.key_pair_name_input = EditBox(
self.driver, xpath="//*[@text='Key pair name']/..//following-sibling::*/*[@content-desc='input']")
def select_network(self, network_name: str): def select_network(self, network_name: str):
self.network_drop_down.click() self.network_drop_down.click()
Button(self.driver, accessibility_id="%s, label-component" % network_name.capitalize()).click() Button(self.driver, accessibility_id="%s, label-component" % network_name.capitalize()).click()
@ -160,8 +174,10 @@ class WalletView(BaseView):
def add_regular_account(self, account_name: str): def add_regular_account(self, account_name: str):
self.add_account_button.click() self.add_account_button.click()
self.create_account_button.click() self.create_account_button.click()
derivation_path = self.add_account_derivation_path_text.text
SignInView(self.driver).profile_title_input.send_keys(account_name) SignInView(self.driver).profile_title_input.send_keys(account_name)
self.slide_and_confirm_with_password() self.slide_and_confirm_with_password()
return derivation_path.replace(' ', '')
def add_watch_only_account(self, address: str, account_name: str): def add_watch_only_account(self, address: str, account_name: str):
self.add_account_button.click() self.add_account_button.click()
@ -181,3 +197,33 @@ class WalletView(BaseView):
def get_activity_element(self, index=1): def get_activity_element(self, index=1):
return ActivityElement(self.driver, index=index) return ActivityElement(self.driver, index=index)
def add_key_pair_account(self, account_name, passphrase=None, key_pair_name=None):
self.add_account_button.click()
self.create_account_button.click()
signin_view = SignInView(self.driver)
signin_view.profile_title_input.send_keys(account_name)
self.edit_key_pair_button.click()
self.key_pairs_plus_button.click()
if passphrase:
self.import_using_recovery_phrase_button.click()
signin_view.passphrase_edit_box.send_keys(passphrase)
self.key_pair_continue_button.click()
self.key_pair_name_input.send_keys(key_pair_name)
self.key_pair_continue_button.click()
else:
self.generate_new_keypair_button.click()
for checkbox in self.checkbox_button.find_elements():
checkbox.click()
self.element_by_translation_id("reveal-phrase").click()
# ToDo: can't be done in current small size emulators, add when moved to LambdaTest
self.slide_and_confirm_with_password()
derivation_path = self.add_account_derivation_path_text.text
return derivation_path.replace(' ', '')
def get_account_address(self):
self.account_emoji_button.click_until_presence_of_element(self.copy_address_button)
self.share_address_button.click()
wallet_address = self.sharing_text_native.text
self.click_system_back_button()
return wallet_address