fix(driver): killing process using pid not port number
* Drop unnecessary killing of processes by port, we have the PID. * Split `stop()` method into `_detach_context()` and `_kill_process()`. Signed-off-by: Jakub Sokołowski <jakub@status.im>
This commit is contained in:
parent
917a4bfde1
commit
fc665cf5ec
|
@ -73,27 +73,22 @@ class AUT:
|
||||||
self.ctx = context.attach(self.aut_id, timeout_sec)
|
self.ctx = context.attach(self.aut_id, timeout_sec)
|
||||||
squish.setApplicationContext(self.ctx)
|
squish.setApplicationContext(self.ctx)
|
||||||
|
|
||||||
|
def _detach_context(self):
|
||||||
|
if self.ctx is None:
|
||||||
|
return
|
||||||
|
squish.currentApplicationContext().detach()
|
||||||
|
self.ctx = None
|
||||||
|
|
||||||
|
def _kill_process(self):
|
||||||
|
if self.pid is None:
|
||||||
|
raise Exception('No process to kill, no PID available.')
|
||||||
|
local_system.kill_process(self.pid, verify=True)
|
||||||
|
self.pid = None
|
||||||
|
|
||||||
@allure.step('Close application')
|
@allure.step('Close application')
|
||||||
def stop(self):
|
def stop(self):
|
||||||
if self.ctx is not None:
|
self._detach_context()
|
||||||
squish.currentApplicationContext().detach()
|
self._kill_process()
|
||||||
self.ctx = None
|
|
||||||
|
|
||||||
if self.port is not None:
|
|
||||||
pid_list = local_system.find_process_by_port(self.port)
|
|
||||||
if pid_list:
|
|
||||||
for pid in pid_list:
|
|
||||||
local_system.kill_process(pid, verify=True)
|
|
||||||
assert driver.waitFor(
|
|
||||||
lambda: not local_system.find_process_by_port(self.port), configs.timeouts.PROCESS_TIMEOUT_SEC), \
|
|
||||||
f'Port {self.port} still in use by process: {local_system.find_process_by_port(self.port)}'
|
|
||||||
self.port = None
|
|
||||||
if self.pid in pid_list:
|
|
||||||
self.pid = None
|
|
||||||
|
|
||||||
if self.pid is not None:
|
|
||||||
local_system.kill_process(self.pid, verify=True)
|
|
||||||
self.pid = None
|
|
||||||
|
|
||||||
@allure.step("Start application")
|
@allure.step("Start application")
|
||||||
def launch(self, options='', attempt: int = 2) -> 'AUT':
|
def launch(self, options='', attempt: int = 2) -> 'AUT':
|
||||||
|
|
Loading…
Reference in New Issue