aboutsummaryrefslogtreecommitdiff
path: root/src/test/test.py
blob: 7be1d1802e78b590ffbdc75294d61fbe8f90001a (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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
# ############################################################################ #
#                                                                              #
#                                                         :::      ::::::::    #
#    test.py                                            :+:      :+:    :+:    #
#                                                     +:+ +:+         +:+      #
#    By: charles <me@cacharle.xyz>                  +#+  +:+       +#+         #
#                                                 +#+#+#+#+#+   +#+            #
#    Created: 2020/09/27 11:36:32 by charles           #+#    #+#              #
#    Updated: 2020/09/27 13:28:15 by charles          ###   ########.fr        #
#                                                                              #
# ############################################################################ #

import re
import subprocess
# import threading

# from result import Result


class Test: #(threading.Thread):
    _tests = []
    _exec_path = None
    # _stdout_lock = threading.Lock()

    @classmethod
    def run_all(cls, exec_path: str):
        cls._exec_path = exec_path
        for t in cls._tests:
            t.run()
        # threads = [test.start() for test in cls._tests]
        # for thread in threads:
        #     thread.join()

    def __init__(
        self,
        philo_num:     int,
        timeout_die:   int,
        timeout_eat:   int,
        timeout_sleep: int,
        meal_num:      int = None,
        should_fail:   bool = False
    ):
        self._philo_num     = philo_num
        self._timeout_die   = timeout_die
        self._timeout_eat   = timeout_eat
        self._timeout_sleep = timeout_sleep
        self._meal_num      = meal_num
        Test._tests.append(self)
        # threading.Thread.__init__(self)

    def run(self):
        argv = [
            Test._exec_path,
            str(self._philo_num),
            str(self._timeout_die),
            str(self._timeout_eat),
            str(self._timeout_sleep)
        ]
        if self._meal_num is not None:
            argv.append(str(self._meal_num))
        # try:
        process_result = subprocess.run(
            argv,
            stdout=subprocess.PIPE,
            stderr=subprocess.STDOUT
        )
        output = process_result.stdout.decode()
        print(output)
                # timeout=1,
        # except subprocess.TimeoutExpered as err:
        #     return Result(err)
        # except subprocess.CalledProcessError as err:
        #     return Result(err)

        self._check_output(output)
        # return Result()

    def _check_output(self, stream):
        # table = Table(self._philo_num)

        for line in stream.split('\n'):
            match = re.match(
                "^(?P<timestamp>\d+) "
                "(?P<id>\d+) "
                "(?P<event>is thinking|is eating|is sleeping|died)$",
                line
            )
            if match is None:
                print("Bad line format |{}|".format(line))
                return

            print(match.group('event'))
            try:
                timestamp = int(match.group("timestamp"))
                # if timestamp < 0
            except ValueError:
                print("Invalid timestamp value {}".format(match.group("timestamp")))

            table.add_log(match)

            # philo_states.append(Philo)

    # def _print(self, *args):
    #     Test._stdout_lock.aquire()
    #     print(*args)
    #     Test._stdout_lock.release()

# from enum import Enum
# class PhiloEvent(Enum):
#     EATING = 1
#     SLEEPING = 2
#     THINKING = 3