|  | ## Show that SIGINT and similar signals don't cause crash messages to be | 
|  | ## reported. | 
|  | # RUN: %python %s wrapper llvm-symbolizer 2> %t.err | 
|  | # RUN: FileCheck -DMSG=%errc_ENOENT --input-file=%t.err %s | 
|  |  | 
|  | # CHECK: {{.*}} error: 'foo': [[MSG]] | 
|  | # CHECK-NOT: {{.+}} | 
|  |  | 
|  | import os | 
|  | import signal | 
|  | import subprocess | 
|  | import sys | 
|  | import time | 
|  |  | 
|  | def run_symbolizer(): | 
|  | proc = subprocess.Popen([sys.argv[2]], stdout=subprocess.PIPE, | 
|  | stdin=subprocess.PIPE, stderr=sys.stderr) | 
|  | # Write then read some output to ensure the process has started fully. | 
|  | proc.stdin.write(b'foo bar\n') | 
|  | proc.stdin.flush() | 
|  | proc.stdout.readline() | 
|  | # Windows handles signals differently. | 
|  | if os.name == 'nt': | 
|  | os.kill(0, signal.CTRL_BREAK_EVENT) | 
|  | else: | 
|  | proc.send_signal(signal.SIGINT) | 
|  |  | 
|  | # On Windows, this function spawns the subprocess in its own (hidden) console, | 
|  | # so that signals do not interfere with the calling test. This isn't necessary | 
|  | # on other systems. | 
|  | def run_wrapper(): | 
|  | args = [sys.executable, __file__, 'symbolizer'] + sys.argv[2:] | 
|  | if os.name == 'nt': | 
|  | startupinfo = subprocess.STARTUPINFO() | 
|  | startupinfo.dwFlags |= subprocess.STARTF_USESHOWWINDOW | 
|  | subprocess.run(args, stderr=sys.stderr, startupinfo=startupinfo, | 
|  | creationflags=subprocess.CREATE_NEW_CONSOLE) | 
|  | else: | 
|  | subprocess.run(args, stderr=sys.stderr) | 
|  |  | 
|  | if sys.argv[1] == 'wrapper': | 
|  | run_wrapper() | 
|  | else: | 
|  | run_symbolizer() |