e2e: updates for community tests

This commit is contained in:
Yevheniia Berdnyk 2024-06-07 21:21:29 +03:00
parent d223151b93
commit 712e67a62e
No known key found for this signature in database
GPG Key ID: 0642C73C66214825
10 changed files with 173 additions and 88 deletions

View File

@ -170,7 +170,7 @@ class TestActivityCenterContactRequestMultipleDevicePR(MultipleSharedDeviceTestC
self.home_2.just_fyi("Device 2 sign in, user name is " + self.username_2) self.home_2.just_fyi("Device 2 sign in, user name is " + self.username_2)
self.home_2.reopen_app(sign_in=False) self.home_2.reopen_app(sign_in=False)
self.device_2.show_profiles_button.wait_and_click() self.device_2.show_profiles_button.wait_and_click()
self.device_2.get_user(username=self.username_2).click() self.device_2.get_user_profile_by_name(username=self.username_2).click()
self.device_2.sign_in() self.device_2.sign_in()
self.loop.run_until_complete(run_in_parallel(((_device_1_creates_user, {}), self.loop.run_until_complete(run_in_parallel(((_device_1_creates_user, {}),

View File

@ -115,12 +115,18 @@ class TestGroupChatMultipleDeviceMergedNewUI(MultipleSharedDeviceTestCase):
self.chats[2].add_remove_same_reaction(message=message, emoji="thumbs-up") self.chats[2].add_remove_same_reaction(message=message, emoji="thumbs-up")
self.chats[2].set_reaction(message=message, emoji="laugh") self.chats[2].set_reaction(message=message, emoji="laugh")
for i in range(3): def _check_reactions_count(chat_view_index):
self.chats[i].just_fyi("Checking reactions count for each group member and admin") self.chats[chat_view_index].just_fyi("Checking reactions count for each group member and admin")
message_element = self.chats[i].chat_element_by_text(message) chat_element = self.chats[chat_view_index].chat_element_by_text(message)
message_element.emojis_below_message(emoji="thumbs-up").wait_for_element_text(2) chat_element.emojis_below_message(emoji="thumbs-up").wait_for_element_text(2)
message_element.emojis_below_message(emoji="love").wait_for_element_text(1) chat_element.emojis_below_message(emoji="love").wait_for_element_text(1)
message_element.emojis_below_message(emoji="laugh").wait_for_element_text(1) chat_element.emojis_below_message(emoji="laugh").wait_for_element_text(1)
self.loop.run_until_complete(run_in_parallel((
(_check_reactions_count, {'chat_view_index': 0}),
(_check_reactions_count, {'chat_view_index': 1}),
(_check_reactions_count, {'chat_view_index': 2})
)))
self.chats[0].just_fyi("Admin checks info about voted users") self.chats[0].just_fyi("Admin checks info about voted users")
self.chats[0].chat_element_by_text(message).emojis_below_message( self.chats[0].chat_element_by_text(message).emojis_below_message(
@ -163,15 +169,23 @@ class TestGroupChatMultipleDeviceMergedNewUI(MultipleSharedDeviceTestCase):
self.chats[2].add_remove_same_reaction(message=message, emoji="laugh") self.chats[2].add_remove_same_reaction(message=message, emoji="laugh")
self.chats[2].add_remove_same_reaction(message=message, emoji="sad") self.chats[2].add_remove_same_reaction(message=message, emoji="sad")
for i in range(3): def _check_reactions_count_after_change(chat_view_index):
self.chats[i].just_fyi("Checking reactions count for each group member and admin after they were changed") self.chats[chat_view_index].just_fyi(
message_element = self.chats[i].chat_element_by_text(message) "Checking reactions count for each group member and admin after they were changed")
chat_element = self.chats[chat_view_index].chat_element_by_text(message)
try: try:
message_element.emojis_below_message(emoji="thumbs-up").wait_for_element_text(1) chat_element.emojis_below_message(emoji="thumbs-up").wait_for_element_text(1)
message_element.emojis_below_message(emoji="love").wait_for_element_text(1) chat_element.emojis_below_message(emoji="love").wait_for_element_text(1)
message_element.emojis_below_message(emoji="sad").wait_for_element_text(2) chat_element.emojis_below_message(emoji="sad").wait_for_element_text(2)
except (Failed, NoSuchElementException): except (Failed, NoSuchElementException):
self.errors.append("Incorrect reactions count for %s after changing the reactions" % self.usernames[i]) self.errors.append(
"Incorrect reactions count for %s after changing the reactions" % self.usernames[chat_view_index])
self.loop.run_until_complete(run_in_parallel((
(_check_reactions_count_after_change, {'chat_view_index': 0}),
(_check_reactions_count_after_change, {'chat_view_index': 1}),
(_check_reactions_count_after_change, {'chat_view_index': 2})
)))
self.chats[0].just_fyi("Admin relogins") self.chats[0].just_fyi("Admin relogins")
self.chats[0].reopen_app() self.chats[0].reopen_app()
@ -286,11 +300,16 @@ class TestGroupChatMultipleDeviceMergedNewUI(MultipleSharedDeviceTestCase):
@marks.testrail_id(702808) @marks.testrail_id(702808)
def test_group_chat_offline_pn(self): def test_group_chat_offline_pn(self):
for i in range(1, 3): def _proceed_to_chat(index):
self.homes[i].navigate_back_to_home_view() self.homes[index].navigate_back_to_home_view()
self.homes[i].chats_tab.click() self.homes[index].chats_tab.click()
self.homes[i].groups_tab.click() self.homes[index].groups_tab.click()
self.homes[i].get_chat(self.chat_name).click() self.homes[index].get_chat(self.chat_name).click()
self.loop.run_until_complete(run_in_parallel((
(_proceed_to_chat, {'index': 1}),
(_proceed_to_chat, {'index': 2})
)))
message_1, message_2 = 'message from old member', 'message from new member' message_1, message_2 = 'message from old member', 'message from new member'
@ -318,11 +337,18 @@ class TestGroupChatMultipleDeviceMergedNewUI(MultipleSharedDeviceTestCase):
self.homes[0].chats_tab.click() self.homes[0].chats_tab.click()
self.homes[0].get_chat(self.chat_name).click() self.homes[0].get_chat(self.chat_name).click()
self.homes[0].just_fyi("check that messages are shown for every member") def _check_messages(index):
for i in range(3): self.chats[index].just_fyi("Check that messages are shown for user %s" % self.usernames[index])
for message in (message_1, message_2): for message_text in (message_1, message_2):
if not self.chats[i].chat_element_by_text(message).is_element_displayed(30): if not self.chats[index].chat_element_by_text(message_text).is_element_displayed(30):
self.errors.append('%s if not shown for device %s' % (message, str(i))) self.errors.append('%s if not shown for device %s' % (message_text, index))
self.loop.run_until_complete(run_in_parallel((
(_check_messages, {'index': 0}),
(_check_messages, {'index': 1}),
(_check_messages, {'index': 2})
)))
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(702732) @marks.testrail_id(702732)
@ -381,28 +407,33 @@ class TestGroupChatMultipleDeviceMergedNewUI(MultipleSharedDeviceTestCase):
self.chats[1].chat_element_by_text(self.message_4).pinned_by_label.is_element_displayed(30)): self.chats[1].chat_element_by_text(self.message_4).pinned_by_label.is_element_displayed(30)):
self.errors.append("Message 4 is not pinned in group chat after unpinning previous one") self.errors.append("Message 4 is not pinned in group chat after unpinning previous one")
self.chats[0].just_fyi("Check pinned messages count and content") def _check_pinned_messages(index):
for chat_number, group_chat in enumerate([self.chats[0], self.chats[1]]): self.chats[index].just_fyi("Check pinned messages count and content for user %s" % self.usernames[index])
count = group_chat.pinned_messages_count.text count = self.chats[index].pinned_messages_count.text
if count != '3': if count != '3':
self.errors.append( self.errors.append(
"Pinned messages count %s doesn't match expected 3 for user %s" % (count, chat_number + 1)) "Pinned messages count %s doesn't match expected 3 for user %s" % (count, self.usernames[index]))
group_chat.pinned_messages_count.click() self.chats[index].pinned_messages_count.click()
for message in self.message_1, self.message_3, self.message_4: for message_text in self.message_1, self.message_3, self.message_4:
pinned_by = group_chat.pinned_messages_list.get_message_pinned_by_text(message) pinned_by = self.chats[index].pinned_messages_list.get_message_pinned_by_text(message_text)
if pinned_by.is_element_displayed(): if pinned_by.is_element_displayed():
text = pinned_by.text.strip() text = pinned_by.text.strip()
expected_text = "You" if chat_number == 0 else self.usernames[0] expected_text = "You" if index == 0 else self.usernames[0]
if text != expected_text: if text != expected_text:
self.errors.append( self.errors.append(
"Pinned by '%s' doesn't match expected '%s' for user %s" % ( "Pinned by '%s' doesn't match expected '%s' for user %s" % (
text, expected_text, chat_number + 1) text, expected_text, self.usernames[index])
) )
else: else:
self.errors.append( self.errors.append(
"Message '%s' is missed on Pinned messages list for user %s" % (message, chat_number + 1) "Message '%s' is missed on Pinned messages list for user %s" % (message, self.usernames[index])
) )
self.loop.run_until_complete(run_in_parallel((
(_check_pinned_messages, {'index': 0}),
(_check_pinned_messages, {'index': 1})
)))
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(703495) @marks.testrail_id(703495)

View File

@ -33,43 +33,6 @@ class TestCommunityOneDeviceMerged(MultipleSharedDeviceTestCase):
self.community_view = self.home.get_community_view() self.community_view = self.home.get_community_view()
self.channel = self.community_view.get_channel(self.channel_name).click() self.channel = self.community_view.get_channel(self.channel_name).click()
@marks.testrail_id(703503)
@marks.xfail(reason="Curated communities not loading, https://github.com/status-im/status-mobile/issues/17852",
run=False)
def test_community_discovery(self):
self.home.navigate_back_to_home_view()
self.home.communities_tab.click()
self.home.discover_communities_button.click()
self.home.community_card_item.wait_for_visibility_of_element(30)
if len(self.home.community_card_item.find_elements()) > 1:
contributors_test_community_attributes = "Test Community", 'Open for anyone', 'Web3', 'Software dev'
for text in contributors_test_community_attributes:
if not self.home.element_by_text(text).is_element_displayed(10):
self.errors.append("'%s' text is not in Discovery!" % text)
self.home.element_by_text(contributors_test_community_attributes[0]).click()
element_templates = {
self.community_view.join_button: 'discovery_join_button.png',
self.community_view.get_channel_avatar(): 'discovery_general_channel.png',
}
for element, template in element_templates.items():
if element.is_element_differs_from_template(template):
element.save_new_screenshot_of_element('%s_different.png' % template.split('.')[0])
self.errors.append(
"Element %s is different from expected template %s!" % (element.locator, template))
self.community_view.navigate_back_to_home_view()
self.home.communities_tab.click()
self.home.discover_communities_button.click()
self.home.community_card_item.wait_for_visibility_of_element(30)
self.home.swipe_up()
status_ccs_community_attributes = '(old) Status CCs', 'Community for Status CCs', 'Ethereum', \
'Software dev', 'Web3'
for text in status_ccs_community_attributes:
if not self.community_view.element_by_text(text).is_element_displayed(10):
self.errors.append("'%s' text is not shown for (old) Status CCs!" % text)
self.errors.verify_no_errors()
@marks.testrail_id(702846) @marks.testrail_id(702846)
def test_community_navigate_to_channel_when_relaunch(self): def test_community_navigate_to_channel_when_relaunch(self):
text_message = 'some_text' text_message = 'some_text'
@ -261,7 +224,7 @@ class TestCommunityOneDeviceMerged(MultipleSharedDeviceTestCase):
self.home.just_fyi("Check that can remove user from logged out state") self.home.just_fyi("Check that can remove user from logged out state")
self.home.reopen_app(sign_in=False) self.home.reopen_app(sign_in=False)
self.sign_in.show_profiles_button.wait_and_click() self.sign_in.show_profiles_button.wait_and_click()
user_card = self.sign_in.get_user(username=self.username) user_card = self.sign_in.get_user_profile_by_name(username=self.username)
user_card.open_user_options() user_card.open_user_options()
self.sign_in.remove_profile_button.click() self.sign_in.remove_profile_button.click()
if not self.sign_in.element_by_translation_id("remove-profile-confirm-message").is_element_displayed(30): if not self.sign_in.element_by_translation_id("remove-profile-confirm-message").is_element_displayed(30):
@ -276,6 +239,67 @@ class TestCommunityOneDeviceMerged(MultipleSharedDeviceTestCase):
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(703503)
def test_community_discovery(self):
try:
# workaround for case if a user is logged out in the previous test
self.sign_in.get_user_profile_by_index(index=1).click()
self.sign_in.sign_in()
except NoSuchElementException:
pass
self.home.navigate_back_to_home_view()
self.home.just_fyi("Turn off testnet in the profile settings")
profile = self.home.profile_button.click()
profile.advanced_button.scroll_and_click()
profile.testnet_mode_toggle.click()
profile.ok_button.click()
self.sign_in.sign_in()
self.home.just_fyi("Check Discover Communities content")
self.home.communities_tab.click()
self.home.discover_communities_button.click()
self.home.community_card_item.wait_for_elements(seconds=120)
expected_communities = {
' 0xUX': ['Design', 'Ethereum', 'Collaboration'],
'Status': ['Web3', 'Blockchain', 'Ethereum'],
'Status Inu': ['News', 'Social', 'Web3'],
}
for community_name, tags in expected_communities.items():
self.home.just_fyi("Check %s community tags in the Discover communities screen" % community_name)
card = self.home.get_discover_community_card_by_name(community_name=community_name)
try:
card.wait_for_visibility_of_element(30)
if community_name == 'Status':
card.swipe_to_web_element()
missing_tags = list()
for text in tags:
try:
card.get_child_element_by_text(text=text).wait_for_element()
except TimeoutException:
missing_tags.append(text)
if missing_tags:
self.errors.append("Community '%s' is missing tag(s) %s." % (community_name, ','.join(tags)))
if community_name == 'Status':
self.home.just_fyi("Check Status community screen")
card.click()
if self.community_view.join_button.is_element_differs_from_template(
'status_community_join_button.png'):
self.errors.append("Status community Join button is different from expected template.")
if self.community_view.community_logo.is_element_differs_from_template('status_community_logo.png'):
self.errors.append("Status community logo is different from expected template.")
self.community_view.close_community_view_button.click()
self.home.discover_communities_button.click()
self.home.swipe_up()
except TimeoutException:
self.errors.append("Community '%s' is not in the Discover Communities list." % community_name)
self.errors.verify_no_errors()
# Note: this test should always be the LAST ONE in the group because it turns on mainnet in the app!
@pytest.mark.xdist_group(name="new_three_2") @pytest.mark.xdist_group(name="new_three_2")
@marks.new_ui_critical @marks.new_ui_critical
@ -998,6 +1022,8 @@ class TestCommunityMultipleDeviceMergedTwo(MultipleSharedDeviceTestCase):
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(702948) @marks.testrail_id(702948)
@marks.xfail(reason="Can't enter channel after community is fetched for the first time, " \
"https://github.com/status-im/status-mobile/issues/20395")
def test_community_hashtag_links_to_community_channels(self): def test_community_hashtag_links_to_community_channels(self):
for home in self.homes: for home in self.homes:
home.navigate_back_to_home_view() home.navigate_back_to_home_view()
@ -1098,6 +1124,8 @@ class TestCommunityMultipleDeviceMergedTwo(MultipleSharedDeviceTestCase):
self.errors.verify_no_errors() self.errors.verify_no_errors()
@marks.testrail_id(703629) @marks.testrail_id(703629)
@marks.xfail(reason="Can't enter channel after community is fetched for the first time, " \
"https://github.com/status-im/status-mobile/issues/20395")
def test_community_join_when_node_owner_offline(self): def test_community_join_when_node_owner_offline(self):
for home in self.homes: for home in self.homes:
home.navigate_back_to_home_view() home.navigate_back_to_home_view()
@ -1143,8 +1171,8 @@ class TestCommunityMultipleDeviceMergedTwo(MultipleSharedDeviceTestCase):
general_channel.click() general_channel.click()
if not self.channel_2.chat_element_by_text(control_message_general_chat).is_element_displayed(30): if not self.channel_2.chat_element_by_text(control_message_general_chat).is_element_displayed(30):
self.errors.append( self.errors.append(
"Message in community channel is not visible for user before join, it was indicated as" \ "Message in community channel is not visible for user before join, it was indicated as " \
"%s sent for the sender before he went offline" % "" if message_sent else "not") "%s sent for the sender before he went offline" % ("" if message_sent else "not"))
else: else:
self.errors.append("Community channel is not displayed for user before join") self.errors.append("Community channel is not displayed for user before join")
self.community_2.toast_content_element.wait_for_invisibility_of_element(30) self.community_2.toast_content_element.wait_for_invisibility_of_element(30)

View File

@ -367,6 +367,9 @@ class BaseElement(object):
def exclude_emoji(value): def exclude_emoji(value):
return 'emoji' if value in emoji.UNICODE_EMOJI else value return 'emoji' if value in emoji.UNICODE_EMOJI else value
def get_child_element_by_text(self, text: str):
return BaseElement(self.driver, prefix=self.locator, xpath="//*[@text='%s']" % text)
class EditBox(BaseElement): class EditBox(BaseElement):

View File

@ -406,10 +406,10 @@ class CommunityView(HomeView):
#### NEW UI #### NEW UI
# Communities initial page # Communities initial page
self.close_community_view_button = Button( self.close_community_view_button = Button(self.driver, accessibility_id="back-button")
self.driver,
xpath="//*[@content-desc='community-options-for-community']/../*[1]//android.widget.ImageView")
self.community_title = Text(self.driver, accessibility_id="community-title") self.community_title = Text(self.driver, accessibility_id="community-title")
self.community_logo = BaseElement(
self.driver, xpath="//*[@content-desc='community-title']/preceding-sibling::*/android.widget.ImageView")
self.community_description_text = Text(self.driver, accessibility_id="community-description-text") self.community_description_text = Text(self.driver, accessibility_id="community-description-text")
self.community_status_joined = Text(self.driver, accessibility_id="status-tag-positive") self.community_status_joined = Text(self.driver, accessibility_id="status-tag-positive")
self.community_status_pending = Text(self.driver, accessibility_id="status-tag-pending") self.community_status_pending = Text(self.driver, accessibility_id="status-tag-pending")

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

View File

@ -603,3 +603,10 @@ class HomeView(BaseView):
address = self.copy_wallet_address() address = self.copy_wallet_address()
self.click_system_back_button() self.click_system_back_button()
return address return address
def get_discover_community_card_by_name(self, community_name: str):
return BaseElement(
self.driver,
xpath="//*[@content-desc='%s'][descendant::*[@content-desc='chat-name-text'][@text='%s']]" % (
self.community_card_item.accessibility_id, community_name)
)

View File

@ -61,7 +61,7 @@ class ENSusernames(Button):
class AdvancedButton(Button): class AdvancedButton(Button):
def __init__(self, driver): def __init__(self, driver):
super().__init__(driver, accessibility_id="advanced-button") super().__init__(driver, accessibility_id="icon, Advanced, label-component, icon")
def click(self): def click(self):
self.scroll_to_element().click() self.scroll_to_element().click()
@ -363,6 +363,8 @@ class ProfileView(BaseView):
self.profile_blocked_users_button = Button(self.driver, accessibility_id="Blocked users, label-component, icon") self.profile_blocked_users_button = Button(self.driver, accessibility_id="Blocked users, label-component, icon")
self.profile_legacy_button = Button(self.driver, self.profile_legacy_button = Button(self.driver,
accessibility_id="icon, Legacy settings, label-component, icon") accessibility_id="icon, Legacy settings, label-component, icon")
self.testnet_mode_toggle = Button(self.driver,
xpath="//*[@content-desc='test-networks-enabled']/android.widget.Switch")
def switch_network(self, network='Mainnet with upstream RPC'): def switch_network(self, network='Mainnet with upstream RPC'):
self.driver.info("## Switch network to '%s'" % network, device=False) self.driver.info("## Switch network to '%s'" % network, device=False)

View File

@ -12,7 +12,8 @@ from views.base_view import BaseView
class MultiAccountButton(Button): class MultiAccountButton(Button):
class Username(Text): class Username(Text):
def __init__(self, driver, locator_value): def __init__(self, driver, locator_value):
super(MultiAccountButton.Username, self).__init__(driver, super(MultiAccountButton.Username, self).__init__(
driver,
xpath="%s//android.widget.TextView[@content-desc='username']" % locator_value) xpath="%s//android.widget.TextView[@content-desc='username']" % locator_value)
def __init__(self, driver, position=1): def __init__(self, driver, position=1):
@ -123,10 +124,17 @@ class TermsOfUseLink(Button):
class UserProfileElement(Button): class UserProfileElement(Button):
def __init__(self, driver, username): def __init__(self, driver, username: str = None, index: int = None):
self.username = username self.username = username
super().__init__(driver, self.index = index
xpath="//*[@text='%s']//ancestor::android.view.ViewGroup[@content-desc='profile-card']" % username) if username:
super().__init__(
driver,
xpath="//*[@text='%s']//ancestor::android.view.ViewGroup[@content-desc='profile-card']" % self.username)
elif index:
super().__init__(driver, xpath="(//*[@content-desc='profile-card'])[%s]" % self.index)
else:
raise AttributeError("Either username or profile index should be defined")
def open_user_options(self): def open_user_options(self):
Button(self.driver, xpath='%s//*[@content-desc="profile-card-options"]' % self.locator).click() Button(self.driver, xpath='%s//*[@content-desc="profile-card-options"]' % self.locator).click()
@ -154,7 +162,8 @@ class SignInView(BaseView):
self.privacy_policy_link = PrivacyPolicyLink(self.driver) self.privacy_policy_link = PrivacyPolicyLink(self.driver)
self.terms_of_use_link = TermsOfUseLink(self.driver) self.terms_of_use_link = TermsOfUseLink(self.driver)
self.keycard_storage_button = KeycardKeyStorageButton(self.driver) self.keycard_storage_button = KeycardKeyStorageButton(self.driver)
self.first_username_on_choose_chat_name = Text(self.driver, self.first_username_on_choose_chat_name = Text(
self.driver,
xpath="//*[@content-desc='select-account-button-0']//android.widget.TextView[1]") xpath="//*[@content-desc='select-account-button-0']//android.widget.TextView[1]")
self.get_keycard_banner = Button(self.driver, translation_id="get-a-keycard") self.get_keycard_banner = Button(self.driver, translation_id="get-a-keycard")
self.accept_tos_checkbox = self.checkbox_button self.accept_tos_checkbox = self.checkbox_button
@ -348,7 +357,12 @@ class SignInView(BaseView):
print(str(e)) print(str(e))
self.driver.info('## Exporting database is finished!', device=False) self.driver.info('## Exporting database is finished!', device=False)
def get_user(self, username): def get_user_profile_by_name(self, username: str):
self.driver.info("Getting username card by '%s'" % username) self.driver.info("Getting username card by '%s'" % username)
expected_element = UserProfileElement(self.driver, username) expected_element = UserProfileElement(self.driver, username=username)
return expected_element if expected_element.is_element_displayed(10) else self.driver.fail("User is not found!") return expected_element if expected_element.is_element_displayed(10) else self.driver.fail(
"User %s is not found!" % username)
def get_user_profile_by_index(self, index: int):
self.driver.info("Getting username card by index %s" % index)
return UserProfileElement(self.driver, index=index)