Added new atomic tests for Smoke phase 1 section

Signed-off-by: yevh-berdnyk <ie.berdnyk@gmail.com>
This commit is contained in:
yevh-berdnyk 2018-07-13 12:56:36 +02:00
parent 03598d47c2
commit 458e7231bd
No known key found for this signature in database
GPG Key ID: E9B425FDFC4DEA9C
14 changed files with 340 additions and 69 deletions

View File

@ -43,7 +43,7 @@ class NetworkApi:
return return
pytest.fail('Transaction is not found in Ropsten network') pytest.fail('Transaction is not found in Ropsten network')
def find_transaction_by_unique_amount(self, address, amount, token=False, wait_time=600): def find_transaction_by_unique_amount(self, address, amount, token=False, decimals=18, wait_time=600):
counter = 0 counter = 0
while True: while True:
if counter >= wait_time: if counter >= wait_time:
@ -60,10 +60,19 @@ class NetworkApi:
info('Looking for a transaction with unique amount %s in list of transactions, address is %s' % info('Looking for a transaction with unique amount %s in list of transactions, address is %s' %
(amount, address)) (amount, address))
for transaction in transactions: for transaction in transactions:
if float(int(transaction['value']) / 10 ** 18) == float(amount): if float(int(transaction['value']) / 10 ** decimals) == float(amount):
info('Transaction with unique amount %s is found in list of transactions, address is %s' % info('Transaction with unique amount %s is found in list of transactions, address is %s' %
(amount, address)) (amount, address))
return transaction
def wait_for_confirmation_of_transaction(self, address, amount):
start_time = time.time()
while round(time.time() - start_time, ndigits=2) < 10:
transaction = self.find_transaction_by_unique_amount(address, amount)
if int(transaction['confirmations']) > 1:
return return
time.sleep(10)
pytest.fail('Transaction with amount %s was not confirmed, address is %s' % (amount, address))
def verify_balance_is_updated(self, initial_balance, recipient_address, wait_time=360): def verify_balance_is_updated(self, initial_balance, recipient_address, wait_time=360):
counter = 0 counter = 0

View File

@ -15,7 +15,8 @@ RERUN_ERRORS = [
"503 Service Unavailable", "503 Service Unavailable",
"object has no attribute", "object has no attribute",
"[Errno 104] Connection reset by peer", "[Errno 104] Connection reset by peer",
"Sauce could not start your job" "Sauce could not start your job",
"HTTP Error 303"
] ]

View File

@ -3,7 +3,6 @@ import pytest
from tests import marks, transaction_users from tests import marks, transaction_users
from tests.base_test_case import SingleDeviceTestCase from tests.base_test_case import SingleDeviceTestCase
from views.sign_in_view import SignInView from views.sign_in_view import SignInView
from views.web_views.base_web_view import BaseWebView
@marks.all @marks.all

View File

@ -1,7 +1,7 @@
import pytest import pytest
from tests import marks, group_chat_users, basic_user from tests import marks, group_chat_users, basic_user, get_current_time
from tests.base_test_case import SingleDeviceTestCase from tests.base_test_case import SingleDeviceTestCase, MultipleDeviceTestCase
from views.sign_in_view import SignInView from views.sign_in_view import SignInView
@ -64,40 +64,6 @@ class TestChatManagement(SingleDeviceTestCase):
self.errors.append('Chat history is shown') self.errors.append('Chat history is shown')
self.verify_no_errors() self.verify_no_errors()
@marks.testrail_id(3694)
@marks.smoke_1
def test_add_contact_from_public_chat(self):
sign_in = SignInView(self.driver)
home = sign_in.create_user()
chat_name = 'testaddcontact'
chat = home.join_public_chat(chat_name)
message = 'test message'
chat.reconnect()
chat_element = chat.chat_element_by_text(message)
chat_element.find_element()
username = chat_element.username.text
chat_element.member_photo.click()
for element in [chat.contact_profile_picture, chat.add_to_contacts, chat.profile_send_message,
chat.profile_send_transaction, chat.public_key_text, chat.element_by_text(username, 'text')]:
if not element.is_element_displayed():
self.errors.append('%s is not visible' % 'user name' if 'Base' in element.name else element.name)
chat.add_to_contacts.click()
if not chat.element_by_text('In contacts').is_element_displayed():
self.errors.append("'Add to contacts' is not changed to 'In contacts'")
chat.get_back_to_home_view()
start_new_chat = home.plus_button.click()
start_new_chat.start_new_chat_button.click()
if not start_new_chat.element_by_text(username).is_element_displayed():
self.errors.append("List of contacts doesn't contain added user")
start_new_chat.get_back_to_home_view()
home.get_chat_with_user('#' + chat_name).click()
chat.chat_message_input.send_keys(message)
chat.send_message_button.click()
self.verify_no_errors()
@marks.testrail_id(763) @marks.testrail_id(763)
@marks.smoke_1 @marks.smoke_1
def test_add_contact_by_pasting_public_key(self): def test_add_contact_by_pasting_public_key(self):
@ -155,3 +121,42 @@ class TestChatManagement(SingleDeviceTestCase):
if home.element_by_text(chat_name).is_element_present(5): if home.element_by_text(chat_name).is_element_present(5):
self.errors.append("Public chat '%s' is shown after re-login, but the chat has been deleted" % chat_name) self.errors.append("Public chat '%s' is shown after re-login, but the chat has been deleted" % chat_name)
self.verify_no_errors() self.verify_no_errors()
@marks.chat
class TestChatManagementMultipleDevice(MultipleDeviceTestCase):
@marks.testrail_id(3694)
@marks.smoke_1
def test_add_contact_from_public_chat(self):
self.create_drivers(2)
device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
home_1, home_2 = device_1.create_user(), device_2.create_user()
chat_name = 'testaddcontact'
chat_1, chat_2 = home_1.join_public_chat(chat_name), home_2.join_public_chat(chat_name)
message = 'test message'
chat_2.chat_message_input.send_keys(message)
chat_2.send_message_button.click()
self.drivers[1].quit()
chat_element = chat_1.chat_element_by_text(message)
chat_element.find_element()
username = chat_element.username.text
chat_element.member_photo.click()
for element in [chat_1.contact_profile_picture, chat_1.add_to_contacts, chat_1.profile_send_message,
chat_1.profile_send_transaction, chat_1.public_key_text,
chat_1.element_by_text(username, 'text')]:
if not element.is_element_displayed():
self.errors.append('%s is not visible' % 'user name' if 'Base' in element.name else element.name)
chat_1.add_to_contacts.click()
if not chat_1.element_by_text('In contacts').is_element_displayed():
self.errors.append("'Add to contacts' is not changed to 'In contacts'")
chat_1.get_back_to_home_view()
start_new_chat = home_1.plus_button.click()
start_new_chat.start_new_chat_button.click()
if not start_new_chat.element_by_text(username).is_element_displayed():
self.errors.append("List of contacts doesn't contain added user")
self.verify_no_errors()

View File

@ -1,3 +1,4 @@
import pytest
from _pytest.outcomes import Failed from _pytest.outcomes import Failed
from decimal import Decimal as d from decimal import Decimal as d
from selenium.common.exceptions import TimeoutException from selenium.common.exceptions import TimeoutException
@ -246,11 +247,9 @@ class TestCommandsMultipleDevices(MultipleDeviceTestCase):
device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1]) device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
home_1 = device_1.recover_access(passphrase=sender['passphrase'], password=sender['password']) home_1 = device_1.recover_access(passphrase=sender['passphrase'], password=sender['password'])
home_2 = device_2.recover_access(passphrase=recipient['passphrase'], password=recipient['password']) home_2 = device_2.recover_access(passphrase=recipient['passphrase'], password=recipient['password'])
wallet_1, wallet_2 = home_1.wallet_button.click(), home_2.wallet_button.click() wallet_1 = home_1.wallet_button.click()
wallet_1.set_up_wallet() wallet_1.set_up_wallet()
wallet_1.home_button.click() wallet_1.home_button.click()
wallet_2.set_up_wallet()
wallet_2.home_button.click()
chat_1 = home_1.add_contact(recipient['public_key']) chat_1 = home_1.add_contact(recipient['public_key'])
amount = chat_1.get_unique_amount() amount = chat_1.get_unique_amount()
@ -305,6 +304,28 @@ class TestCommandsMultipleDevices(MultipleDeviceTestCase):
self.errors.append(e.msg) self.errors.append(e.msg)
self.verify_no_errors() self.verify_no_errors()
@marks.testrail_id(3749)
@marks.smoke_1
def test_transaction_confirmed_on_recipient_side(self):
recipient = transaction_users['D_USER']
sender = transaction_users['C_USER']
self.create_drivers(2)
device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
home_1 = device_1.recover_access(passphrase=sender['passphrase'], password=sender['password'])
home_2 = device_2.recover_access(passphrase=recipient['passphrase'], password=recipient['password'])
wallet_1 = home_1.wallet_button.click()
wallet_1.set_up_wallet()
wallet_1.home_button.click()
chat_1 = home_1.add_contact(recipient['public_key'])
amount = chat_1.get_unique_amount()
chat_1.send_transaction_in_1_1_chat('ETH', amount, sender['password'])
chat_2 = home_2.get_chat_with_user(sender['username']).click()
self.network_api.wait_for_confirmation_of_transaction(recipient['address'], amount)
if not chat_2.chat_element_by_text(amount).contains_text('Confirmed', 60):
pytest.fail('Transaction state is not updated on the recipient side')
@marks.chat @marks.chat
@marks.transaction @marks.transaction
@ -340,3 +361,49 @@ class TestCommandsSingleDevices(SingleDeviceTestCase):
amount = chat.get_unique_amount() amount = chat.get_unique_amount()
chat.send_transaction_in_1_1_chat('ETH', amount, sender['password']) chat.send_transaction_in_1_1_chat('ETH', amount, sender['password'])
chat.check_no_value_in_logcat(sender['password']) chat.check_no_value_in_logcat(sender['password'])
@marks.testrail_id(3736)
@marks.smoke_1
def test_send_transaction_details_in_1_1_chat(self):
recipient = transaction_users['D_USER']
sender = transaction_users['C_USER']
sign_in = SignInView(self.driver)
home = sign_in.recover_access(passphrase=sender['passphrase'], password=sender['password'])
wallet = home.wallet_button.click()
wallet.set_up_wallet()
wallet.home_button.click()
chat = home.add_contact(recipient['public_key'])
amount = chat.get_unique_amount()
chat.commands_button.click()
chat.send_command.click()
chat.asset_by_name('ETH').click()
chat.send_as_keyevent(amount)
send_transaction_view = chat.get_send_transaction_view()
chat.send_message_button.click_until_presence_of_element(send_transaction_view.sign_transaction_button)
if not send_transaction_view.element_by_text(recipient['username']).is_element_displayed():
self.errors.append('Recipient name is not shown')
if not send_transaction_view.element_by_text('0x' + recipient['address']).is_element_displayed():
self.errors.append('Recipient address is not shown')
if not send_transaction_view.element_by_text('ETH').is_element_displayed():
self.errors.append("Asset field doesn't contain 'ETH' text")
if not send_transaction_view.element_by_text(amount).is_element_displayed():
self.errors.append('Amount is not visible')
self.verify_no_errors()
@marks.testrail_id(3750)
@marks.smoke_1
def test_transaction_confirmed_on_sender_side(self):
sender = transaction_users['D_USER']
sign_in = SignInView(self.driver)
home = sign_in.recover_access(passphrase=sender['passphrase'], password=sender['password'])
wallet = home.wallet_button.click()
wallet.set_up_wallet()
wallet.home_button.click()
chat = home.add_contact(transaction_users['C_USER']['public_key'])
amount = chat.get_unique_amount()
chat.send_transaction_in_1_1_chat('ETH', amount, sender['password'])
self.network_api.wait_for_confirmation_of_transaction(sender['address'], amount)
if not chat.chat_element_by_text(amount).contains_text('Confirmed'):
pytest.fail('Transaction state is not updated on the sender side')

View File

@ -27,10 +27,8 @@ class TestMessagesOneToOneChatMultiple(MultipleDeviceTestCase):
device_1_chat.chat_message_input.send_keys(message) device_1_chat.chat_message_input.send_keys(message)
device_1_chat.send_message_button.click() device_1_chat.send_message_button.click()
device_2_home.get_chat_with_user(username_1).click() device_2_chat = device_2_home.get_chat_with_user(username_1).click()
device_2_chat.chat_element_by_text(message).wait_for_visibility_of_element()
if device_1_chat.chat_element_by_text(message).status.text != 'Seen':
pytest.fail("'Seen' status is not shown under the sent text message")
@marks.testrail_id(772) @marks.testrail_id(772)
@marks.smoke_1 @marks.smoke_1
@ -101,7 +99,7 @@ class TestMessagesOneToOneChatMultiple(MultipleDeviceTestCase):
chat_1.reconnect() chat_1.reconnect()
chat_element = chat_1.chat_element_by_text(message) chat_element = chat_1.chat_element_by_text(message)
chat_1.element_by_text('Resend').click_until_presence_of_element(chat_element) chat_1.element_by_text('Resend').click()
chat_element.status.wait_for_visibility_of_element() chat_element.status.wait_for_visibility_of_element()
if chat_element.status.text != 'Sent': if chat_element.status.text != 'Sent':
self.errors.append("Message status is not 'Sent' after resending the message") self.errors.append("Message status is not 'Sent' after resending the message")
@ -288,6 +286,31 @@ class TestMessagesOneToOneChatMultiple(MultipleDeviceTestCase):
self.errors.append('Offline status is not shown in a public chat') self.errors.append('Offline status is not shown in a public chat')
self.verify_no_errors() self.verify_no_errors()
@marks.testrail_id(3695)
@marks.smoke_1
def test_message_marked_as_sent_and_seen_1_1_chat(self):
self.create_drivers(2)
device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
username_1 = 'user_%s' % get_current_time()
device_1_home, device_2_home = device_1.create_user(username=username_1), device_2.create_user()
device_2_public_key = device_2_home.get_public_key()
device_2_home.home_button.click()
device_1_chat = device_1_home.add_contact(device_2_public_key)
message = 'test message'
device_1_chat.chat_message_input.send_keys(message)
device_1_chat.send_message_button.click()
if device_1_chat.chat_element_by_text(message).status.text != 'Sent':
self.errors.append("'Sent' status is not shown under the sent text message")
device_2_chat = device_2_home.get_chat_with_user(username_1).click()
device_2_chat.chat_element_by_text(message).wait_for_visibility_of_element()
if device_1_chat.chat_element_by_text(message).status.text != 'Seen':
self.errors.append("'Seen' status is not shown under the text message which was read by a receiver")
self.verify_no_errors()
@marks.all @marks.all
@marks.chat @marks.chat

View File

@ -1,3 +1,5 @@
import pytest
from tests import transaction_users, marks, common_password from tests import transaction_users, marks, common_password
from tests.base_test_case import SingleDeviceTestCase from tests.base_test_case import SingleDeviceTestCase
from views.sign_in_view import SignInView from views.sign_in_view import SignInView
@ -36,6 +38,36 @@ class TestTransactionDApp(SingleDeviceTestCase):
send_transaction_view.enter_password_input.send_keys(password) send_transaction_view.enter_password_input.send_keys(password)
send_transaction_view.sign_transaction_button.click() send_transaction_view.sign_transaction_button.click()
@marks.testrail_id(3696)
@marks.smoke_1
def test_deploy_contract_from_daap(self):
sender = transaction_users['E_USER']
sign_in_view = SignInView(self.driver)
sign_in_view.recover_access(sender['passphrase'], sender['password'])
status_test_dapp = sign_in_view.open_status_test_dapp()
status_test_dapp.wait_for_d_aap_to_load()
status_test_dapp.transactions_button.click()
send_transaction_view = status_test_dapp.deploy_contract_button.click()
send_transaction_view.sign_transaction(sender['password'])
status_test_dapp.element_starts_with_text('Mining new contract in tx:').wait_for_visibility_of_element()
for text in 'Contract deployed at: ', 'Call contract get function', \
'Call contract set function', 'Call function 2 times in a row':
if not status_test_dapp.element_by_text(text).is_element_displayed(30):
pytest.fail('Contract was not created')
@marks.testrail_id(3782)
@marks.smoke_1
def test_filters_from_daap(self):
sign_in_view = SignInView(self.driver)
sign_in_view.create_user()
status_test_dapp = sign_in_view.open_status_test_dapp()
status_test_dapp.wait_for_d_aap_to_load()
status_test_dapp.transactions_button.click()
status_test_dapp.test_filters_button.click()
for element in status_test_dapp.element_by_text('eth_uninstallFilter'), status_test_dapp.ok_button:
if element.is_element_displayed(10):
pytest.fail("'Test filters' button produced an error")
@marks.logcat @marks.logcat
@marks.testrail_id(3772) @marks.testrail_id(3772)
def test_logcat_send_transaction_from_daap(self): def test_logcat_send_transaction_from_daap(self):

View File

@ -1,10 +1,12 @@
import random
from tests import transaction_users, transaction_users_wallet, marks, common_password from tests import transaction_users, transaction_users_wallet, marks, common_password
from tests.base_test_case import SingleDeviceTestCase from tests.base_test_case import SingleDeviceTestCase, MultipleDeviceTestCase
from views.sign_in_view import SignInView from views.sign_in_view import SignInView
@marks.transaction @marks.transaction
class TestTransactionWallet(SingleDeviceTestCase): class TestTransactionWalletSingleDevice(SingleDeviceTestCase):
@marks.testrail_id(766) @marks.testrail_id(766)
@marks.smoke_1 @marks.smoke_1
@ -74,8 +76,9 @@ class TestTransactionWallet(SingleDeviceTestCase):
wallet_view = home_view.wallet_button.click() wallet_view = home_view.wallet_button.click()
wallet_view.set_up_wallet() wallet_view.set_up_wallet()
send_transaction = wallet_view.send_transaction_button.click() send_transaction = wallet_view.send_transaction_button.click()
send_transaction.select_asset_button.click_until_presence_of_element(send_transaction.stt_button) stt_button = send_transaction.asset_by_name('STT')
send_transaction.stt_button.click() send_transaction.select_asset_button.click_until_presence_of_element(stt_button)
stt_button.click()
send_transaction.amount_edit_box.click() send_transaction.amount_edit_box.click()
amount = send_transaction.get_unique_amount() amount = send_transaction.get_unique_amount()
send_transaction.amount_edit_box.set_value(amount) send_transaction.amount_edit_box.set_value(amount)
@ -189,3 +192,109 @@ class TestTransactionWallet(SingleDeviceTestCase):
send_transaction.sign_transaction_button.click() send_transaction.sign_transaction_button.click()
send_transaction.got_it_button.click() send_transaction.got_it_button.click()
send_transaction.check_no_value_in_logcat(sender['password']) send_transaction.check_no_value_in_logcat(sender['password'])
@marks.testrail_id(3746)
@marks.smoke_1
def test_send_token_with_7_decimals(self):
sender = transaction_users_wallet['A_USER']
recipient = transaction_users_wallet['B_USER']
sign_in_view = SignInView(self.driver)
sign_in_view.recover_access(sender['passphrase'], sender['password'])
home_view = sign_in_view.get_home_view()
home_view.add_contact(recipient['public_key'])
home_view.get_back_to_home_view()
wallet_view = home_view.wallet_button.click()
wallet_view.set_up_wallet()
wallet_view.options_button.click()
wallet_view.manage_assets_button.click()
wallet_view.asset_checkbox_by_name('ADI').click()
wallet_view.done_button.click()
send_transaction = wallet_view.send_transaction_button.click()
adi_button = send_transaction.asset_by_name('ADI')
send_transaction.select_asset_button.click_until_presence_of_element(adi_button)
adi_button.click()
send_transaction.amount_edit_box.click()
amount = '0.0%s' % random.randint(100000, 999999)
send_transaction.amount_edit_box.set_value(amount)
send_transaction.confirm()
send_transaction.chose_recipient_button.click()
send_transaction.enter_recipient_address_button.click()
send_transaction.enter_recipient_address_input.set_value(recipient['address'])
send_transaction.done_button.click()
send_transaction.sign_transaction_button.click()
send_transaction.enter_password_input.send_keys(sender['password'])
send_transaction.sign_transaction_button.click()
send_transaction.got_it_button.click()
self.network_api.find_transaction_by_unique_amount(sender['address'], amount, token=True, decimals=7)
@marks.testrail_id(3747)
@marks.smoke_1
def test_token_with_more_than_allowed_decimals(self):
sender = transaction_users_wallet['A_USER']
sign_in_view = SignInView(self.driver)
sign_in_view.recover_access(sender['passphrase'], sender['password'])
wallet_view = sign_in_view.wallet_button.click()
wallet_view.set_up_wallet()
wallet_view.options_button.click()
wallet_view.manage_assets_button.click()
wallet_view.asset_checkbox_by_name('ADI').click()
wallet_view.done_button.click()
send_transaction = wallet_view.send_transaction_button.click()
adi_button = send_transaction.asset_by_name('ADI')
send_transaction.select_asset_button.click_until_presence_of_element(adi_button)
adi_button.click()
send_transaction.amount_edit_box.click()
amount = '0.0%s' % random.randint(1000000, 9999999)
send_transaction.amount_edit_box.set_value(amount)
error_text = 'Amount is too precise. Max number of decimals is 7.'
if not send_transaction.element_by_text(error_text).is_element_displayed():
self.errors.append('Warning about too precise amount is not shown when sending a transaction')
send_transaction.back_button.click()
wallet_view.receive_transaction_button.click()
wallet_view.send_transaction_request.click()
send_transaction.select_asset_button.click_until_presence_of_element(adi_button)
adi_button.click()
send_transaction.amount_edit_box.set_value(amount)
error_text = 'Amount is too precise. Max number of decimals is 7.'
if not send_transaction.element_by_text(error_text).is_element_displayed():
self.errors.append('Warning about too precise amount is not shown when requesting a transaction')
self.verify_no_errors()
@marks.transaction
class TestTransactionWalletMultipleDevice(MultipleDeviceTestCase):
@marks.testrail_id(3761)
@marks.smoke_1
def test_transaction_message_sending_from_wallet(self):
recipient = transaction_users['D_USER']
sender = transaction_users['C_USER']
self.create_drivers(2)
device_1, device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
home_1 = device_1.recover_access(passphrase=sender['passphrase'], password=sender['password'])
home_2 = device_2.recover_access(passphrase=recipient['passphrase'], password=recipient['password'])
chat_1 = home_1.add_contact(recipient['public_key'])
chat_1.get_back_to_home_view()
wallet_1 = home_1.wallet_button.click()
wallet_1.set_up_wallet()
send_transaction = wallet_1.send_transaction_button.click()
send_transaction.amount_edit_box.click()
amount = send_transaction.get_unique_amount()
send_transaction.amount_edit_box.set_value(amount)
send_transaction.confirm()
send_transaction.chose_recipient_button.click()
send_transaction.enter_recipient_address_button.click()
send_transaction.enter_recipient_address_input.set_value(recipient['address'])
send_transaction.done_button.click()
send_transaction.sign_transaction(sender['password'])
wallet_1.home_button.click()
home_1.get_chat_with_user(recipient['username']).click()
if not chat_1.chat_element_by_text(amount).is_element_displayed():
self.errors.append('Transaction message is not shown in 1-1 chat for the sender')
chat_2 = home_2.get_chat_with_user(sender['username']).click()
if not chat_2.chat_element_by_text(amount).is_element_displayed():
self.errors.append('Transaction message is not shown in 1-1 chat for the recipient')
self.verify_no_errors()

View File

@ -422,7 +422,10 @@ class BaseView(object):
connect_status = self.connection_status connect_status = self.connection_status
for i in range(3): for i in range(3):
if connect_status.is_element_displayed(5) and 'Tap to reconnect' in connect_status.text: if connect_status.is_element_displayed(5) and 'Tap to reconnect' in connect_status.text:
try:
connect_status.click() connect_status.click()
except AttributeError:
pass
try: try:
connect_status.wait_for_invisibility_of_element() connect_status.wait_for_invisibility_of_element()
except TimeoutException as e: except TimeoutException as e:

View File

@ -190,7 +190,8 @@ class ChatElementByText(BaseText):
class StatusText(BaseText): class StatusText(BaseText):
def __init__(self, driver, parent_locator: str): def __init__(self, driver, parent_locator: str):
super(StatusText, self).__init__(driver) super(StatusText, self).__init__(driver)
self.locator = self.Locator.xpath_selector(parent_locator + '/android.widget.TextView') text = "//android.widget.TextView[@text='Seen' or @text='Sent' or @text='Not sent. Tap for options']"
self.locator = self.Locator.xpath_selector(parent_locator + text)
return StatusText(self.driver, self.locator.value) return StatusText(self.driver, self.locator.value)
@ -230,11 +231,11 @@ class ChatElementByText(BaseText):
return SendRequestButton(self.driver, self.locator.value) return SendRequestButton(self.driver, self.locator.value)
def contains_text(self, text) -> bool: def contains_text(self, text, wait_time=5) -> bool:
element = BaseText(self.driver) element = BaseText(self.driver)
element.locator = element.Locator.xpath_selector( element.locator = element.Locator.xpath_selector(
self.locator.value + "//android.view.ViewGroup//android.widget.TextView[contains(@text,'%s')]" % text) self.locator.value + "//android.view.ViewGroup//android.widget.TextView[contains(@text,'%s')]" % text)
return element.is_element_displayed() return element.is_element_displayed(wait_time)
class ChatView(BaseView): class ChatView(BaseView):

View File

@ -51,11 +51,15 @@ class ChatElement(BaseButton):
def find_element(self): def find_element(self):
info('Looking for %s' % self.name) info('Looking for %s' % self.name)
for _ in range(2): for i in range(2):
try: try:
return super(ChatElement, self).find_element() return super(ChatElement, self).find_element()
except NoSuchElementException: except NoSuchElementException as e:
if i == 0:
HomeView(self.driver).reconnect() HomeView(self.driver).reconnect()
else:
e.msg = 'Unable to find chat with user %s' % self.username
raise e
@property @property
def swipe_delete_button(self): def swipe_delete_button(self):

View File

@ -1,6 +1,5 @@
from views.base_element import BaseButton, BaseEditBox, BaseText from views.base_element import BaseText
from views.base_view import BaseView from views.base_element import BaseButton, BaseEditBox
from views.base_element import BaseElement, BaseButton, BaseEditBox
from views.base_view import BaseView, OkButton from views.base_view import BaseView, OkButton
@ -90,10 +89,10 @@ class SelectAssetButton(BaseButton):
self.locator = self.Locator.accessibility_id('choose-asset-button') self.locator = self.Locator.accessibility_id('choose-asset-button')
class STTButton(BaseButton): class AssetButton(BaseButton):
def __init__(self, driver): def __init__(self, driver, asset_name):
super(STTButton, self).__init__(driver) super(AssetButton, self).__init__(driver)
self.locator = self.Locator.xpath_selector("//*[@text='Status Test Token']") self.locator = self.Locator.text_part_selector(asset_name)
class ErrorDialog(BaseView): class ErrorDialog(BaseView):
@ -169,7 +168,6 @@ class SendTransactionView(BaseView):
self.got_it_button = GotItButton(self.driver) self.got_it_button = GotItButton(self.driver)
self.select_asset_button = SelectAssetButton(self.driver) self.select_asset_button = SelectAssetButton(self.driver)
self.stt_button = STTButton(self.driver)
self.error_dialog = ErrorDialog(self.driver) self.error_dialog = ErrorDialog(self.driver)
@ -180,3 +178,6 @@ class SendTransactionView(BaseView):
self.enter_password_input.send_keys(sender_password) self.enter_password_input.send_keys(sender_password)
self.sign_transaction_button.click_until_presence_of_element(self.got_it_button) self.sign_transaction_button.click_until_presence_of_element(self.got_it_button)
self.got_it_button.click() self.got_it_button.click()
def asset_by_name(self, asset_name):
return AssetButton(self.driver, asset_name)

View File

@ -126,6 +126,7 @@ class SignInView(BaseView):
self.element_by_text_part('Display name').wait_for_element(30) self.element_by_text_part('Display name').wait_for_element(30)
username = username if username else 'user_%s' % get_current_time() username = username if username else 'user_%s' % get_current_time()
self.name_input.set_value(username) self.name_input.set_value(username)
self.confirm()
self.next_button.click() self.next_button.click()
self.do_not_share_button.wait_for_visibility_of_element(10) self.do_not_share_button.wait_for_visibility_of_element(10)
@ -163,4 +164,4 @@ class SignInView(BaseView):
try: try:
self.account_button.find_elements()[position].click() self.account_button.find_elements()[position].click()
except IndexError: except IndexError:
raise NoSuchElementException('Unable to find account by position %s' % position) raise NoSuchElementException('Unable to find account by position %s' % position) from None

View File

@ -32,6 +32,20 @@ class TransactionsButton(BaseButton):
from views.send_transaction_view import SendTransactionView from views.send_transaction_view import SendTransactionView
return SendTransactionView(self.driver) return SendTransactionView(self.driver)
class DeployContractButton(BaseButton):
def __init__(self, driver):
super(TransactionsButton.DeployContractButton, self).__init__(driver)
self.locator = self.Locator.text_selector('Deploy simple contract')
def navigate(self):
from views.send_transaction_view import SendTransactionView
return SendTransactionView(self.driver)
class TestFiltersButton(BaseButton):
def __init__(self, driver):
super(TransactionsButton.TestFiltersButton, self).__init__(driver)
self.locator = self.Locator.text_selector('Test filters')
class StatusTestDAppView(BaseWebView): class StatusTestDAppView(BaseWebView):
@ -44,3 +58,5 @@ class StatusTestDAppView(BaseWebView):
self.transactions_button = TransactionsButton(self.driver) self.transactions_button = TransactionsButton(self.driver)
self.sign_message_button = TransactionsButton.SignMessageButton(self.driver) self.sign_message_button = TransactionsButton.SignMessageButton(self.driver)
self.deploy_contract_button = TransactionsButton.DeployContractButton(self.driver)
self.test_filters_button = TransactionsButton.TestFiltersButton(self.driver)