2023-08-04 20:27:03 +02:00
|
|
|
import time
|
|
|
|
from copy import deepcopy
|
|
|
|
|
|
|
|
import configs.timeouts
|
2023-09-13 09:47:51 +02:00
|
|
|
import driver
|
2023-08-04 20:27:03 +02:00
|
|
|
|
|
|
|
if configs.system.IS_MAC:
|
2023-08-22 17:15:25 +02:00
|
|
|
from atomacos._a11y import _running_apps_with_bundle_id
|
2023-08-04 20:27:03 +02:00
|
|
|
import atomacos
|
|
|
|
|
|
|
|
BUNDLE_ID = 'im.Status.NimStatusClient'
|
|
|
|
|
|
|
|
|
|
|
|
# https://pypi.org/project/atomacos/
|
|
|
|
|
|
|
|
|
|
|
|
def attach_atomac(timeout_sec: int = configs.timeouts.UI_LOAD_TIMEOUT_SEC):
|
2023-08-22 17:15:25 +02:00
|
|
|
def from_bundle_id(bundle_id):
|
|
|
|
"""
|
|
|
|
Get the top level element for the application with the specified
|
|
|
|
bundle ID, such as com.vmware.fusion.
|
|
|
|
"""
|
|
|
|
apps = _running_apps_with_bundle_id(bundle_id)
|
|
|
|
if not apps:
|
|
|
|
raise ValueError(
|
|
|
|
"Specified bundle ID not found in " "running apps: %s" % bundle_id
|
|
|
|
)
|
|
|
|
return atomacos.NativeUIElement.from_pid(apps[-1].processIdentifier())
|
|
|
|
|
2023-09-13 09:47:51 +02:00
|
|
|
pid = driver.currentApplicationContext().pid
|
|
|
|
atomator = atomacos.getAppRefByPid(pid)
|
2023-08-04 20:27:03 +02:00
|
|
|
started_at = time.monotonic()
|
|
|
|
while not hasattr(atomator, 'AXMainWindow'):
|
|
|
|
time.sleep(1)
|
|
|
|
assert time.monotonic() - started_at < timeout_sec, f'Attach error: {BUNDLE_ID}'
|
|
|
|
return atomator
|
|
|
|
|
|
|
|
|
|
|
|
def find_object(object_name: dict):
|
|
|
|
_object_name = deepcopy(object_name)
|
|
|
|
if 'container' in _object_name:
|
|
|
|
parent = find_object(_object_name['container'])
|
|
|
|
del _object_name['container']
|
|
|
|
else:
|
|
|
|
return attach_atomac().windows()[0]
|
|
|
|
|
|
|
|
assert parent is not None, f'Object not found: {object_name["container"]}'
|
|
|
|
_object = parent.findFirst(**_object_name)
|
|
|
|
assert _object is not None, f'Object not found: {_object_name}'
|
|
|
|
return _object
|
|
|
|
|
|
|
|
|
|
|
|
def wait_for_object(object_name: dict, timeout_sec: int = configs.timeouts.UI_LOAD_TIMEOUT_SEC):
|
|
|
|
started_at = time.monotonic()
|
|
|
|
while True:
|
|
|
|
try:
|
|
|
|
return find_object(object_name)
|
|
|
|
except AssertionError as err:
|
|
|
|
if time.monotonic() - started_at > timeout_sec:
|
|
|
|
raise LookupError(f'Object: {object_name} not found. Error: {err}')
|