aboutsummaryrefslogtreecommitdiffstats
path: root/sources/pyside6/tests/util/processtimer.py
blob: fb38943c81afa62ca5d9bb9afc51330f90796212 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/usr/bin/env python
# Copyright (C) 2022 The Qt Company Ltd.
# SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0

import os
import time


class TimeoutException(Exception):
    def __init__(self, msg):
        self.msg = msg

    def __str__(self):
        return repr(self.msg)


class ProcessTimer(object):
    '''Timeout function for controlling a subprocess.Popen instance.

    Naive implementation using busy loop, see later other means
    of doing this.
    '''

    def __init__(self, proc, timeout):
        self.proc = proc
        self.timeout = timeout

    def waitfor(self):
        time_passed = 0
        while(self.proc.poll() is None and time_passed < self.timeout):
            time_passed = time_passed + 1
            time.sleep(1)

        if time_passed >= self.timeout:
            raise TimeoutException("Timeout expired, possible deadlock")


if __name__ == "__main__":
    # simple example

    from subprocess import Popen

    proc = Popen(['sleep', '10'])
    t = ProcessTimer(proc, 5)
    try:
        t.waitfor()
    except TimeoutException:
        print(f"timeout - PID: {t.proc.pid}")
        #TODO: detect SO and kill accordingly
        #Linux
        os.kill(t.proc.pid, 9)
        #Windows (not tested)
        #subprocess.Popen("taskkill /F /T /PID %i"%handle.pid , shell=True)
    print(f"exit code: {t.proc.poll()}")