mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-23 21:11:55 +00:00
b09504be36
* test(pytest) The driver methods added. Wrappers for UI elements added. #67 * test(pytest) Squishserver added #68 * test(pytest) Attach/Detach AUT methods added #69 * test(pytest) Main window handler added #70 * test(pytest) Save screenshot on fail added #71 * test(pytest) Wait for squishserver added #71 * test(pytest) Setup Windows #71 * Generate new keys (#11804) * test(pytest) Image comparison methods added #76 * test(pytest) Tesseract methods added #77 * test(pytest) The Methods to search color on image added #80 * test(onboarding) Test on generation new keys added #75 * test(pytest) Handlers for OS Native File dialog added #81 * test(Onboarding) Test on Profile image added #83 * Allure and TestRail integration (#11806) * test(Allure) Steps descriptions added #72 * test(TestRail) Integration #72
68 lines
2.3 KiB
Python
68 lines
2.3 KiB
Python
import time
|
|
|
|
import allure
|
|
|
|
import configs
|
|
import constants
|
|
import driver
|
|
from gui.components.profile_popup import ProfilePopup
|
|
from gui.elements.qt.button import Button
|
|
from gui.elements.qt.object import QObject
|
|
from gui.elements.qt.text_label import TextLabel
|
|
|
|
|
|
class UserCanvas(QObject):
|
|
|
|
def __init__(self):
|
|
super(UserCanvas, self).__init__('o_StatusListView')
|
|
self._always_active_button = Button('userContextmenu_AlwaysActiveButton')
|
|
self._inactive_button = Button('userContextmenu_InActiveButton')
|
|
self._automatic_button = Button('userContextmenu_AutomaticButton')
|
|
self._view_my_profile_button = Button('userContextMenu_ViewMyProfileAction')
|
|
self._user_name_text_label = TextLabel('userLabel_StyledText')
|
|
self._profile_image = QObject('o_StatusIdenticonRing')
|
|
|
|
@property
|
|
@allure.step('Get profile image')
|
|
def profile_image(self):
|
|
return self._profile_image.image
|
|
|
|
@property
|
|
@allure.step('Get user name')
|
|
def user_name(self) -> str:
|
|
return self._user_name_text_label.text
|
|
|
|
@allure.step('Wait until appears {0}')
|
|
def wait_until_appears(self, timeout_msec: int = configs.timeouts.UI_LOAD_TIMEOUT_MSEC):
|
|
super(UserCanvas, self).wait_until_appears(timeout_msec)
|
|
time.sleep(1)
|
|
return self
|
|
|
|
@allure.step('Set user state online')
|
|
def set_user_state_online(self):
|
|
self._always_active_button.click()
|
|
self.wait_until_hidden()
|
|
|
|
@allure.step('Set user state offline')
|
|
def set_user_state_offline(self):
|
|
self._inactive_button.click()
|
|
self.wait_until_hidden()
|
|
|
|
@allure.step('Set user automatic state')
|
|
def set_user_automatic_state(self):
|
|
self._automatic_button.click()
|
|
self.wait_until_hidden()
|
|
|
|
@allure.step('Open Profile popup')
|
|
def open_profile_popup(self) -> ProfilePopup:
|
|
self._view_my_profile_button.click()
|
|
return ProfilePopup().wait_until_appears()
|
|
|
|
@allure.step('Verify: User image contains text')
|
|
def is_user_image_contains(self, text: str):
|
|
# To remove all artifacts, the image cropped.
|
|
crop = driver.UiTypes.ScreenRectangle(
|
|
5, 5, self._profile_image.image.width-10, self._profile_image.image.height-10
|
|
)
|
|
return self._profile_image.image.has_text(text, constants.tesseract.text_on_profile_image, crop=crop)
|