# 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}')