summaryrefslogtreecommitdiff
path: root/deps/v8/tools/testrunner/testproc/timeout.py
blob: 54dc60e9b42d8cf6d1e6c5f7556124819e5affe5 (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
# Copyright 2018 the V8 project authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

import time

from . import base


class TimeoutProc(base.TestProcObserver):
  def __init__(self, duration_sec):
    super(TimeoutProc, self).__init__()
    self._duration_sec = duration_sec
    self._start = time.time()

  def _on_next_test(self, test):
    self._on_event()

  def _on_result_for(self, test, result):
    self._on_event()

  def _on_heartbeat(self):
    self._on_event()

  def _on_event(self):
    if not self.is_stopped:
      if time.time() - self._start > self._duration_sec:
        print('>>> Total timeout reached.')
        self.stop()