2022-04-14 10:48:34 +02:00
|
|
|
|
import random
|
|
|
|
|
from datetime import timedelta
|
|
|
|
|
|
|
|
|
|
import emoji
|
|
|
|
|
import pytest
|
|
|
|
|
from dateutil import parser
|
2023-02-28 14:44:13 +02:00
|
|
|
|
from selenium.common.exceptions import NoSuchElementException
|
2022-04-14 10:48:34 +02:00
|
|
|
|
|
2022-12-13 20:07:34 +02:00
|
|
|
|
from tests import marks, test_dapp_name, test_dapp_url, run_in_parallel
|
2022-04-14 10:48:34 +02:00
|
|
|
|
from tests.base_test_case import create_shared_drivers, MultipleSharedDeviceTestCase
|
2022-12-13 20:07:34 +02:00
|
|
|
|
from views.chat_view import CommunityView
|
2023-02-28 14:44:13 +02:00
|
|
|
|
from views.sign_in_view import SignInView
|
2022-04-14 10:48:34 +02:00
|
|
|
|
|
|
|
|
|
|
2022-05-10 18:03:44 +02:00
|
|
|
|
@pytest.mark.xdist_group(name="three_1")
|
2022-04-14 10:48:34 +02:00
|
|
|
|
@marks.critical
|
|
|
|
|
class TestPublicChatBrowserOneDeviceMerged(MultipleSharedDeviceTestCase):
|
|
|
|
|
|
2022-06-17 03:57:19 +03:00
|
|
|
|
def prepare_devices(self):
|
|
|
|
|
self.drivers, self.loop = create_shared_drivers(1)
|
|
|
|
|
self.sign_in = SignInView(self.drivers[0])
|
2022-04-14 10:48:34 +02:00
|
|
|
|
|
2022-06-17 03:57:19 +03:00
|
|
|
|
self.home = self.sign_in.create_user()
|
|
|
|
|
self.public_chat_name = self.home.get_random_chat_name()
|
|
|
|
|
self.chat = self.home.join_public_chat(self.public_chat_name)
|
2022-04-14 10:48:34 +02:00
|
|
|
|
|
|
|
|
|
@marks.testrail_id(5675)
|
|
|
|
|
def test_public_chat_fetch_more_history(self):
|
|
|
|
|
self.home.just_fyi("Check that can fetch previous history for several days")
|
|
|
|
|
device_time = parser.parse(self.drivers[0].device_time)
|
|
|
|
|
yesterday = (device_time - timedelta(days=1)).strftime("%b %-d, %Y")
|
|
|
|
|
before_yesterday = (device_time - timedelta(days=2)).strftime("%b %-d, %Y")
|
|
|
|
|
quiet_time_yesterday, quiet_time_before_yesterday = '24 hours', '2 days'
|
|
|
|
|
fetch_more = self.home.get_translation_by_key("load-more-messages")
|
|
|
|
|
for message in (yesterday, quiet_time_yesterday):
|
|
|
|
|
if not self.chat.element_by_text_part(message).is_element_displayed(120):
|
|
|
|
|
self.drivers[0].fail('"%s" is not shown' % message)
|
|
|
|
|
self.chat.element_by_text_part(fetch_more).wait_and_click(120)
|
|
|
|
|
self.chat.element_by_text_part(fetch_more).wait_for_visibility_of_element(180)
|
|
|
|
|
for message in (before_yesterday, quiet_time_before_yesterday):
|
|
|
|
|
if not self.chat.element_by_text_part(message).is_element_displayed():
|
|
|
|
|
self.drivers[0].fail('"%s" is not shown' % message)
|
|
|
|
|
self.home.just_fyi("Check that can fetch previous history for month")
|
|
|
|
|
times = {
|
|
|
|
|
"three-days": '5 days',
|
|
|
|
|
"one-week": '12 days',
|
|
|
|
|
"one-month": ['43 days', '42 days', '41 days', '40 days'],
|
|
|
|
|
}
|
|
|
|
|
profile = self.home.profile_button.click()
|
|
|
|
|
profile.sync_settings_button.click()
|
|
|
|
|
profile.sync_history_for_button.click()
|
|
|
|
|
for period in times:
|
|
|
|
|
profile.just_fyi("Checking %s period" % period)
|
|
|
|
|
profile.element_by_translation_id(period).click()
|
|
|
|
|
profile.home_button.click(desired_view='chat')
|
|
|
|
|
self.chat.element_by_text_part(fetch_more).wait_and_click(120)
|
|
|
|
|
if period != "one-month":
|
|
|
|
|
if not profile.element_by_text_part(times[period]).is_element_displayed(30):
|
|
|
|
|
self.errors.append("'Quiet here for %s' is not shown after fetching more history" % times[period])
|
|
|
|
|
else:
|
|
|
|
|
variants = times[period]
|
|
|
|
|
self.chat.element_by_text_part(fetch_more).wait_for_invisibility_of_element(120)
|
|
|
|
|
res = any(profile.element_by_text_part(variant).is_element_displayed(30) for variant in variants)
|
|
|
|
|
if not res:
|
|
|
|
|
self.errors.append("History is not fetched for one month!")
|
|
|
|
|
self.home.profile_button.click(desired_element_text=profile.get_translation_by_key("default-sync-period"))
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(5396)
|
|
|
|
|
def test_public_chat_navigate_to_chat_when_relaunch(self):
|
|
|
|
|
text_message = 'some_text'
|
|
|
|
|
self.home.home_button.double_click()
|
|
|
|
|
self.home.get_chat('#%s' % self.public_chat_name).click()
|
|
|
|
|
self.chat.send_message(text_message)
|
|
|
|
|
self.chat.reopen_app()
|
|
|
|
|
if not self.chat.chat_element_by_text(text_message).is_element_displayed(30):
|
|
|
|
|
self.drivers[0].fail("Not navigated to chat view after reopening app")
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(5317)
|
|
|
|
|
def test_public_chat_copy_and_paste_message_in_chat_input(self):
|
|
|
|
|
message_text = {'text_message': 'mmmeowesage_text'}
|
|
|
|
|
formatted_message = {'message_with_link': 'https://status.im',
|
2022-10-04 17:44:55 +02:00
|
|
|
|
# TODO: blocked with 11161 (rechecked 04.10.22, valid)
|
2022-04-14 10:48:34 +02:00
|
|
|
|
# 'message_with_tag': '#successishere'
|
|
|
|
|
}
|
|
|
|
|
message_input = self.chat.chat_message_input
|
|
|
|
|
if not message_input.is_element_displayed():
|
|
|
|
|
self.home.get_chat('#%s' % self.public_chat_name).click()
|
|
|
|
|
message_input.send_keys(message_text['text_message'])
|
|
|
|
|
self.chat.send_message_button.click()
|
|
|
|
|
|
|
|
|
|
self.chat.copy_message_text(message_text['text_message'])
|
|
|
|
|
|
|
|
|
|
message_input.paste_text_from_clipboard()
|
|
|
|
|
if message_input.text != message_text['text_message']:
|
|
|
|
|
self.errors.append('Message %s text was not copied in a public chat' % message_text['text_message'])
|
|
|
|
|
message_input.clear()
|
|
|
|
|
|
|
|
|
|
for message in formatted_message:
|
|
|
|
|
message_input.send_keys(formatted_message[message])
|
|
|
|
|
self.chat.send_message_button.click()
|
|
|
|
|
|
|
|
|
|
message_bubble = self.chat.chat_element_by_text(formatted_message[message])
|
|
|
|
|
message_bubble.sent_status_checkmark.long_press_element()
|
|
|
|
|
self.chat.element_by_text('Copy').click()
|
|
|
|
|
|
|
|
|
|
message_input.paste_text_from_clipboard()
|
|
|
|
|
if message_input.text != formatted_message[message]:
|
|
|
|
|
self.errors.append('Message %s text was not copied in a public chat' % formatted_message[message])
|
|
|
|
|
message_input.clear()
|
|
|
|
|
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(700738)
|
|
|
|
|
def test_public_chat_tag_message(self):
|
|
|
|
|
tag_message = '#wuuut'
|
|
|
|
|
self.home.home_button.double_click()
|
|
|
|
|
self.home.get_chat('#%s' % self.public_chat_name).click()
|
|
|
|
|
self.home.just_fyi("Check that will be redirected to chat view on tap on tag message")
|
|
|
|
|
self.chat.send_message(tag_message)
|
|
|
|
|
self.chat.element_starts_with_text(tag_message).click()
|
|
|
|
|
self.chat.element_by_text_part(self.public_chat_name).wait_for_invisibility_of_element()
|
|
|
|
|
if not self.chat.user_name_text.text == tag_message:
|
|
|
|
|
self.errors.append('Could not redirect a user to a public chat tapping the tag message.')
|
|
|
|
|
self.home.just_fyi("Check that chat is added to home view")
|
|
|
|
|
self.chat.home_button.double_click()
|
|
|
|
|
if not self.home.element_by_text(tag_message).is_element_displayed():
|
|
|
|
|
self.errors.append('Could not find the public chat in user chat list.')
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(700739)
|
|
|
|
|
def test_public_chat_open_using_deep_link(self):
|
|
|
|
|
self.drivers[0].close_app()
|
|
|
|
|
chat_name = self.home.get_random_chat_name()
|
|
|
|
|
deep_link = 'status-im://%s' % chat_name
|
|
|
|
|
self.sign_in.open_weblink_and_login(deep_link)
|
|
|
|
|
try:
|
|
|
|
|
assert self.chat.user_name_text.text == '#' + chat_name
|
|
|
|
|
except (AssertionError, NoSuchElementException):
|
|
|
|
|
self.drivers[0].fail("Public chat '%s' is not opened" % chat_name)
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702072)
|
|
|
|
|
def test_browser_blocked_url(self):
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
for url in ('metamask.site', 'cryptokitties.domainname'):
|
|
|
|
|
dapp.just_fyi('Checking blocked website %s' % url)
|
|
|
|
|
dapp_detail = dapp.open_url(url)
|
|
|
|
|
dapp_detail.element_by_translation_id('browsing-site-blocked-title')
|
|
|
|
|
if dapp_detail.browser_refresh_page_button.is_element_displayed():
|
|
|
|
|
self.errors.append("Refresh button is present in blocked site")
|
|
|
|
|
dapp_detail.go_back_button.click()
|
|
|
|
|
dapp_detail.open_tabs_button.click()
|
|
|
|
|
dapp.element_by_text_part(url[:8]).click()
|
|
|
|
|
dapp_detail.continue_anyway_button.click()
|
|
|
|
|
if dapp_detail.element_by_text('This site is blocked').is_element_displayed():
|
|
|
|
|
self.errors.append("Failed to open Dapp after 'Continue anyway' tapped for %s" % url)
|
|
|
|
|
dapp_detail.open_tabs_button.click()
|
|
|
|
|
dapp_detail.empty_tab_button.click()
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702073)
|
|
|
|
|
def test_browser_connection_is_secure_not_secure_warning(self):
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
web_page = dapp.open_url('http://www.dvwa.co.uk')
|
|
|
|
|
web_page.url_edit_box_lock_icon.click_until_presence_of_element(
|
|
|
|
|
web_page.element_by_translation_id("browser-not-secure"))
|
|
|
|
|
web_page.open_tabs_button.click()
|
|
|
|
|
web_page.empty_tab_button.click()
|
|
|
|
|
dapp.just_fyi('Checking connection is secure for Airswap')
|
|
|
|
|
web_page = dapp.open_url('https://instant.airswap.io')
|
|
|
|
|
web_page.wait_for_d_aap_to_load()
|
|
|
|
|
web_page.url_edit_box_lock_icon.click_until_presence_of_element(
|
|
|
|
|
web_page.element_by_translation_id("browser-secure"))
|
|
|
|
|
web_page.open_tabs_button.click()
|
|
|
|
|
web_page.empty_tab_button.click()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702074)
|
|
|
|
|
def test_browser_invalid_url(self):
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
browsing_view = dapp.open_url('invalid.takoe')
|
|
|
|
|
browsing_view.element_by_translation_id("web-view-error").wait_for_element(20)
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702075)
|
|
|
|
|
def test_browser_offline(self):
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
self.home.toggle_airplane_mode()
|
|
|
|
|
browsing_view = dapp.open_url('status.im')
|
|
|
|
|
offline_texts = ['Unable to load page', 'ERR_INTERNET_DISCONNECTED']
|
|
|
|
|
for text in offline_texts:
|
|
|
|
|
browsing_view.element_by_text_part(text).wait_for_element(15)
|
|
|
|
|
self.home.toggle_airplane_mode()
|
|
|
|
|
browsing_view.browser_refresh_page_button.click_until_presence_of_element(
|
|
|
|
|
browsing_view.element_by_text_part('An Open Source Community'))
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702076)
|
|
|
|
|
def test_browser_delete_close_tabs(self):
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
urls = {
|
|
|
|
|
'google.com': 'Google',
|
|
|
|
|
'status.im': 'Status - Private',
|
|
|
|
|
'bbc.com': 'bbc.com'
|
|
|
|
|
}
|
|
|
|
|
for url in urls:
|
|
|
|
|
web_page = dapp.open_url(url)
|
|
|
|
|
web_page.open_tabs_button.click()
|
|
|
|
|
web_page.empty_tab_button.click()
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Delete one tab')
|
|
|
|
|
web_page.remove_tab(name=urls['bbc.com'])
|
2022-05-06 16:06:29 +02:00
|
|
|
|
web_page.open_tabs_button.wait_for_invisibility_of_element()
|
|
|
|
|
web_page.element_by_text_part(urls['bbc.com']).wait_for_invisibility_of_element()
|
2022-04-14 10:48:34 +02:00
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Close all tabs via "Close all", relogin and check that it is not reappearing')
|
|
|
|
|
web_page.close_all_button.click()
|
|
|
|
|
self.home.reopen_app()
|
|
|
|
|
web_page.dapp_tab_button.click()
|
|
|
|
|
web_page.open_tabs_button.click()
|
|
|
|
|
if web_page.element_by_text_part(urls['status.im']).is_element_displayed():
|
|
|
|
|
self.errors.append('Tabs are not closed or reappeared after re-login!')
|
|
|
|
|
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702077)
|
|
|
|
|
def test_browser_bookmarks_create_edit_remove(self):
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Add some url to bookmarks with default name')
|
|
|
|
|
web_page = dapp.open_url('status.im')
|
|
|
|
|
default_bookmark_name = web_page.add_to_bookmarks()
|
|
|
|
|
web_page.browser_previous_page_button.click()
|
|
|
|
|
if not web_page.element_by_text(default_bookmark_name).is_element_displayed():
|
|
|
|
|
self.errors.append("Bookmark with default name is not added!")
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Add some url to bookmarks with custom name')
|
|
|
|
|
custom_name = 'Custom BBC'
|
|
|
|
|
dapp.open_url('bbc.com')
|
|
|
|
|
web_page.add_to_bookmarks(custom_name)
|
|
|
|
|
web_page.open_tabs_button.click()
|
|
|
|
|
web_page.empty_tab_button.click()
|
|
|
|
|
if not web_page.element_by_text(custom_name).is_element_displayed():
|
|
|
|
|
self.driver.fail("Bookmark with custom name is not added!")
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Checking "Open in new tab"')
|
|
|
|
|
dapp.browser_entry_long_press(custom_name)
|
|
|
|
|
dapp.open_in_new_tab_button.click()
|
|
|
|
|
web_page.options_button.click()
|
|
|
|
|
if not web_page.element_by_translation_id('remove-favourite').is_element_displayed():
|
|
|
|
|
self.errors.append("Remove favourite is not shown on added bookmark!")
|
|
|
|
|
dapp.click_system_back_button()
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Check deleting bookmark')
|
|
|
|
|
web_page.open_tabs_button.click()
|
|
|
|
|
web_page.empty_tab_button.click()
|
|
|
|
|
dapp.browser_entry_long_press(custom_name)
|
|
|
|
|
dapp.delete_bookmark_button.click()
|
|
|
|
|
if web_page.element_by_text(custom_name).is_element_displayed():
|
|
|
|
|
self.errors.append("Bookmark with custom name is not deleted!")
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('Check "Edit bookmark" and "Open in new tab"')
|
|
|
|
|
edited_name = 'My Fav Status'
|
|
|
|
|
dapp.browser_entry_long_press(default_bookmark_name)
|
|
|
|
|
dapp.edit_bookmark_button.click()
|
|
|
|
|
web_page.edit_bookmark_name(edited_name)
|
|
|
|
|
if not web_page.element_by_text(edited_name).is_element_displayed():
|
|
|
|
|
self.driver.fail("Edited bookmark name is not shown!")
|
|
|
|
|
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702078)
|
|
|
|
|
def test_browser_web3_permissions_testdapp(self):
|
|
|
|
|
self.home.home_button.double_click()
|
|
|
|
|
|
|
|
|
|
self.home.just_fyi('open Status Test Dapp, allow all and check permissions in Profile')
|
|
|
|
|
web_view = self.home.open_status_test_dapp()
|
|
|
|
|
dapp = self.home.dapp_tab_button.click()
|
|
|
|
|
profile = self.home.profile_button.click()
|
|
|
|
|
profile.privacy_and_security_button.click()
|
|
|
|
|
profile.dapp_permissions_button.click()
|
|
|
|
|
profile.element_by_text(test_dapp_name).click()
|
|
|
|
|
if not profile.element_by_text(self.home.status_account_name).is_element_displayed():
|
|
|
|
|
self.errors.append('Wallet permission was not granted')
|
|
|
|
|
if not profile.element_by_translation_id("chat-key").is_element_displayed():
|
|
|
|
|
self.errors.append('Contact code permission was not granted')
|
|
|
|
|
|
|
|
|
|
profile.just_fyi('revoke access and check that they are asked second time')
|
|
|
|
|
profile.revoke_access_button.click()
|
2022-05-30 13:49:30 +02:00
|
|
|
|
profile.get_back_to_home_view()
|
2022-04-14 10:48:34 +02:00
|
|
|
|
profile.dapp_tab_button.click()
|
|
|
|
|
web_view.open_tabs_button.click()
|
|
|
|
|
web_view.empty_tab_button.click()
|
|
|
|
|
dapp.open_url(test_dapp_url)
|
|
|
|
|
if not dapp.element_by_text_part(self.home.status_account_name).is_element_displayed():
|
|
|
|
|
self.errors.append('Wallet permission is not asked')
|
|
|
|
|
if dapp.allow_button.is_element_displayed():
|
|
|
|
|
dapp.allow_button.click(times_to_click=1)
|
|
|
|
|
if not dapp.element_by_translation_id("your-contact-code").is_element_displayed():
|
|
|
|
|
self.errors.append('Profile permission is not asked')
|
|
|
|
|
self.errors.verify_no_errors()
|
2022-12-13 20:07:34 +02:00
|
|
|
|
|
|
|
|
|
|
2023-01-04 11:57:05 +01:00
|
|
|
|
@pytest.mark.xdist_group(name="one_1")
|
2022-12-13 20:07:34 +02:00
|
|
|
|
@marks.new_ui_critical
|
|
|
|
|
class TestCommunityOneDeviceMerged(MultipleSharedDeviceTestCase):
|
|
|
|
|
|
|
|
|
|
def prepare_devices(self):
|
|
|
|
|
self.drivers, self.loop = create_shared_drivers(1)
|
|
|
|
|
self.sign_in = SignInView(self.drivers[0])
|
|
|
|
|
|
|
|
|
|
self.home = self.sign_in.create_user()
|
|
|
|
|
self.home.communities_tab.click_until_presence_of_element(self.home.plus_button)
|
|
|
|
|
self.community_name = self.home.get_random_chat_name()
|
|
|
|
|
self.channel_name = self.home.get_random_chat_name()
|
2023-02-28 14:44:13 +02:00
|
|
|
|
self.community = self.home.create_community(name=self.community_name, description='test description',
|
|
|
|
|
require_approval=False)
|
2022-12-13 20:07:34 +02:00
|
|
|
|
self.channel = self.community.add_channel(name=self.channel_name)
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702846)
|
|
|
|
|
def test_community_navigate_to_channel_when_relaunch(self):
|
|
|
|
|
text_message = 'some_text'
|
|
|
|
|
if not self.channel.chat_message_input.is_element_displayed():
|
|
|
|
|
self.home.communities_tab.double_click()
|
|
|
|
|
self.home.get_chat(self.community_name, community=True).click()
|
|
|
|
|
self.community.get_chat(self.channel_name).click()
|
|
|
|
|
self.channel.send_message(text_message)
|
|
|
|
|
self.channel.reopen_app()
|
|
|
|
|
if not self.channel.chat_element_by_text(text_message).is_element_displayed(30):
|
|
|
|
|
self.drivers[0].fail("Not navigated to channel view after reopening app")
|
|
|
|
|
|
2023-02-28 14:44:13 +02:00
|
|
|
|
@marks.testrail_id(702742)
|
|
|
|
|
def test_community_copy_and_paste_message_in_chat_input(self):
|
|
|
|
|
message_texts = ['mmmeowesage_text', 'https://status.im']
|
|
|
|
|
|
|
|
|
|
message_input = self.channel.chat_message_input
|
|
|
|
|
if not message_input.is_element_displayed():
|
|
|
|
|
self.home.communities_tab.double_click()
|
|
|
|
|
self.home.get_chat(self.community_name, community=True).click()
|
|
|
|
|
self.community.get_chat(self.channel_name).click()
|
|
|
|
|
|
|
|
|
|
for message in message_texts:
|
|
|
|
|
message_input.send_keys(message)
|
|
|
|
|
self.channel.send_message_button.click()
|
|
|
|
|
|
|
|
|
|
self.channel.copy_message_text(message)
|
|
|
|
|
message_input.paste_text_from_clipboard()
|
|
|
|
|
if message_input.text != message:
|
|
|
|
|
self.errors.append('Message %s text was not copied in community channel' % message)
|
|
|
|
|
message_input.clear()
|
|
|
|
|
|
|
|
|
|
self.errors.verify_no_errors()
|
2022-12-13 20:07:34 +02:00
|
|
|
|
|
|
|
|
|
|
2023-01-19 19:01:07 +01:00
|
|
|
|
@pytest.mark.xdist_group(name="two_2")
|
2022-12-13 20:07:34 +02:00
|
|
|
|
@marks.new_ui_critical
|
|
|
|
|
class TestCommunityMultipleDeviceMerged(MultipleSharedDeviceTestCase):
|
|
|
|
|
|
|
|
|
|
def prepare_devices(self):
|
|
|
|
|
self.drivers, self.loop = create_shared_drivers(2)
|
|
|
|
|
self.device_1, self.device_2 = SignInView(self.drivers[0]), SignInView(self.drivers[1])
|
|
|
|
|
self.loop.run_until_complete(run_in_parallel(((self.device_1.create_user,), (self.device_2.create_user,))))
|
|
|
|
|
self.home_1, self.home_2 = self.device_1.get_home_view(), self.device_2.get_home_view()
|
|
|
|
|
self.public_key_1, self.default_username_1 = self.home_1.get_public_key_and_username(return_username=True)
|
|
|
|
|
self.public_key_2, self.default_username_2 = self.home_2.get_public_key_and_username(return_username=True)
|
|
|
|
|
self.profile_1 = self.home_1.get_profile_view()
|
2023-03-01 12:33:58 +01:00
|
|
|
|
[home.chats_tab.click() for home in (self.home_1, self.home_2)]
|
|
|
|
|
self.home_1.add_contact(self.public_key_2)
|
2022-12-13 20:07:34 +02:00
|
|
|
|
self.home_2.handle_contact_request(self.default_username_1)
|
|
|
|
|
self.text_message = 'hello'
|
2023-02-24 20:05:30 +01:00
|
|
|
|
|
|
|
|
|
self.home_1.just_fyi("Open community to message")
|
2022-12-13 20:07:34 +02:00
|
|
|
|
self.home_1.communities_tab.click()
|
|
|
|
|
self.community_name = self.home_1.get_random_chat_name()
|
|
|
|
|
self.channel_name = self.home_1.get_random_chat_name()
|
|
|
|
|
self.home_1.create_community(name=self.community_name, description='community to test', require_approval=False)
|
|
|
|
|
self.community_1 = CommunityView(self.drivers[0])
|
|
|
|
|
self.community_1.send_invite_to_community(self.default_username_2)
|
|
|
|
|
self.channel_1 = self.community_1.add_channel(self.channel_name)
|
|
|
|
|
self.channel_1.send_message(self.text_message)
|
|
|
|
|
self.chat_2 = self.home_2.get_chat(self.default_username_1).click()
|
|
|
|
|
self.chat_2.element_by_text_part('View').click()
|
|
|
|
|
self.community_2 = CommunityView(self.drivers[1])
|
|
|
|
|
self.community_2.join_button.click()
|
2023-02-24 20:05:30 +01:00
|
|
|
|
|
|
|
|
|
self.home_1.just_fyi("Reopen community view to use new interface")
|
|
|
|
|
for home in (self.home_1, self.home_2):
|
|
|
|
|
home.jump_to_communities_home()
|
|
|
|
|
home.get_chat(self.community_name, community=True).click()
|
|
|
|
|
community_view = home.get_community_view()
|
|
|
|
|
community_view.get_channel(self.channel_name).click()
|
|
|
|
|
self.channel_2 = self.home_2.get_chat_view()
|
|
|
|
|
|
2022-12-13 20:07:34 +02:00
|
|
|
|
@marks.testrail_id(702838)
|
2023-01-24 19:26:00 +01:00
|
|
|
|
@marks.xfail(reason="blocked by 14797")
|
2022-12-13 20:07:34 +02:00
|
|
|
|
def test_community_message_send_check_timestamps_sender_username(self):
|
|
|
|
|
message = self.text_message
|
|
|
|
|
sent_time_variants = self.channel_1.convert_device_time_to_chat_timestamp()
|
|
|
|
|
timestamp = self.channel_1.chat_element_by_text(message).timestamp
|
|
|
|
|
if sent_time_variants and timestamp:
|
|
|
|
|
if timestamp not in sent_time_variants:
|
|
|
|
|
self.errors.append("Timestamp is not shown, expected: '%s', in fact: '%s'" %
|
2023-01-18 14:06:05 +01:00
|
|
|
|
(", ".join(sent_time_variants), timestamp))
|
2022-12-13 20:07:34 +02:00
|
|
|
|
for channel in self.channel_1, self.channel_2:
|
|
|
|
|
channel.verify_message_is_under_today_text(message, self.errors)
|
|
|
|
|
if self.channel_2.chat_element_by_text(message).username.text != self.default_username_1:
|
|
|
|
|
self.errors.append("Default username '%s' is not shown next to the received message" % self.username_1)
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702843)
|
|
|
|
|
def test_community_message_edit(self):
|
2023-01-18 14:06:05 +01:00
|
|
|
|
message_before_edit, message_after_edit = 'Message BEFORE edit', "Message AFTER edit 2"
|
|
|
|
|
self.channel_1.send_message(message_before_edit)
|
2022-12-13 20:07:34 +02:00
|
|
|
|
self.channel_1.edit_message_in_chat(message_before_edit, message_after_edit)
|
|
|
|
|
for channel in (self.channel_1, self.channel_2):
|
|
|
|
|
if not channel.element_by_text_part(message_after_edit).is_element_displayed(60):
|
|
|
|
|
self.errors.append('Message is not edited')
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702839)
|
|
|
|
|
def test_community_message_delete(self):
|
|
|
|
|
message_to_delete_everyone = 'delete for everyone'
|
|
|
|
|
message_to_delete_for_me = 'delete for me'
|
|
|
|
|
self.channel_2.send_message(message_to_delete_everyone)
|
|
|
|
|
self.home_2.just_fyi('Delete for message everyone. Checking that message is deleted for all members')
|
|
|
|
|
self.channel_2.delete_message_in_chat(message_to_delete_everyone)
|
|
|
|
|
for channel in (self.channel_1, self.channel_2):
|
|
|
|
|
if not channel.chat_element_by_text(message_to_delete_everyone).is_element_disappeared(30):
|
|
|
|
|
self.errors.append("Deleted message is shown in channel")
|
2023-02-24 20:05:30 +01:00
|
|
|
|
if not self.channel_2.element_by_translation_id('message-deleted-for-everyone').is_element_displayed(30):
|
|
|
|
|
self.errors.append("System message about deletion for everyone is not displayed")
|
2022-12-13 20:07:34 +02:00
|
|
|
|
|
2023-02-28 14:44:13 +02:00
|
|
|
|
self.home_2.just_fyi(
|
|
|
|
|
'Deleting message for me. Checking that message is deleted only for the author of the message')
|
2022-12-13 20:07:34 +02:00
|
|
|
|
self.channel_2.send_message(message_to_delete_for_me)
|
|
|
|
|
self.channel_2.delete_message_in_chat(message_to_delete_for_me, everyone=False)
|
|
|
|
|
if not self.channel_2.chat_element_by_text(message_to_delete_for_me).is_element_disappeared(30):
|
|
|
|
|
self.errors.append("Deleted for me message is shown in channel for the author of message")
|
|
|
|
|
if not channel.element_by_translation_id('message-deleted-for-you').is_element_displayed(30):
|
|
|
|
|
self.errors.append("System message about deletion for you is not displayed")
|
|
|
|
|
if not self.channel_1.chat_element_by_text(message_to_delete_for_me).is_element_displayed(30):
|
|
|
|
|
self.errors.append("Deleted for me message is deleted all channel members")
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702840)
|
|
|
|
|
def test_community_emoji_send_copy_paste_reply(self):
|
|
|
|
|
emoji_name = random.choice(list(emoji.EMOJI_UNICODE))
|
|
|
|
|
emoji_unicode = emoji.EMOJI_UNICODE[emoji_name]
|
|
|
|
|
emoji_message = emoji.emojize(emoji_name)
|
|
|
|
|
self.channel_1.send_message(emoji_message)
|
|
|
|
|
for channel in self.channel_1, self.channel_2:
|
|
|
|
|
if not channel.chat_element_by_text(emoji_unicode).is_element_displayed(30):
|
|
|
|
|
self.errors.append('Message with emoji was not sent or received in community channel')
|
|
|
|
|
|
2023-02-28 14:44:13 +02:00
|
|
|
|
self.channel_1.just_fyi("Can copy and paste emojis")
|
|
|
|
|
self.channel_1.copy_message_text(emoji_unicode)
|
|
|
|
|
self.channel_1.chat_message_input.paste_text_from_clipboard()
|
|
|
|
|
if self.channel_1.chat_message_input.text != emoji_unicode:
|
|
|
|
|
self.errors.append('Emoji message was not copied')
|
2022-12-13 20:07:34 +02:00
|
|
|
|
|
|
|
|
|
self.channel_1.just_fyi("Can reply to emojis")
|
|
|
|
|
self.channel_2.quote_message(emoji_unicode)
|
|
|
|
|
message_text = 'test message'
|
|
|
|
|
self.channel_2.chat_message_input.send_keys(message_text)
|
|
|
|
|
self.channel_2.send_message_button.click()
|
|
|
|
|
chat_element_1 = self.channel_1.chat_element_by_text(message_text)
|
|
|
|
|
if not chat_element_1.is_element_displayed(sec=10) or chat_element_1.replied_message_text != emoji_unicode:
|
|
|
|
|
self.errors.append('Reply message was not received by the sender')
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
2023-01-24 19:26:00 +01:00
|
|
|
|
@marks.testrail_id(702844)
|
|
|
|
|
def test_community_links_with_previews_github_youtube_twitter_gif_send_enable(self):
|
|
|
|
|
giphy_url = 'https://giphy.com/gifs/this-is-fine-QMHoU66sBXqqLqYvGO'
|
|
|
|
|
preview_urls = {'github_pr': {'url': 'https://github.com/status-im/status-mobile/pull/11707',
|
|
|
|
|
'txt': 'Update translations by jinhojang6 · Pull Request #11707 · status-im/status-mobile',
|
|
|
|
|
'subtitle': 'GitHub'},
|
|
|
|
|
'yotube_short': {
|
|
|
|
|
'url': 'https://youtu.be/Je7yErjEVt4',
|
|
|
|
|
'txt': 'Status, your gateway to Ethereum',
|
2023-02-24 20:05:30 +01:00
|
|
|
|
'subtitle': 'YouTube'},
|
|
|
|
|
'yotube_full': {
|
|
|
|
|
'url': 'https://www.youtube.com/watch?v=XN-SVmuJH2g&list=PLbrz7IuP1hrgNtYe9g6YHwHO6F3OqNMao',
|
|
|
|
|
'txt': 'Status & Keycard – Hardware-Enforced Security',
|
2023-01-24 19:26:00 +01:00
|
|
|
|
'subtitle': 'YouTube'}
|
|
|
|
|
# twitter link is temporary removed from check as current xpath locator in message.preview_title is not applicable for this type of links
|
|
|
|
|
# 'twitter': {
|
|
|
|
|
# 'url': 'https://twitter.com/ethdotorg/status/1445161651771162627?s=20',
|
|
|
|
|
# 'txt': "We've rethought how we translate content, allowing us to translate",
|
|
|
|
|
# 'subtitle': 'Twitter'
|
|
|
|
|
# }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
self.home_1.just_fyi("Check enabling and sending first gif")
|
|
|
|
|
self.channel_2.send_message(giphy_url)
|
|
|
|
|
self.channel_2.element_by_translation_id("dont-ask").click()
|
|
|
|
|
self.channel_1.element_by_text("Enable").wait_and_click()
|
|
|
|
|
|
|
|
|
|
self.channel_1.element_by_translation_id("enable-all").wait_and_click()
|
|
|
|
|
self.channel_1.click_system_back_button()
|
|
|
|
|
if not self.channel_1.get_preview_message_by_text(giphy_url).preview_image:
|
|
|
|
|
self.errors.append("No preview is shown for %s" % giphy_url)
|
|
|
|
|
for key in preview_urls:
|
|
|
|
|
self.home_2.just_fyi("Checking %s preview case" % key)
|
|
|
|
|
data = preview_urls[key]
|
|
|
|
|
self.channel_2.send_message(data['url'])
|
|
|
|
|
message = self.channel_1.get_preview_message_by_text(data['url'])
|
|
|
|
|
if message.preview_title:
|
|
|
|
|
if data['txt'] not in message.preview_title.text:
|
|
|
|
|
self.errors.append("Title '%s' does not match expected" % message.preview_title.text)
|
|
|
|
|
else:
|
|
|
|
|
self.drivers[0].fail("No preview is shown!")
|
|
|
|
|
if message.preview_subtitle:
|
|
|
|
|
if message.preview_subtitle.text != data['subtitle']:
|
|
|
|
|
self.errors.append("Subtitle '%s' does not match expected" % message.preview_subtitle.text)
|
|
|
|
|
else:
|
|
|
|
|
self.drivers[0].fail("No preview title is shown!")
|
|
|
|
|
|
|
|
|
|
self.home_2.just_fyi("Check if after do not ask again previews are not shown and no enable button appear")
|
|
|
|
|
if self.channel_2.element_by_translation_id("enable").is_element_displayed():
|
|
|
|
|
self.errors.append("Enable button is still shown after clicking on 'Don't ask again'")
|
|
|
|
|
if self.channel_2.get_preview_message_by_text(giphy_url).preview_image:
|
|
|
|
|
self.errors.append("Preview is shown for sender without permission")
|
|
|
|
|
self.errors.verify_no_errors()
|
2022-12-13 20:07:34 +02:00
|
|
|
|
|
2023-01-26 23:28:46 +01:00
|
|
|
|
@marks.testrail_id(702841)
|
|
|
|
|
def test_community_unread_messages_badge(self):
|
|
|
|
|
self.channel_1.jump_to_communities_home()
|
|
|
|
|
message = 'test message'
|
|
|
|
|
self.channel_2.send_message(message)
|
|
|
|
|
self.home_1.just_fyi('Check new messages badge is shown for community')
|
|
|
|
|
community_element_1 = self.home_1.get_chat(self.community_name, community=True)
|
|
|
|
|
if not community_element_1.new_messages_community.is_element_displayed():
|
|
|
|
|
self.errors.append('New message community badge is not shown')
|
|
|
|
|
|
|
|
|
|
community_1 = community_element_1.click()
|
2023-02-24 20:05:30 +01:00
|
|
|
|
channel_1_element = community_1.get_channel(self.channel_name)
|
|
|
|
|
|
|
|
|
|
self.home_1.just_fyi('Check new messages badge is shown for community')
|
|
|
|
|
if not community_element_1.new_messages_community.is_element_displayed():
|
|
|
|
|
self.errors.append('New messages channel badge is not shown on channel')
|
2023-01-26 23:28:46 +01:00
|
|
|
|
channel_1_element.click()
|
|
|
|
|
self.errors.verify_no_errors()
|
|
|
|
|
|
2023-02-24 20:05:30 +01:00
|
|
|
|
# @marks.testrail_id(702842)
|
|
|
|
|
# Skipped until implemented in NEW UI
|
|
|
|
|
# def test_community_mark_all_messages_as_read(self):
|
|
|
|
|
# self.channel_1.jump_to_communities_home()
|
|
|
|
|
# self.home_1.get_chat(self.community_name, community=True).click()
|
|
|
|
|
# self.channel_2.send_message(self.text_message)
|
|
|
|
|
# #self.home_1.get_chat(self.community_name).click()
|
|
|
|
|
# channel_1_element = self.community_1.get_channel(self.channel_name)
|
|
|
|
|
# if not channel_1_element.new_messages_public_chat.is_element_displayed():
|
|
|
|
|
# self.errors.append('New messages counter is not shown in public chat')
|
|
|
|
|
# mark_as_read_button = self.community_1.mark_all_messages_as_read_button
|
|
|
|
|
# channel_1_element.long_press_until_element_is_shown(mark_as_read_button)
|
|
|
|
|
# mark_as_read_button.click()
|
|
|
|
|
# if channel_1_element.new_messages_public_chat.is_element_displayed():
|
|
|
|
|
# self.errors.append('Unread messages badge is shown in community channel while there are no unread messages')
|
|
|
|
|
# self.community_1.click_system_back_button_until_element_is_shown()
|
|
|
|
|
# community_1_element = self.home_1.get_chat(self.community_name, community=True)
|
|
|
|
|
# if community_1_element.new_messages_community.is_element_displayed():
|
|
|
|
|
# self.errors.append('New messages community badge is shown on community after marking messages as read')
|
|
|
|
|
# self.errors.verify_no_errors()
|
2022-12-13 20:07:34 +02:00
|
|
|
|
|
|
|
|
|
@marks.testrail_id(702845)
|
|
|
|
|
def test_community_leave(self):
|
2023-02-24 20:05:30 +01:00
|
|
|
|
self.home_2.jump_to_communities_home()
|
2023-02-27 16:38:50 +01:00
|
|
|
|
community = self.home_2.get_chat(self.community_name, community=True)
|
2023-02-24 20:05:30 +01:00
|
|
|
|
community_to_leave = CommunityView(self.drivers[1])
|
|
|
|
|
community.long_press_until_element_is_shown(community_to_leave.leave_community_button)
|
2022-12-13 20:07:34 +02:00
|
|
|
|
community_to_leave.leave_community_button.click()
|
2023-02-02 12:16:34 +01:00
|
|
|
|
community_to_leave.leave_community_button.click()
|
2023-02-24 20:05:30 +01:00
|
|
|
|
if community.is_element_displayed():
|
2022-12-13 20:07:34 +02:00
|
|
|
|
self.errors.append('Community is still shown in the list after leave')
|
|
|
|
|
self.errors.verify_no_errors()
|