12345678910111213141516171819202122232425262728293031323334 |
- # Copyright (c) Facebook, Inc. and its affiliates.
- # All rights reserved.
- #
- # This source code is licensed under the BSD-style license found in the
- # LICENSE file in the root directory of this source tree.
- from contextlib import contextmanager
- import os
- import subprocess
- import signal
- @contextmanager
- def magic_trace(output='trace.fxt', magic_trace_cache='/tmp/magic-trace'):
- pid = os.getpid()
- if not os.path.exists(magic_trace_cache):
- print(f"Downloading magic_trace to: {magic_trace_cache}")
- subprocess.run(['wget', '-O', magic_trace_cache, '-q',
- 'https://github.com/janestreet/magic-trace/releases/download/v1.0.2/magic-trace'])
- subprocess.run(['chmod', '+x', magic_trace_cache])
- args = [magic_trace_cache, 'attach', '-pid', str(pid), '-o', output]
- p = subprocess.Popen(args, stderr=subprocess.PIPE, encoding='utf-8')
- while True:
- x = p.stderr.readline()
- print(x)
- if 'Attached' in x:
- break
- try:
- yield
- finally:
- p.send_signal(signal.SIGINT)
- r = p.wait()
- print(p.stderr.read())
- p.stderr.close()
- if r != 0:
- raise ValueError(f'magic_trace exited abnormally: {r}')
|