2023-11-16 13:48:17 +03:00
|
|
|
import os
|
|
|
|
|
2023-09-28 13:45:49 +07:00
|
|
|
import allure
|
2023-10-06 10:17:13 +07:00
|
|
|
import pyperclip
|
2023-09-28 13:45:49 +07:00
|
|
|
import pytest
|
|
|
|
from allure_commons._allure import step
|
2023-12-07 16:47:34 +00:00
|
|
|
from . import marks
|
2023-09-28 13:45:49 +07:00
|
|
|
|
|
|
|
import configs.testpath
|
|
|
|
import constants
|
|
|
|
import driver
|
|
|
|
from constants import UserAccount
|
2023-10-06 10:17:13 +07:00
|
|
|
from constants.syncing import SyncingSettings
|
2023-09-28 13:45:49 +07:00
|
|
|
from gui.components.onboarding.before_started_popup import BeforeStartedPopUp
|
|
|
|
from gui.components.onboarding.beta_consent_popup import BetaConsentPopup
|
2023-11-27 13:44:30 +03:00
|
|
|
from gui.components.settings.sync_new_device_popup import SyncNewDevicePopup
|
2023-09-28 13:45:49 +07:00
|
|
|
from gui.components.splash_screen import SplashScreen
|
|
|
|
from gui.main_window import MainWindow
|
2023-10-06 10:17:13 +07:00
|
|
|
from gui.screens.onboarding import AllowNotificationsView, WelcomeToStatusView, SyncResultView, \
|
|
|
|
SyncCodeView, SyncDeviceFoundView
|
2023-09-28 13:45:49 +07:00
|
|
|
|
2023-12-07 16:47:34 +00:00
|
|
|
pytestmark = marks
|
2023-09-28 13:45:49 +07:00
|
|
|
|
2023-12-22 17:34:36 +03:00
|
|
|
|
2023-10-06 10:17:13 +07:00
|
|
|
@pytest.fixture
|
|
|
|
def sync_screen(main_window) -> SyncCodeView:
|
|
|
|
with step('Open Syncing view'):
|
|
|
|
if configs.system.IS_MAC:
|
|
|
|
AllowNotificationsView().wait_until_appears().allow()
|
|
|
|
BeforeStartedPopUp().get_started()
|
|
|
|
wellcome_screen = WelcomeToStatusView().wait_until_appears()
|
|
|
|
return wellcome_screen.sync_existing_user().open_sync_code_view()
|
|
|
|
|
|
|
|
|
2023-09-28 13:45:49 +07:00
|
|
|
@allure.testcase('https://ethstatus.testrail.net/index.php?/cases/view/703592', 'Sync device during onboarding')
|
|
|
|
@pytest.mark.case(703592)
|
2024-04-18 19:40:30 +03:00
|
|
|
# @pytest.mark.critical TODO: fix the locator to use object name for button paste
|
2024-03-28 12:19:23 +03:00
|
|
|
def test_sync_device_during_onboarding(multiple_instances):
|
2024-03-28 14:37:24 +03:00
|
|
|
user: UserAccount = constants.user_with_random_attributes_1
|
2023-09-28 13:45:49 +07:00
|
|
|
main_window = MainWindow()
|
|
|
|
|
2024-03-28 12:19:23 +03:00
|
|
|
with multiple_instances(user_data=None) as aut_one, multiple_instances(user_data=None) as aut_two:
|
2023-09-28 13:45:49 +07:00
|
|
|
with step('Get syncing code in first instance'):
|
|
|
|
aut_one.attach()
|
|
|
|
main_window.prepare()
|
|
|
|
main_window.authorize_user(user)
|
|
|
|
sync_settings_view = main_window.left_panel.open_settings().left_panel.open_syncing_settings()
|
|
|
|
sync_settings_view.is_instructions_header_present()
|
|
|
|
sync_settings_view.is_instructions_subtitle_present()
|
|
|
|
if configs.DEV_BUILD:
|
|
|
|
sync_settings_view.is_backup_button_present()
|
|
|
|
setup_syncing = main_window.left_panel.open_settings().left_panel.open_syncing_settings().set_up_syncing(
|
|
|
|
user.password)
|
|
|
|
sync_code = setup_syncing.syncing_code
|
|
|
|
setup_syncing.done()
|
|
|
|
main_window.hide()
|
|
|
|
|
|
|
|
with step('Verify syncing code is correct'):
|
|
|
|
sync_code_fields = sync_code.split(':')
|
|
|
|
assert sync_code_fields[0] == 'cs3'
|
|
|
|
assert len(sync_code_fields) == 5
|
|
|
|
|
|
|
|
with step('Open sync code form in second instance'):
|
|
|
|
aut_two.attach()
|
|
|
|
main_window.prepare()
|
|
|
|
if configs.system.IS_MAC:
|
|
|
|
AllowNotificationsView().wait_until_appears().allow()
|
|
|
|
BeforeStartedPopUp().get_started()
|
|
|
|
wellcome_screen = WelcomeToStatusView().wait_until_appears()
|
|
|
|
sync_view = wellcome_screen.sync_existing_user().open_sync_code_view()
|
|
|
|
|
|
|
|
with step('Paste sync code on second instance and wait until device is synced'):
|
2023-10-06 10:17:13 +07:00
|
|
|
sync_start = sync_view.open_enter_sync_code_form()
|
|
|
|
sync_start.paste_sync_code()
|
|
|
|
sync_device_found = SyncDeviceFoundView()
|
2023-11-22 13:42:26 +03:00
|
|
|
assert driver.waitFor(
|
|
|
|
lambda: 'Device found!' in sync_device_found.device_found_notifications, 15000)
|
2023-12-22 17:34:36 +03:00
|
|
|
try:
|
|
|
|
assert driver.waitForObjectExists(SyncResultView().real_name, 15000), \
|
|
|
|
f'Sync result view is not shown within 15 seconds'
|
|
|
|
except (Exception, AssertionError) as ex:
|
|
|
|
raise ex
|
|
|
|
sync_result = SyncResultView()
|
2023-11-22 13:42:26 +03:00
|
|
|
assert driver.waitFor(
|
2024-02-21 13:39:52 +07:00
|
|
|
lambda: 'Device synced!' in sync_result.device_synced_notifications, 18000)
|
2023-10-06 10:17:13 +07:00
|
|
|
assert user.name in sync_device_found.device_found_notifications
|
2023-09-28 13:45:49 +07:00
|
|
|
|
|
|
|
with step('Sign in to synced account'):
|
|
|
|
sync_result.sign_in()
|
2023-10-31 11:34:02 +03:00
|
|
|
SplashScreen().wait_until_hidden()
|
2023-11-16 13:48:17 +03:00
|
|
|
if not configs.system.TEST_MODE:
|
|
|
|
BetaConsentPopup().confirm()
|
2023-09-28 13:45:49 +07:00
|
|
|
|
|
|
|
with step('Verify user details are the same with user in first instance'):
|
2023-12-22 17:34:36 +03:00
|
|
|
online_identifier = main_window.left_panel.open_online_identifier()
|
|
|
|
assert online_identifier.get_user_name == user.name, \
|
2023-12-23 10:27:34 +03:00
|
|
|
f'Name in online identifier and display name do not match'
|
2023-10-06 10:17:13 +07:00
|
|
|
|
|
|
|
|
|
|
|
@allure.testcase('https://ethstatus.testrail.net/index.php?/cases/view/703631', 'Wrong sync code')
|
|
|
|
@pytest.mark.case(703631)
|
|
|
|
@pytest.mark.parametrize('wrong_sync_code', [
|
|
|
|
pytest.param('9rhfjgfkgfj890tjfgtjfgshjef900')
|
|
|
|
])
|
|
|
|
def test_wrong_sync_code(sync_screen, wrong_sync_code):
|
|
|
|
with step('Open sync code form'):
|
|
|
|
sync_view = sync_screen.open_enter_sync_code_form()
|
|
|
|
|
|
|
|
with step('Paste wrong sync code on second instance and check that error message appears'):
|
|
|
|
pyperclip.copy(wrong_sync_code)
|
|
|
|
sync_view.paste_sync_code()
|
|
|
|
assert SyncingSettings.SYNC_CODE_IS_WRONG_TEXT.value == sync_view.sync_code_error_message, f'Wrong sync code message did not appear'
|
2023-11-27 13:44:30 +03:00
|
|
|
|
|
|
|
|
|
|
|
@allure.testcase('https://ethstatus.testrail.net/index.php?/cases/view/703591', 'Generate sync code. Negative')
|
|
|
|
@pytest.mark.case(703591)
|
|
|
|
def test_cancel_setup_syncing(main_screen: MainWindow):
|
|
|
|
with step('Open syncing settings'):
|
|
|
|
sync_settings_view = main_screen.left_panel.open_settings().left_panel.open_syncing_settings()
|
|
|
|
sync_settings_view.is_instructions_header_present()
|
|
|
|
sync_settings_view.is_instructions_subtitle_present()
|
|
|
|
if configs.DEV_BUILD:
|
|
|
|
sync_settings_view.is_backup_button_present()
|
|
|
|
with step('Click setup syncing and close authenticate popup'):
|
|
|
|
main_screen.left_panel.open_settings().left_panel.open_syncing_settings().click_setup_syncing().close_authenticate_popup()
|
|
|
|
sync_new_device_popup = SyncNewDevicePopup().wait_until_appears()
|
|
|
|
|
|
|
|
with step('Verify error messages appear'):
|
|
|
|
assert sync_new_device_popup.primary_error_message == SyncingSettings.SYNC_SETUP_ERROR_PRIMARY.value
|
|
|
|
assert sync_new_device_popup.secondary_error_message == SyncingSettings.SYNC_SETUP_ERROR_SECONDARY.value
|