llvm-project/llvm/test/Support/interrupts.test
Serge Pavlov e144ae54dc [symbolizer] Support symbol lookup
Recent versions of GNU binutils starting from 2.39 support symbol+offset
lookup in addition to the usual numeric address lookup. This change adds
symbol lookup to llvm-symbolize and llvm-addr2line.

Now llvm-symbolize behaves closer to GNU addr2line, - if the value specified
as address in command line or input stream is not a number, it is treated as
a symbol name. For example:

    llvm-symbolize --obj=abc.so func_22
    llvm-symbolize --obj=abc.so "CODE func_22"

This lookup is now supported only for functions. Specification with
offset is not supported yet.

This is a recommit of 2b27948783e4bbc1132d3220d8517ef62607b558, reverted
in 39fec5457c0925bd39f67f63fe17391584e08258 because the test
llvm/test/Support/interrupts.test started failing on Windows. The test was
changed in 18f036d0105589c3175bb51a518c5d272dae61e2 and is also updated in
this commit.

Differential Revision: https://reviews.llvm.org/D149759
2023-11-01 14:41:39 +07:00

45 lines
1.4 KiB
Plaintext

## 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 --input-file=%t.err %s
# CHECK: {{.*}} error: 'foo': {{[Nn]}}o such file or directory
# 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()