2018-02-14 13:48:18 +00:00
|
|
|
import time
|
2018-06-21 23:57:54 +00:00
|
|
|
|
|
|
|
import pytest
|
2018-03-31 20:05:11 +00:00
|
|
|
from selenium.common.exceptions import TimeoutException
|
2018-01-26 11:07:09 +00:00
|
|
|
from tests import info
|
2018-06-21 16:40:27 +00:00
|
|
|
from views.base_element import BaseButton, BaseEditBox, BaseText, BaseElement
|
2018-01-14 17:43:36 +00:00
|
|
|
from views.base_view import BaseView
|
2018-05-16 19:59:36 +00:00
|
|
|
from views.profile_view import ProfilePictureElement
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ChatMessageInput(BaseEditBox):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ChatMessageInput, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.accessibility_id('chat-message-input')
|
|
|
|
|
|
|
|
|
|
|
|
class AddToContacts(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(AddToContacts, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.accessibility_id('add-to-contacts-button')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
class UserNameText(BaseText):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(UserNameText, self).__init__(driver)
|
|
|
|
self.locator = \
|
2018-03-28 10:21:39 +00:00
|
|
|
self.Locator.accessibility_id('chat-name-text')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
2018-02-09 15:16:07 +00:00
|
|
|
class TransactionPopupText(BaseText):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(TransactionPopupText, self).__init__(driver)
|
2018-02-19 11:51:53 +00:00
|
|
|
self.locator = self.Locator.xpath_selector("//*[@text='Specify amount']")
|
2018-02-09 15:16:07 +00:00
|
|
|
|
|
|
|
|
2018-01-03 09:34:40 +00:00
|
|
|
class SendCommand(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(SendCommand, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.accessibility_id('send-payment-button')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
class RequestCommand(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(RequestCommand, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.accessibility_id('request-payment-button')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
2018-06-15 15:20:50 +00:00
|
|
|
class EthAsset(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(EthAsset, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.text_selector('ETH')
|
|
|
|
|
|
|
|
|
2018-05-16 07:22:02 +00:00
|
|
|
class FaucetCommand(BaseButton):
|
2018-05-02 16:01:17 +00:00
|
|
|
def __init__(self, driver):
|
2018-05-16 07:22:02 +00:00
|
|
|
super(FaucetCommand, self).__init__(driver)
|
2018-05-02 16:01:17 +00:00
|
|
|
self.locator = self.Locator.xpath_selector(
|
2018-05-16 07:22:02 +00:00
|
|
|
"//*[contains(@text,'Get some ETH')]/preceding-sibling::*[@text='/faucet']")
|
2018-05-02 16:01:17 +00:00
|
|
|
|
|
|
|
|
2018-05-16 07:22:02 +00:00
|
|
|
class FaucetSendCommand(BaseButton):
|
2018-05-02 16:01:17 +00:00
|
|
|
def __init__(self, driver):
|
2018-05-16 07:22:02 +00:00
|
|
|
super(FaucetSendCommand, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector("//*[@text='Status Testnet Faucet']")
|
2018-05-02 16:01:17 +00:00
|
|
|
|
|
|
|
|
2018-03-28 10:21:39 +00:00
|
|
|
class ChatMenuButton(BaseButton):
|
2018-01-03 09:34:40 +00:00
|
|
|
def __init__(self, driver):
|
2018-03-28 10:21:39 +00:00
|
|
|
super(ChatMenuButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.accessibility_id('chat-menu-button')
|
2018-01-26 11:07:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
class MembersButton(BaseButton):
|
|
|
|
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(MembersButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('(//android.view.ViewGroup[@content-desc="action"])[1]')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
2018-02-14 13:48:18 +00:00
|
|
|
class DeleteChatButton(BaseButton):
|
|
|
|
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(DeleteChatButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[@text="Delete chat"]')
|
|
|
|
|
|
|
|
|
2018-05-23 13:02:45 +00:00
|
|
|
class ClearHistoryButton(BaseButton):
|
|
|
|
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ClearHistoryButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[@text="Clear history"]')
|
|
|
|
|
|
|
|
|
|
|
|
class LeaveChatButton(BaseButton):
|
|
|
|
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(LeaveChatButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[@text="Leave public chat"]')
|
|
|
|
|
|
|
|
|
|
|
|
class ClearButton(BaseButton):
|
|
|
|
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ClearButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[@text="CLEAR"]')
|
|
|
|
|
|
|
|
|
|
|
|
class LeaveButton(BaseButton):
|
|
|
|
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(LeaveButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[@text="LEAVE"]')
|
|
|
|
|
|
|
|
|
2018-01-03 09:34:40 +00:00
|
|
|
class ChatSettings(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ChatSettings, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector("//android.widget.TextView[@text='Settings']")
|
|
|
|
|
|
|
|
|
|
|
|
class UserOptions(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(UserOptions, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.accessibility_id('options')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
|
|
|
class RemoveButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(RemoveButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector("//android.widget.TextView[@text='Remove']")
|
|
|
|
|
|
|
|
|
|
|
|
class FirstRecipient(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(FirstRecipient, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.accessibility_id('contact-item')
|
2018-01-03 09:34:40 +00:00
|
|
|
|
|
|
|
|
2018-05-16 19:59:36 +00:00
|
|
|
class UsernameByMessage(BaseText):
|
|
|
|
def __init__(self, driver, message):
|
|
|
|
super(UsernameByMessage, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.xpath_selector(
|
2018-05-16 19:59:36 +00:00
|
|
|
"//*[@content-desc='chat-item']//*[contains(@text, '%s')]/../../android.widget.TextView" % message)
|
2018-01-26 11:07:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
class MoreUsersButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(MoreUsersButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector("//android.widget.TextView[contains(@text, 'MORE')]")
|
|
|
|
|
|
|
|
|
2018-02-14 13:48:18 +00:00
|
|
|
class OpenInBrowserButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(OpenInBrowserButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector("//*[@text='Open in browser']")
|
|
|
|
|
|
|
|
def navigate(self):
|
|
|
|
from views.web_views.base_web_view import BaseWebView
|
|
|
|
return BaseWebView(self.driver)
|
|
|
|
|
|
|
|
|
2018-02-19 11:51:53 +00:00
|
|
|
class CommandsButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(CommandsButton, self).__init__(driver)
|
2018-03-28 10:21:39 +00:00
|
|
|
self.locator = self.Locator.accessibility_id('chat-commands-button')
|
2018-02-19 11:51:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
class ViewProfileButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ViewProfileButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[@text="View profile"]')
|
|
|
|
|
|
|
|
|
2018-04-26 06:22:11 +00:00
|
|
|
class NoMessagesInChatText(BaseText):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(NoMessagesInChatText, self).__init__(driver)
|
2018-06-08 10:02:54 +00:00
|
|
|
self.locator = self.Locator.text_part_selector(
|
|
|
|
'Any messages you send here are encrypted and can only be read by you and')
|
2018-04-26 06:22:11 +00:00
|
|
|
|
|
|
|
|
2018-05-02 16:01:17 +00:00
|
|
|
class ProfileSendMessageButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ProfileSendMessageButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.accessibility_id('start-conversation-button')
|
|
|
|
|
|
|
|
|
|
|
|
class ProfileSendTransactionButton(BaseButton):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ProfileSendTransactionButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.accessibility_id('send-transaction-button')
|
|
|
|
|
|
|
|
|
2018-06-18 13:10:34 +00:00
|
|
|
class SendRequestButton(BaseButton):
|
|
|
|
def __init__(self, driver, amount):
|
|
|
|
super(SendRequestButton, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector('//*[contains(@text, "%s.ETH")]/../*[@text="Send"]' % amount)
|
|
|
|
|
|
|
|
|
2018-06-21 16:40:27 +00:00
|
|
|
class ChatElementByText(BaseText):
|
|
|
|
def __init__(self, driver, text):
|
|
|
|
super(ChatElementByText, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector(
|
|
|
|
"//*[starts-with(@text,'%s')]/ancestor::android.view.ViewGroup[@content-desc='chat-item']" % text)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def status(self):
|
|
|
|
class StatusText(BaseText):
|
|
|
|
def __init__(self, driver, parent_locator: str):
|
|
|
|
super(StatusText, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector(parent_locator + '/android.widget.TextView')
|
|
|
|
|
|
|
|
return StatusText(self.driver, self.locator.value)
|
|
|
|
|
|
|
|
@property
|
|
|
|
def progress_bar(self):
|
|
|
|
class ProgressBar(BaseElement):
|
|
|
|
def __init__(self, driver, parent_locator: str):
|
|
|
|
super(ProgressBar, self).__init__(driver)
|
|
|
|
self.locator = self.Locator.xpath_selector(parent_locator + '//android.widget.ProgressBar')
|
|
|
|
|
|
|
|
return ProgressBar(self.driver, self.locator.value)
|
|
|
|
|
|
|
|
def contains_text(self, text) -> bool:
|
|
|
|
element = BaseText(self.driver)
|
|
|
|
element.locator = element.Locator.xpath_selector("//android.view.ViewGroup//android.widget.TextView[@text='%s']"
|
|
|
|
% text)
|
|
|
|
return element.is_element_displayed()
|
|
|
|
|
|
|
|
|
2018-01-03 09:34:40 +00:00
|
|
|
class ChatView(BaseView):
|
|
|
|
def __init__(self, driver):
|
|
|
|
super(ChatView, self).__init__(driver)
|
|
|
|
|
|
|
|
self.chat_message_input = ChatMessageInput(self.driver)
|
|
|
|
self.add_to_contacts = AddToContacts(self.driver)
|
|
|
|
self.user_name_text = UserNameText(self.driver)
|
2018-04-26 06:22:11 +00:00
|
|
|
self.no_messages_in_chat = NoMessagesInChatText(self.driver)
|
2018-01-03 09:34:40 +00:00
|
|
|
|
2018-02-19 11:51:53 +00:00
|
|
|
self.commands_button = CommandsButton(self.driver)
|
2018-01-03 09:34:40 +00:00
|
|
|
self.send_command = SendCommand(self.driver)
|
|
|
|
self.request_command = RequestCommand(self.driver)
|
2018-06-15 15:20:50 +00:00
|
|
|
self.eth_asset = EthAsset(self.driver)
|
2018-05-16 07:22:02 +00:00
|
|
|
self.faucet_command = FaucetCommand(self.driver)
|
|
|
|
self.faucet_send_command = FaucetSendCommand(self.driver)
|
|
|
|
|
2018-03-28 10:21:39 +00:00
|
|
|
self.chat_options = ChatMenuButton(self.driver)
|
2018-01-26 11:07:09 +00:00
|
|
|
self.members_button = MembersButton(self.driver)
|
2018-02-14 13:48:18 +00:00
|
|
|
self.delete_chat_button = DeleteChatButton(self.driver)
|
2018-05-23 13:02:45 +00:00
|
|
|
self.clear_history_button = ClearHistoryButton(self.driver)
|
|
|
|
self.clear_button = ClearButton(self.driver)
|
|
|
|
self.leave_chat_button = LeaveChatButton(self.driver)
|
|
|
|
self.leave_button = LeaveButton(self.driver)
|
2018-01-26 11:07:09 +00:00
|
|
|
|
2018-01-03 09:34:40 +00:00
|
|
|
self.chat_settings = ChatSettings(self.driver)
|
2018-02-19 11:51:53 +00:00
|
|
|
self.view_profile_button = ViewProfileButton(self.driver)
|
2018-01-26 11:07:09 +00:00
|
|
|
self.more_users_button = MoreUsersButton(self.driver)
|
2018-01-03 09:34:40 +00:00
|
|
|
self.user_options = UserOptions(self.driver)
|
|
|
|
self.remove_button = RemoveButton(self.driver)
|
|
|
|
|
|
|
|
self.first_recipient_button = FirstRecipient(self.driver)
|
|
|
|
|
2018-02-14 13:48:18 +00:00
|
|
|
self.open_in_browser_button = OpenInBrowserButton(self.driver)
|
2018-02-13 17:22:41 +00:00
|
|
|
|
2018-05-02 16:01:17 +00:00
|
|
|
# Contact's profile
|
2018-05-16 19:59:36 +00:00
|
|
|
self.contact_profile_picture = ProfilePictureElement(self.driver)
|
2018-05-02 16:01:17 +00:00
|
|
|
self.profile_send_message = ProfileSendMessageButton(self.driver)
|
|
|
|
self.profile_send_transaction = ProfileSendTransactionButton(self.driver)
|
|
|
|
|
2018-01-03 09:34:40 +00:00
|
|
|
def wait_for_syncing_complete(self):
|
2018-01-26 11:07:09 +00:00
|
|
|
info('Waiting for syncing complete:')
|
2018-01-03 09:34:40 +00:00
|
|
|
while True:
|
|
|
|
try:
|
|
|
|
sync = self.find_text_part('Syncing', 10)
|
2018-01-26 11:07:09 +00:00
|
|
|
info(sync.text)
|
2018-01-03 09:34:40 +00:00
|
|
|
except TimeoutException:
|
|
|
|
break
|
2018-01-26 11:07:09 +00:00
|
|
|
|
2018-05-16 19:59:36 +00:00
|
|
|
def wait_for_message_in_one_to_one_chat(self, expected_message: str, errors: list, wait_time: int = 20):
|
2018-02-14 13:48:18 +00:00
|
|
|
try:
|
2018-06-21 16:40:27 +00:00
|
|
|
element = ChatElementByText(self.driver, expected_message)
|
|
|
|
element.wait_for_element(wait_time)
|
2018-02-14 13:48:18 +00:00
|
|
|
except TimeoutException:
|
|
|
|
errors.append('Message with text "%s" was not received' % expected_message)
|
|
|
|
|
2018-03-15 20:01:08 +00:00
|
|
|
def wait_for_messages(self, username: str, expected_messages: list, errors: list, wait_time: int = 30):
|
|
|
|
expected_messages = expected_messages if type(expected_messages) == list else [expected_messages]
|
|
|
|
repeat = 0
|
|
|
|
received_messages = list()
|
|
|
|
while repeat <= wait_time:
|
|
|
|
for message in expected_messages:
|
2018-04-30 09:58:20 +00:00
|
|
|
if self.element_starts_with_text(message, 'text').is_element_present(1):
|
2018-03-15 20:01:08 +00:00
|
|
|
received_messages.append(message)
|
|
|
|
if not set(expected_messages) - set(received_messages):
|
|
|
|
break
|
|
|
|
time.sleep(3)
|
|
|
|
repeat += 3
|
|
|
|
if set(expected_messages) - set(received_messages):
|
2018-02-14 13:48:18 +00:00
|
|
|
errors.append('Not received messages from user %s: "%s"' % (username, ', '.join(
|
|
|
|
[i for i in list(set(expected_messages) - set(received_messages))])))
|
2018-02-09 15:16:07 +00:00
|
|
|
|
2018-05-16 19:59:36 +00:00
|
|
|
def verify_username_is_shown_per_message(self, username: str, messages: str, errors: list):
|
|
|
|
messages = messages if type(messages) == list else [messages]
|
|
|
|
for message in messages:
|
|
|
|
elements = UsernameByMessage(self.driver, message).find_elements()
|
|
|
|
for element in elements:
|
|
|
|
if not element.text == username:
|
|
|
|
errors.append("Message '%s' was received but username is '%s' instead of %s" %
|
|
|
|
(message, element.text, username))
|
|
|
|
|
2018-06-18 13:10:34 +00:00
|
|
|
def send_eth_to_request(self, amount, sender_password, wallet_set_up=False):
|
2018-02-19 11:51:53 +00:00
|
|
|
gas_popup = self.element_by_text_part('Specify amount')
|
2018-06-18 13:10:34 +00:00
|
|
|
send_request_button = SendRequestButton(self.driver, amount)
|
|
|
|
send_request_button.click_until_presence_of_element(gas_popup)
|
2018-02-09 15:16:07 +00:00
|
|
|
send_transaction = self.get_send_transaction_view()
|
2018-05-30 15:41:00 +00:00
|
|
|
if wallet_set_up:
|
|
|
|
wallet_view = self.get_wallet_view()
|
|
|
|
self.send_message_button.click_until_presence_of_element(wallet_view.sign_in_phrase)
|
|
|
|
wallet_view.done_button.click()
|
|
|
|
wallet_view.yes_button.click()
|
|
|
|
else:
|
|
|
|
self.send_message_button.click_until_presence_of_element(send_transaction.sign_transaction_button)
|
2018-02-09 15:16:07 +00:00
|
|
|
send_transaction.sign_transaction(sender_password)
|
2018-03-15 16:07:25 +00:00
|
|
|
|
|
|
|
def delete_chat(self, chat_name: str, errors: list):
|
|
|
|
self.chat_options.click()
|
|
|
|
self.delete_chat_button.click()
|
|
|
|
self.delete_button.click()
|
|
|
|
from views.home_view import HomeView
|
|
|
|
if not HomeView(self.driver).plus_button.is_element_present() or \
|
|
|
|
self.element_by_text(chat_name).is_element_present():
|
2018-03-28 10:21:39 +00:00
|
|
|
errors.append('Chat was not deleted')
|
2018-04-26 06:22:11 +00:00
|
|
|
|
2018-06-01 16:37:44 +00:00
|
|
|
def send_transaction_in_1_1_chat(self, amount, password, wallet_set_up=False):
|
2018-04-26 06:22:11 +00:00
|
|
|
self.commands_button.click()
|
|
|
|
self.send_command.click()
|
2018-06-15 15:20:50 +00:00
|
|
|
self.eth_asset.click()
|
2018-04-26 06:22:11 +00:00
|
|
|
self.send_as_keyevent(amount)
|
|
|
|
send_transaction_view = self.get_send_transaction_view()
|
2018-06-01 16:37:44 +00:00
|
|
|
if wallet_set_up:
|
|
|
|
wallet_view = self.get_wallet_view()
|
|
|
|
self.send_message_button.click_until_presence_of_element(wallet_view.sign_in_phrase)
|
|
|
|
wallet_view.done_button.click()
|
|
|
|
wallet_view.yes_button.click()
|
|
|
|
else:
|
|
|
|
self.send_message_button.click_until_presence_of_element(send_transaction_view.sign_transaction_button)
|
2018-04-26 06:22:11 +00:00
|
|
|
send_transaction_view.sign_transaction(password)
|
2018-06-21 23:57:54 +00:00
|
|
|
chat_elem = self.chat_element_by_text(amount)
|
|
|
|
chat_elem.wait_for_visibility_of_element()
|
|
|
|
chat_elem.progress_bar.wait_for_invisibility_of_element()
|
|
|
|
if chat_elem.status.text not in ('Sent', 'Delivered', 'Seen'):
|
|
|
|
pytest.fail('Sent transaction message was not sent')
|
2018-04-26 06:22:11 +00:00
|
|
|
|
|
|
|
def send_transaction_in_group_chat(self, amount, password, recipient):
|
|
|
|
self.commands_button.click()
|
|
|
|
self.send_command.click()
|
|
|
|
self.find_full_text(recipient['username']).click()
|
|
|
|
self.send_as_keyevent(amount)
|
|
|
|
self.send_message_button.click()
|
|
|
|
|
|
|
|
send_transaction_view = self.get_send_transaction_view()
|
|
|
|
self.send_message_button.click_until_presence_of_element(send_transaction_view.sign_transaction_button)
|
|
|
|
send_transaction_view.sign_transaction(password)
|
|
|
|
send_transaction_view.find_full_text(amount)
|
|
|
|
self.find_full_text('to ' + recipient['username'], 10)
|
|
|
|
|
|
|
|
def request_transaction_in_1_1_chat(self, amount):
|
|
|
|
self.commands_button.click()
|
|
|
|
self.request_command.click()
|
2018-06-15 15:20:50 +00:00
|
|
|
self.eth_asset.click()
|
2018-04-26 06:22:11 +00:00
|
|
|
self.send_as_keyevent(amount)
|
|
|
|
self.send_message_button.click()
|
2018-05-16 19:59:36 +00:00
|
|
|
|
|
|
|
def chat_element_by_text(self, text):
|
|
|
|
info("Looking for full text: '%s'" % text)
|
2018-06-21 16:40:27 +00:00
|
|
|
return ChatElementByText(self.driver, text)
|
|
|
|
|
|
|
|
def verify_message_is_under_today_text(self, text, errors):
|
|
|
|
message_element = self.chat_element_by_text(text)
|
|
|
|
message_element.wait_for_visibility_of_element()
|
|
|
|
message_location = message_element.find_element().location['y']
|
|
|
|
today_text_element = self.element_by_text('Today').find_element()
|
|
|
|
today_location = today_text_element.location['y']
|
|
|
|
today_height = today_text_element.size['height']
|
|
|
|
if message_location < today_location + today_height:
|
|
|
|
errors.append("Message '%s' is not uder 'Today' text" % text)
|