status-desktop/test/e2e/driver/context.py

32 lines
845 B
Python
Raw Normal View History

import logging
import allure
import squish
import configs
2024-10-04 07:54:43 +00:00
import driver
from driver.server import SquishServer
LOG = logging.getLogger(__name__)
@allure.step('Get application context of "{0}"')
def get_context(aut_id: str):
LOG.info('Attaching to: %s', aut_id)
try:
2024-10-04 07:54:43 +00:00
context = driver.attachToApplication(aut_id, SquishServer().host, SquishServer().port)
if context is not None:
LOG.info('AUT %s context found', aut_id)
return context
except RuntimeError as error:
LOG.error('AUT %s context has not been found', aut_id)
raise error
@allure.step('Detaching')
def detach():
2024-10-04 07:54:43 +00:00
for ctx in driver.applicationContextList():
ctx.detach()
assert squish.waitFor(lambda: not ctx.isRunning, configs.timeouts.APP_LOAD_TIMEOUT_MSEC)
LOG.info('All AUTs detached')