blob: 5c1132254ed44e43acb736e6c76698d5095118d9 [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
Fred Drake004d5e62000-10-23 17:22:08 +000032HandlerBCalled = "HandlerBCalled" # Exception
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000033
34def handlerB(*args):
Fred Drake004d5e62000-10-23 17:22:08 +000035 if verbose:
36 print "handlerB", args
37 raise HandlerBCalled, args
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000038
Fred Drake004d5e62000-10-23 17:22:08 +000039signal.alarm(20) # Entire test lasts at most 20 sec.
Michael W. Hudson5c26e862004-06-11 18:09:28 +000040hup = signal.signal(signal.SIGHUP, handlerA)
41usr1 = signal.signal(signal.SIGUSR1, handlerB)
42usr2 = signal.signal(signal.SIGUSR2, signal.SIG_IGN)
43alrm = signal.signal(signal.SIGALRM, signal.default_int_handler)
Guido van Rossum4f17e3e1995-03-16 15:07:38 +000044
45try:
Michael W. Hudson5c26e862004-06-11 18:09:28 +000046 os.system(script)
Fred Drake004d5e62000-10-23 17:22:08 +000047
Michael W. Hudson5c26e862004-06-11 18:09:28 +000048 print "starting pause() loop..."
49
50 try:
51 while 1:
52 if verbose:
53 print "call pause()..."
54 try:
55 signal.pause()
56 if verbose:
57 print "pause() returned"
58 except HandlerBCalled:
59 if verbose:
60 print "HandlerBCalled exception caught"
61 else:
62 pass
63
64 except KeyboardInterrupt:
65 if verbose:
66 print "KeyboardInterrupt (assume the alarm() went off)"
67
68finally:
69 signal.signal(signal.SIGHUP, hup)
70 signal.signal(signal.SIGUSR1, usr1)
71 signal.signal(signal.SIGUSR2, usr2)
72 signal.signal(signal.SIGALRM, alrm)