本文整理匯總了Python中signal.SIGALRM屬性的典型用法代碼示例。如果您正苦於以下問題:Python signal.SIGALRM屬性的具體用法?Python signal.SIGALRM怎麽用?Python signal.SIGALRM使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類signal
的用法示例。
在下文中一共展示了signal.SIGALRM屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: test_communicate_eintr
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_communicate_eintr(self):
# Issue #12493: communicate() should handle EINTR
def handler(signum, frame):
pass
old_handler = signal.signal(signal.SIGALRM, handler)
self.addCleanup(signal.signal, signal.SIGALRM, old_handler)
# the process is running for 2 seconds
args = [sys.executable, "-c", 'import time; time.sleep(2)']
for stream in ('stdout', 'stderr'):
kw = {stream: subprocess.PIPE}
with subprocess.Popen(args, **kw) as process:
signal.alarm(1)
try:
# communicate() will be interrupted by SIGALRM
process.communicate()
finally:
signal.alarm(0)
示例2: __init__
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def __init__(self):
# Setup signal fd, this allows signal to behave correctly
if os.name == 'posix':
self.signal_pipe_r, self.signal_pipe_w = os.pipe()
self._set_nonblock(self.signal_pipe_r)
self._set_nonblock(self.signal_pipe_w)
signal.set_wakeup_fd(self.signal_pipe_w)
self._signals_received = collections.deque()
signal.signal(signal.SIGINT, signal.SIG_DFL)
if os.name == 'posix':
signal.signal(signal.SIGCHLD, signal.SIG_DFL)
signal.signal(signal.SIGTERM, self._signal_catcher)
signal.signal(signal.SIGALRM, self._signal_catcher)
signal.signal(signal.SIGHUP, self._signal_catcher)
else:
# currently a noop on window...
signal.signal(signal.SIGTERM, self._signal_catcher)
# FIXME(sileht): should allow to catch signal CTRL_BREAK_EVENT,
# but we to create the child process with CREATE_NEW_PROCESS_GROUP
# to make this work, so current this is a noop for later fix
signal.signal(signal.SIGBREAK, self._signal_catcher)
示例3: _reproduce_preserved_alarm_stuff
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def _reproduce_preserved_alarm_stuff(self):
preserved = self._preserved_alarm_data
if preserved is not None:
assert preserved.handler is not None
# set the preserved handler as well as timeout and repeat
# interval (if any; note: if the timeout has already passed
# it will be set, by `_set_nonzero_alarm()`, to `MINIMAL_TIMEOUT`)
self._signal(signal.SIGALRM, preserved.handler)
if preserved.timeout:
already_elapsed = time.time() - preserved.preserved_at
self._store_alarm(preserved.timeout - already_elapsed, preserved.repeat_interval)
else:
self._store_alarm(0)
self._clear_preserved_alarm_data()
else:
self._store_alarm(0)
示例4: test_timeout_start
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_timeout_start(self, test_name, exc, assertion):
"""
Tests running a timeout with the start method that will raise itself.
"""
tsignal = signal.SIGALRM
existing_handler = signal.getsignal(tsignal)
t = QdbTimeout(1, exc)
t.start()
with self.assertRaises(Exception) as cm:
self.assertTrue(t.pending)
time.sleep(2)
if exc:
self.fail('Timeout did not stop the sleep')
self.assertIs(cm.exception, exc or t)
self.assertIs(signal.getsignal(tsignal), existing_handler)
示例5: test_timeout_ctx_mgr
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_timeout_ctx_mgr(self, test_name, exc, assertion):
tsignal = signal.SIGALRM
existing_handler = signal.getsignal(tsignal)
try:
with QdbTimeout(1, exc) as t:
self.assertTrue(t.pending)
time.sleep(2)
if exc:
self.fail('Timeout did not stop the sleep')
except Exception as u:
assertion(self, u, t)
else:
self.assertIs(
exc,
False,
'QdbTimeout(1, False) should not raise an exception'
)
self.assertIs(signal.getsignal(tsignal), existing_handler)
示例6: check_reentrant_write
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def check_reentrant_write(self, data, **fdopen_kwargs):
def on_alarm(*args):
# Will be called reentrantly from the same thread
wio.write(data)
1/0
signal.signal(signal.SIGALRM, on_alarm)
r, w = os.pipe()
wio = self.io.open(w, **fdopen_kwargs)
try:
signal.alarm(1)
# Either the reentrant call to wio.write() fails with RuntimeError,
# or the signal handler raises ZeroDivisionError.
with self.assertRaises((ZeroDivisionError, RuntimeError)) as cm:
while 1:
for i in range(100):
wio.write(data)
wio.flush()
# Make sure the buffer doesn't fill up and block further writes
os.read(r, len(data) * 100)
exc = cm.exception
if isinstance(exc, RuntimeError):
self.assertTrue(str(exc).startswith("reentrant call"), str(exc))
finally:
wio.close()
os.close(r)
示例7: test_select_interrupt_exc
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_select_interrupt_exc(self):
s = self.SELECTOR()
self.addCleanup(s.close)
rd, wr = self.make_socketpair()
class InterruptSelect(Exception):
pass
def handler(*args):
raise InterruptSelect
orig_alrm_handler = signal.signal(signal.SIGALRM, handler)
self.addCleanup(signal.signal, signal.SIGALRM, orig_alrm_handler)
self.addCleanup(signal.alarm, 0)
signal.alarm(1)
s.register(rd, selectors.EVENT_READ)
t = time()
# select() is interrupted by a signal which raises an exception
with self.assertRaises(InterruptSelect):
s.select(30)
# select() was interrupted before the timeout of 30 seconds
self.assertLess(time() - t, 5.0)
示例8: test_select_interrupt_noraise
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_select_interrupt_noraise(self):
s = self.SELECTOR()
self.addCleanup(s.close)
rd, wr = self.make_socketpair()
orig_alrm_handler = signal.signal(signal.SIGALRM, lambda *args: None)
self.addCleanup(signal.signal, signal.SIGALRM, orig_alrm_handler)
self.addCleanup(signal.alarm, 0)
signal.alarm(1)
s.register(rd, selectors.EVENT_READ)
t = time()
# select() is interrupted by a signal, but the signal handler doesn't
# raise an exception, so select() should by retries with a recomputed
# timeout
self.assertFalse(s.select(1.5))
self.assertGreaterEqual(time() - t, 1.0)
示例9: test_rlock_acquire_interruption
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_rlock_acquire_interruption(self):
# Mimic receiving a SIGINT (KeyboardInterrupt) with SIGALRM while stuck
# in a deadlock.
# XXX this test can fail when the legacy (non-semaphore) implementation
# of locks is used in thread_pthread.h, see issue #11223.
oldalrm = signal.signal(signal.SIGALRM, self.alarm_interrupt)
try:
rlock = thread.RLock()
# For reentrant locks, the initial acquisition must be in another
# thread.
def other_thread():
rlock.acquire()
thread.start_new_thread(other_thread, ())
# Wait until we can't acquire it without blocking...
while rlock.acquire(blocking=False):
rlock.release()
time.sleep(0.01)
signal.alarm(1)
t1 = time.time()
self.assertRaises(KeyboardInterrupt, rlock.acquire, timeout=5)
dt = time.time() - t1
# See rationale above in test_lock_acquire_interruption
self.assertLess(dt, 3.0)
finally:
signal.signal(signal.SIGALRM, oldalrm)
示例10: start
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def start(self):
self.last_profile_time = timer()
if self.use_signal:
try:
signal.signal(signal.SIGALRM, self._signal)
# the following tells the system to restart interrupted system calls if they are
# interrupted before any data has been transferred. This avoids many of the problems
# related to signals interrupting system calls, see issue #16
signal.siginterrupt(signal.SIGALRM, False)
except ValueError:
raise NotMainThreadError()
signal.setitimer(signal.ITIMER_REAL, self.interval, 0.0)
else:
sys.setprofile(self._profile)
示例11: setUp
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def setUp(self):
# isatty() and close() can hang on some platforms. Set an alarm
# before running the test to make sure we don't hang forever.
old_alarm = signal.signal(signal.SIGALRM, self.handle_sig)
self.addCleanup(signal.signal, signal.SIGALRM, old_alarm)
self.addCleanup(signal.alarm, 0)
signal.alarm(10)
示例12: registerSignals
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def registerSignals(for_usr1, for_usr2, for_alrm):
usr1 = signal.signal(signal.SIGUSR1, for_usr1)
usr2 = signal.signal(signal.SIGUSR2, for_usr2)
alrm = signal.signal(signal.SIGALRM, for_alrm)
return usr1, usr2, alrm
# The signal handler. Just note that the signal occurred and
# from who.
示例13: test_main
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def test_main():
global signal_blackboard
signal_blackboard = { signal.SIGUSR1 : {'tripped': 0, 'tripped_by': 0 },
signal.SIGUSR2 : {'tripped': 0, 'tripped_by': 0 },
signal.SIGALRM : {'tripped': 0, 'tripped_by': 0 } }
oldsigs = registerSignals(handle_signals, handle_signals, handle_signals)
try:
run_unittest(ThreadSignals)
finally:
registerSignals(*oldsigs)
示例14: timeout
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def timeout(seconds):
if not seconds:
yield
return
original_handler = signal(SIGALRM, noop)
try:
alarm(seconds)
yield
finally:
alarm(0)
signal(SIGALRM, original_handler)
示例15: limitedTime
# 需要導入模塊: import signal [as 別名]
# 或者: from signal import SIGALRM [as 別名]
def limitedTime(second, func, *args, **kw):
second = fixTimeout(second)
old_alarm = signal(SIGALRM, signalHandler)
try:
alarm(second)
return func(*args, **kw)
finally:
alarm(0)
signal(SIGALRM, old_alarm)