2023-09-28 14:44:13 +02:00
|
|
|
import logging
|
2023-09-11 20:24:13 +02:00
|
|
|
from datetime import datetime
|
|
|
|
|
2023-08-04 20:27:03 +02:00
|
|
|
import allure
|
|
|
|
import squish
|
|
|
|
|
|
|
|
import configs
|
|
|
|
import driver
|
|
|
|
from driver import context
|
|
|
|
from driver.server import SquishServer
|
|
|
|
from scripts.utils import system_path, local_system
|
2023-09-11 20:24:13 +02:00
|
|
|
from scripts.utils.system_path import SystemPath
|
2023-08-04 20:27:03 +02:00
|
|
|
|
2023-09-28 14:44:13 +02:00
|
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
|
2023-08-04 20:27:03 +02:00
|
|
|
|
|
|
|
class AUT:
|
|
|
|
def __init__(
|
|
|
|
self,
|
|
|
|
app_path: system_path.SystemPath = configs.APP_DIR,
|
|
|
|
host: str = '127.0.0.1',
|
2023-10-11 13:38:55 +03:00
|
|
|
port: int = local_system.find_free_port(configs.squish.AUT_PORT, 1000),
|
2023-09-11 20:24:13 +02:00
|
|
|
user_data: SystemPath = None
|
2023-08-04 20:27:03 +02:00
|
|
|
):
|
|
|
|
super(AUT, self).__init__()
|
|
|
|
self.path = app_path
|
|
|
|
self.host = host
|
|
|
|
self.port = int(port)
|
|
|
|
self.ctx = None
|
2023-08-10 13:43:17 +02:00
|
|
|
self.pid = None
|
2023-09-13 09:47:51 +02:00
|
|
|
self.aut_id = f'AUT_{datetime.now():%H%M%S}'
|
2023-09-11 20:24:13 +02:00
|
|
|
self.app_data = configs.testpath.STATUS_DATA / f'app_{datetime.now():%H%M%S_%f}'
|
2023-09-15 10:15:28 +02:00
|
|
|
if user_data is not None:
|
|
|
|
user_data.copy_to(self.app_data / 'data')
|
2023-08-04 20:27:03 +02:00
|
|
|
driver.testSettings.setWrappersForApplication(self.aut_id, ['Qt'])
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return type(self).__qualname__
|
|
|
|
|
2023-09-11 20:24:13 +02:00
|
|
|
def __enter__(self):
|
|
|
|
return self.launch()
|
|
|
|
|
|
|
|
def __exit__(self, *args):
|
|
|
|
self.detach().stop()
|
|
|
|
|
2023-08-04 20:27:03 +02:00
|
|
|
@allure.step('Attach Squish to Test Application')
|
|
|
|
def attach(self, timeout_sec: int = configs.timeouts.PROCESS_TIMEOUT_SEC, attempt: int = 2):
|
|
|
|
if self.ctx is None:
|
2023-09-13 09:47:51 +02:00
|
|
|
self.ctx = context.attach(self.aut_id, timeout_sec)
|
2023-08-04 20:27:03 +02:00
|
|
|
try:
|
|
|
|
squish.setApplicationContext(self.ctx)
|
|
|
|
except TypeError as err:
|
|
|
|
if attempt:
|
|
|
|
return self.attach(timeout_sec, attempt - 1)
|
|
|
|
else:
|
|
|
|
raise err
|
|
|
|
|
|
|
|
@allure.step('Detach Squish and Application')
|
|
|
|
def detach(self):
|
|
|
|
if self.ctx is not None:
|
|
|
|
squish.currentApplicationContext().detach()
|
|
|
|
self.ctx = None
|
|
|
|
return self
|
|
|
|
|
2023-08-22 17:15:25 +02:00
|
|
|
@allure.step('Close application')
|
2023-08-10 08:58:50 +02:00
|
|
|
def stop(self):
|
2023-09-11 20:24:13 +02:00
|
|
|
local_system.kill_process(self.pid, verify=True)
|
2023-08-04 20:27:03 +02:00
|
|
|
|
|
|
|
@allure.step("Start application")
|
2023-09-15 10:15:28 +02:00
|
|
|
def launch(self, ) -> 'AUT':
|
2023-08-04 20:27:03 +02:00
|
|
|
SquishServer().set_aut_timeout()
|
2023-09-11 20:24:13 +02:00
|
|
|
|
2023-08-04 20:27:03 +02:00
|
|
|
if configs.ATTACH_MODE:
|
2023-09-13 09:47:51 +02:00
|
|
|
SquishServer().add_attachable_aut(self.aut_id, self.port)
|
2023-08-04 20:27:03 +02:00
|
|
|
command = [
|
2023-09-11 20:24:13 +02:00
|
|
|
configs.testpath.SQUISH_DIR / 'bin' / 'startaut',
|
|
|
|
f'--port={self.port}',
|
|
|
|
f'"{self.path}"',
|
|
|
|
f'-d={self.app_data}'
|
|
|
|
]
|
2023-08-04 20:27:03 +02:00
|
|
|
local_system.execute(command)
|
2023-09-28 14:44:13 +02:00
|
|
|
self.attach()
|
2023-08-04 20:27:03 +02:00
|
|
|
else:
|
|
|
|
SquishServer().add_executable_aut(self.aut_id, self.path.parent)
|
2023-09-11 20:24:13 +02:00
|
|
|
command = [self.aut_id, f'-d={self.app_data}']
|
|
|
|
self.ctx = squish.startApplication(' '.join(command), configs.timeouts.PROCESS_TIMEOUT_SEC)
|
2023-08-04 20:27:03 +02:00
|
|
|
|
2023-08-10 13:43:17 +02:00
|
|
|
self.pid = self.ctx.pid
|
2023-08-04 20:27:03 +02:00
|
|
|
assert squish.waitFor(lambda: self.ctx.isRunning, configs.timeouts.PROCESS_TIMEOUT_SEC)
|
|
|
|
return self
|
2023-09-15 10:15:28 +02:00
|
|
|
|
|
|
|
@allure.step('Restart application')
|
|
|
|
def restart(self):
|
|
|
|
self.detach().stop()
|
|
|
|
self.launch()
|