e2e for PN and set max

Signed-off-by: Churikova Tetiana <churikova.tm@gmail.com>
This commit is contained in:
Churikova Tetiana 2020-07-29 17:54:45 +02:00
parent 788d0d5cc5
commit 56364ea70c
No known key found for this signature in database
GPG Key ID: 0D4EA7B33B47E6D8
9 changed files with 70 additions and 25 deletions

View File

@ -488,13 +488,13 @@ class TestChatManagementMultipleDevice(MultipleDeviceTestCase):
@marks.testrail_id(5763) @marks.testrail_id(5763)
@marks.medium @marks.medium
def test_block_user_from_one_to_one_header(self): def test_block_user_from_one_to_one_header_check_push_notification_service(self):
self.create_drivers(2) self.create_drivers(2)
device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1]) device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
message_before_block_1 = "Before block from %s" % device_1.driver.number message_before_block_1 = "Before block from %s" % device_1.driver.number
message_before_block_2 = "Before block from %s" % device_2.driver.number message_before_block_2 = "Before block from %s" % device_2.driver.number
message_after_block_2 = "After block from %s" % device_2.driver.number message_after_block_2 = "After block from %s" % device_2.driver.number
home_1, home_2 = device_1.create_user(), device_2.create_user() home_1, home_2 = device_1.create_user(enable_notifications=True), device_2.create_user()
profile_1 = home_1.profile_button.click() profile_1 = home_1.profile_button.click()
device_2_public_key = home_2.get_public_key_and_username() device_2_public_key = home_2.get_public_key_and_username()
home_2.get_back_to_home_view() home_2.get_back_to_home_view()
@ -532,11 +532,12 @@ class TestChatManagementMultipleDevice(MultipleDeviceTestCase):
device_1.just_fyi('no 1-1, messages from blocked user are hidden in public chat') device_1.just_fyi('no 1-1, messages from blocked user are hidden in public chat')
if home_1.get_chat(basic_user['username']).is_element_displayed(): if home_1.get_chat(basic_user['username']).is_element_displayed():
home_1.driver.fail("Chat with blocked user '%s' is not deleted" % device_2.driver.number) home_1.driver.fail("Chat with blocked user '%s' is not deleted" % device_2.driver.number)
public_chat_after_block = home_1.join_public_chat(chat_name) public_chat_after_block_1 = home_1.join_public_chat(chat_name)
if public_chat_after_block.chat_element_by_text(message_before_block_2).is_element_displayed(): if public_chat_after_block_1.chat_element_by_text(message_before_block_2).is_element_displayed():
self.errors.append( self.errors.append(
"Messages from blocked user '%s' are not cleared in public chat '%s'" % (device_2.driver.number, "Messages from blocked user '%s' are not cleared in public chat '%s'" % (device_2.driver.number,
chat_name)) chat_name))
device_1.click_system_home_button()
device_2.just_fyi('send messages to 1-1 and public chat') device_2.just_fyi('send messages to 1-1 and public chat')
for _ in range(2): for _ in range(2):
@ -550,13 +551,19 @@ class TestChatManagementMultipleDevice(MultipleDeviceTestCase):
chat_public_2.chat_message_input.send_keys(message_after_block_2) chat_public_2.chat_message_input.send_keys(message_after_block_2)
chat_public_2.send_message_button.click() chat_public_2.send_message_button.click()
device_1.just_fyi("check that new messages didn't arrived from blocked user") device_1.just_fyi("check that new messages and push notifications don't arrive from blocked user")
if public_chat_after_block.chat_element_by_text(message_after_block_2).is_element_displayed(): device_1.open_notification_bar()
if device_1.element_by_text_part(message_after_block_2).is_element_displayed():
self.errors.append("Push notification is received from blocked user")
device_1.element_by_text_part("Background notification service").click()
if public_chat_after_block_1.chat_element_by_text(message_after_block_2).is_element_displayed():
self.errors.append("Message from blocked user '%s' is received" % device_2.driver.number) self.errors.append("Message from blocked user '%s' is received" % device_2.driver.number)
public_chat_after_block.get_back_to_home_view() public_chat_after_block_1.get_back_to_home_view()
if home_1.get_chat(basic_user['username']).is_element_displayed(): if home_1.get_chat(basic_user['username']).is_element_displayed():
device_2.driver.fail("Chat with blocked user is reappeared after receiving new messages") device_2.driver.fail("Chat with blocked user is reappeared after receiving new messages")
self.drivers[0].close_app() device_1.open_notification_bar()
home_1.stop_status_service_button.click()
device_2.just_fyi("send messages when device 1 is offline") device_2.just_fyi("send messages when device 1 is offline")
for _ in range(2): for _ in range(2):
@ -569,6 +576,7 @@ class TestChatManagementMultipleDevice(MultipleDeviceTestCase):
chat_2.send_message_button.click() chat_2.send_message_button.click()
device_1.just_fyi("reopen app and check that messages from blocked user are not fetched") device_1.just_fyi("reopen app and check that messages from blocked user are not fetched")
device_1.click_system_home_button()
self.drivers[0].launch_app() self.drivers[0].launch_app()
device_1.accept_agreements() device_1.accept_agreements()
device_1.sign_in() device_1.sign_in()
@ -577,10 +585,16 @@ class TestChatManagementMultipleDevice(MultipleDeviceTestCase):
home_1.join_public_chat(chat_name) home_1.join_public_chat(chat_name)
home_1.get_chat_view() home_1.get_chat_view()
if chat_public_1.chat_element_by_text(message_after_block_2).is_element_displayed(): if chat_public_1.chat_element_by_text(message_after_block_2).is_element_displayed():
self.errors.append( self.errors.append("Message from blocked user '%s' is received after fetching new messages from offline"
"Message from blocked user '%s' is received after fetching new messages from offline"
% device_2.driver.number) % device_2.driver.number)
device_1.just_fyi("check that PNs are still enabled in profile after closing 'background notification centre' "
"message and relogin")
home_1.profile_button.click()
profile_1.push_notification_toggle.scroll_to_element()
if not profile_1.push_notification_toggle.is_element_image_equals_template('enabled_toggle.png'):
self.errors.append('Toggle is not enabled')
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(6233) @marks.testrail_id(6233)

View File

@ -96,7 +96,7 @@ class TestCommandsMultipleDevices(MultipleDeviceTestCase):
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(6294) @marks.testrail_id(6294)
@marks.critical @marks.medium
def test_keycard_request_and_receive_stt_in_1_1_chat_offline(self): def test_keycard_request_and_receive_stt_in_1_1_chat_offline(self):
sender = transaction_senders['D'] sender = transaction_senders['D']
self.create_drivers(2) self.create_drivers(2)
@ -161,13 +161,9 @@ class TestCommandsMultipleDevices(MultipleDeviceTestCase):
self.network_api.wait_for_confirmation_of_transaction(sender['address'], amount, token=True) self.network_api.wait_for_confirmation_of_transaction(sender['address'], amount, token=True)
chat_2.toggle_airplane_mode() chat_2.toggle_airplane_mode()
chat_2.connection_status.wait_for_invisibility_of_element(60) chat_2.connection_status.wait_for_invisibility_of_element(60)
if chat_2_sender_message.transaction_status.text != 'Confirmed': if not chat_2.element_by_text('Confirmed').is_element_displayed(30):
self.errors.append('Wrong state is shown for outgoing transaction: "Confirmed" is expected, in fact' self.errors.append('Wrong state is shown for outgoing transaction: "Confirmed" is expected, in fact'
' %s ' % chat_2_sender_message.transaction_status.text) ' %s ' % chat_2_sender_message.transaction_status.text)
try:
self.network_api.find_transaction_by_unique_amount(recipient_address[2:], amount, token=True)
except Failed as e:
self.errors.append(e.msg)
self.errors.verify_no_errors() self.errors.verify_no_errors()

View File

@ -84,10 +84,8 @@ class TestMessagesOneToOneChatMultiple(MultipleDeviceTestCase):
device_1.driver.fail("Failed to open chat view after tap on PN") device_1.driver.fail("Failed to open chat view after tap on PN")
device_1.just_fyi("Checks there are no PN after message was seen") device_1.just_fyi("Checks there are no PN after message was seen")
device_1.click_system_home_button() [device.click_system_home_button() for device in (device_1, device_2)]
device_2.click_system_home_button() [device.open_notification_bar() for device in (device_1, device_2)]
device_1.open_notification_bar()
device_2.open_notification_bar()
if (device_2.element_by_text_part(message).is_element_displayed() if (device_2.element_by_text_part(message).is_element_displayed()
or device_1.element_by_text_part(emoji_unicode).is_element_displayed()): or device_1.element_by_text_part(emoji_unicode).is_element_displayed()):
self.errors.append("PN are keep staying after message was seen by user") self.errors.append("PN are keep staying after message was seen by user")

View File

@ -138,7 +138,7 @@ class TestTransactionWalletSingleDevice(SingleDeviceTestCase):
send_transaction.sign_transaction_button.click() send_transaction.sign_transaction_button.click()
send_transaction.sign_transaction(keycard=True) send_transaction.sign_transaction(keycard=True)
self.network_api.wait_for_confirmation_of_transaction(status_account_address, transaction_amount) self.network_api.wait_for_confirmation_of_transaction(status_account_address, transaction_amount)
self.network_api.verify_balance_is_updated('0.1', status_account_address) self.network_api.verify_balance_is_updated('0', status_account_address)
wallet_view.just_fyi("Verifying previously sent transaction in new account") wallet_view.just_fyi("Verifying previously sent transaction in new account")
wallet_view.back_button.click() wallet_view.back_button.click()
@ -186,3 +186,19 @@ class TestTransactionWalletSingleDevice(SingleDeviceTestCase):
if total_eth_from_two_accounts != expected_balance: if total_eth_from_two_accounts != expected_balance:
self.driver.fail('Total wallet balance %s != of Status account (%s) + SubAccount (%s)' % ( self.driver.fail('Total wallet balance %s != of Status account (%s) + SubAccount (%s)' % (
total_eth_from_two_accounts, balance_of_status_account, balance_of_sub_account)) total_eth_from_two_accounts, balance_of_status_account, balance_of_sub_account))
wallet_view.just_fyi("Check that can set max and send transaction with max amount from subaccount")
wallet_view.get_account_by_name(account_name).click()
wallet_view.send_transaction_button.click()
send_transaction.set_max_button.click()
set_amount = float(send_transaction.amount_edit_box.text)
if set_amount == 0.0 or set_amount >= balance_of_sub_account:
self.driver.fail('Value after setting up max amount is set to %s' % str(set_amount))
send_transaction.confirm()
send_transaction.chose_recipient_button.click()
send_transaction.accounts_button.click()
send_transaction.element_by_text('Status account').click()
send_transaction.sign_transaction_button.click()
send_transaction.sign_transaction(keycard=True)
wallet_view.element_by_text('Assets').click()
wallet_view.wait_balance_is_equal_expected_amount(asset='ETH', expected_balance=0)

View File

@ -571,7 +571,7 @@ class TestTransactionWalletSingleDevice(SingleDeviceTestCase):
wallet_view.back_button.click() wallet_view.back_button.click()
screen = 'sending screen from wallet' screen = 'sending screen from wallet'
sign_in_view.just_fyi('Checking %s on %s' % (errors['sending_screen']['Network fee'],screen)) sign_in_view.just_fyi('Checking %s on %s' % (errors['sending_screen']['Network fee'], screen))
account_name = 'new' account_name = 'new'
wallet_view.add_account(account_name) wallet_view.add_account(account_name)
wallet_view.get_account_by_name(account_name).click() wallet_view.get_account_by_name(account_name).click()
@ -613,7 +613,7 @@ class TestTransactionWalletSingleDevice(SingleDeviceTestCase):
send_transaction.cancel_button.click() send_transaction.cancel_button.click()
screen = 'sending screen from DApp' screen = 'sending screen from DApp'
sign_in_view.just_fyi('Checking %s on %s' % (errors['sending_screen']['Network fee'],screen)) sign_in_view.just_fyi('Checking %s on %s' % (errors['sending_screen']['Network fee'], screen))
home_view = wallet_view.home_button.click() home_view = wallet_view.home_button.click()
dapp_view = sign_in_view.dapp_tab_button.click() dapp_view = sign_in_view.dapp_tab_button.click()
dapp_view.select_account_button.click() dapp_view.select_account_button.click()

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 KiB

View File

@ -72,6 +72,10 @@ class ChatsMenuInviteFriendsButton(BaseButton):
super(ChatsMenuInviteFriendsButton, self).__init__(driver) super(ChatsMenuInviteFriendsButton, self).__init__(driver)
self.locator = self.Locator.accessibility_id('chats-menu-invite-friends-button') self.locator = self.Locator.accessibility_id('chats-menu-invite-friends-button')
class StopStatusServiceButton(BaseButton):
def __init__(self, driver):
super(StopStatusServiceButton, self).__init__(driver)
self.locator = self.Locator.accessibility_id('STOP')
class UserNameBelowNewChatButton(BaseButton): class UserNameBelowNewChatButton(BaseButton):
def __init__(self, driver, username_part): def __init__(self, driver, username_part):
@ -177,6 +181,7 @@ class HomeView(BaseView):
self.delete_chat_button = DeleteChatButton(self.driver) self.delete_chat_button = DeleteChatButton(self.driver)
self.clear_history_button = ClearHistoryButton(self.driver) self.clear_history_button = ClearHistoryButton(self.driver)
self.mark_all_messages_as_read_button = MarkAllMessagesAsReadButton(self.driver) self.mark_all_messages_as_read_button = MarkAllMessagesAsReadButton(self.driver)
self.stop_status_service_button = StopStatusServiceButton(self.driver)
def wait_for_syncing_complete(self): def wait_for_syncing_complete(self):
self.driver.info('Waiting for syncing complete:') self.driver.info('Waiting for syncing complete:')

View File

@ -569,6 +569,12 @@ class AskMeWhenOnMobileNetworkToggle(BaseButton):
self.locator = self.Locator.xpath_selector( self.locator = self.Locator.xpath_selector(
"//*[@text='Ask me when on mobile network']/following-sibling::android.widget.Switch[1]") "//*[@text='Ask me when on mobile network']/following-sibling::android.widget.Switch[1]")
class PushNotificationToggle(BaseButton):
def __init__(self, driver):
super(PushNotificationToggle, self).__init__(driver)
self.locator = self.Locator.xpath_selector(
"//*[@content-desc='notifications-button']//*[@content-desc='switch']")
class ENSUsernameInChatSettings(BaseElement): class ENSUsernameInChatSettings(BaseElement):
def __init__(self, driver): def __init__(self, driver):
super(ENSUsernameInChatSettings, self).__init__(driver) super(ENSUsernameInChatSettings, self).__init__(driver)
@ -672,6 +678,9 @@ class ProfileView(BaseView):
self.use_mobile_data = UseMobileDataToggle(self.driver) self.use_mobile_data = UseMobileDataToggle(self.driver)
self.ask_me_when_on_mobile_network = AskMeWhenOnMobileNetworkToggle(self.driver) self.ask_me_when_on_mobile_network = AskMeWhenOnMobileNetworkToggle(self.driver)
#Push notifications
self.push_notification_toggle = PushNotificationToggle(self.driver)
def switch_network(self, network='Mainnet with upstream RPC'): def switch_network(self, network='Mainnet with upstream RPC'):
self.advanced_button.click() self.advanced_button.click()
self.network_settings_button.click() self.network_settings_button.click()

View File

@ -13,7 +13,7 @@ class FirstRecipient(BaseButton):
class CancelButton(BaseButton): class CancelButton(BaseButton):
def __init__(self, driver): def __init__(self, driver):
super(CancelButton, self).__init__(driver) super(CancelButton, self).__init__(driver)
self.locator = self.Locator.xpath_selector("//*[@text='Cancel']") self.locator = self.Locator.text_selector("Cancel")
class SignTransactionButton(BaseButton): class SignTransactionButton(BaseButton):
@ -28,6 +28,12 @@ class AmountEditBox(BaseEditBox, BaseButton):
super(AmountEditBox, self).__init__(driver) super(AmountEditBox, self).__init__(driver)
self.locator = self.Locator.accessibility_id('amount-input') self.locator = self.Locator.accessibility_id('amount-input')
class SetMaxButton(BaseButton):
def __init__(self, driver):
super(SetMaxButton, self).__init__(driver)
self.locator = self.Locator.text_selector('Set max')
class SignInPhraseText(BaseText): class SignInPhraseText(BaseText):
def __init__(self, driver): def __init__(self, driver):
@ -189,7 +195,7 @@ class ValidationErrorOnSendTransaction(BaseButton):
class ValidationIconOnSendTransaction(BaseButton): class ValidationIconOnSendTransaction(BaseButton):
def __init__(self, driver): def __init__(self, driver):
super(ValidationIconOnSendTransaction, self).__init__(driver) super(ValidationIconOnSendTransaction, self).__init__(driver)
self.locator = self.Locator.xpath_selector('//*[@content-desc="custom-gas-fee"]/../android.view.ViewGroup/*[@content-desc="icon"]') self.locator = self.Locator.xpath_selector('//*[@content-desc="custom-gas-fee"]/../android.view.ViewGroup//*[@content-desc="icon"]')
@ -288,6 +294,7 @@ class SendTransactionView(BaseView):
self.enter_recipient_address_text = EnterRecipientAddressInputText(self.driver) self.enter_recipient_address_text = EnterRecipientAddressInputText(self.driver)
self.recent_recipients_button = RecentRecipientsButton(self.driver) self.recent_recipients_button = RecentRecipientsButton(self.driver)
self.amount_edit_box = AmountEditBox(self.driver) self.amount_edit_box = AmountEditBox(self.driver)
self.set_max_button = SetMaxButton(self.driver)
self.validation_error_element = ValidationIconOnSendTransaction(self.driver) self.validation_error_element = ValidationIconOnSendTransaction(self.driver)
self.network_fee_button = NetworkFeeButton(self.driver) self.network_fee_button = NetworkFeeButton(self.driver)