blob: 042cfa93e82f1af1bb2f57862f2945d5b1d64938 [file] [log] [blame]
Guido van Rossum4f17e3e1995-03-16 15:07:38 +00001# Test the signal module
Barry Warsaw04f357c2002-07-23 19:04:11 +00002from test.test_support import verbose, TestSkipped, TestFailed
Guido van Rossum4f17e3e1995-03-16 15:07:38 +00003import signal
Michael W. Hudson34f20ea2002-05-27 15:08:24 +00004import os, sys, time
Guido van Rossumcc5a91d1997-04-16 00:29:15 +00005
Guido van Rossume2ae77b2001-10-24 20:42:55 +00006if sys.platform[:3] in ('win', 'os2') or sys.platform=='riscos':
7 raise TestSkipped, "Can't test signal on %s" % sys.platform
Guido van Rossum4f17e3e1995-03-16 15:07:38 +00008
Barry Warsaw5e056bb1996-12-23 23:39:42 +00009if verbose:
Fred Drake004d5e62000-10-23 17:22:08 +000010 x = '-x'
Barry Warsaw5e056bb1996-12-23 23:39:42 +000011else:
Fred Drake004d5e62000-10-23 17:22:08 +000012 x = '+x'
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000013pid = os.getpid()
14
15# Shell script that will send us asynchronous signals
16script = """
Barry Warsaw5e056bb1996-12-23 23:39:42 +000017 (
Fred Drake004d5e62000-10-23 17:22:08 +000018 set %(x)s
19 sleep 2
Michael W. Hudson5c26e862004-06-11 18:09:28 +000020 kill -HUP %(pid)d
Fred Drake004d5e62000-10-23 17:22:08 +000021 sleep 2
Michael W. Hudson5c26e862004-06-11 18:09:28 +000022 kill -USR1 %(pid)d
Fred Drake004d5e62000-10-23 17:22:08 +000023 sleep 2
Michael W. Hudson5c26e862004-06-11 18:09:28 +000024 kill -USR2 %(pid)d
Barry Warsaw5e056bb1996-12-23 23:39:42 +000025 ) &
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000026""" % vars()
27
28def handlerA(*args):
Fred Drake004d5e62000-10-23 17:22:08 +000029 if verbose:
30 print "handlerA", args
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000031
Armin Rigo8b2cbfd2004-08-07 21:27:43 +000032class HandlerBCalled(Exception):
33 pass
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000034
35def handlerB(*args):
Fred Drake004d5e62000-10-23 17:22:08 +000036 if verbose:
37 print "handlerB", args
38 raise HandlerBCalled, args
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000039
Fred Drake004d5e62000-10-23 17:22:08 +000040signal.alarm(20) # Entire test lasts at most 20 sec.
Michael W. Hudson5c26e862004-06-11 18:09:28 +000041hup = signal.signal(signal.SIGHUP, handlerA)
42usr1 = signal.signal(signal.SIGUSR1, handlerB)
43usr2 = signal.signal(signal.SIGUSR2, signal.SIG_IGN)
44alrm = signal.signal(signal.SIGALRM, signal.default_int_handler)
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000045
46try:
Michael W. Hudson5c26e862004-06-11 18:09:28 +000047 os.system(script)
Fred Drake004d5e62000-10-23 17:22:08 +000048
Michael W. Hudson5c26e862004-06-11 18:09:28 +000049 print "starting pause() loop..."
50
51 try:
52 while 1:
53 if verbose:
54 print "call pause()..."
55 try:
56 signal.pause()
57 if verbose:
58 print "pause() returned"
59 except HandlerBCalled:
60 if verbose:
61 print "HandlerBCalled exception caught"
62 else:
63 pass
64
65 except KeyboardInterrupt:
66 if verbose:
67 print "KeyboardInterrupt (assume the alarm() went off)"
68
69finally:
70 signal.signal(signal.SIGHUP, hup)
71 signal.signal(signal.SIGUSR1, usr1)
72 signal.signal(signal.SIGUSR2, usr2)
73 signal.signal(signal.SIGALRM, alrm)