From e0e3e1717e3d33762ce61950504f9637a6e669ed Mon Sep 17 00:00:00 2001 From: nkozlovskiy <nmk@ydb.tech> Date: Fri, 29 Sep 2023 12:24:06 +0300 Subject: add ydb deps --- library/python/runtime_py3/test/traceback/crash.py | 42 ++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 library/python/runtime_py3/test/traceback/crash.py (limited to 'library/python/runtime_py3/test/traceback/crash.py') diff --git a/library/python/runtime_py3/test/traceback/crash.py b/library/python/runtime_py3/test/traceback/crash.py new file mode 100644 index 0000000000..dfd316d4c6 --- /dev/null +++ b/library/python/runtime_py3/test/traceback/crash.py @@ -0,0 +1,42 @@ +import argparse +import sys +import time + +from IPython.core import ultratb + +from .mod import modfunc + + +def one(): + modfunc(two) # aaa + + +def two(): + three(42) + + +def three(x): + raise RuntimeError(f"Kaboom! I'm dead: {x}") + + +def main(): + hooks = { + "default": lambda: sys.excepthook, + "ultratb_color": lambda: ultratb.ColorTB(ostream=sys.stderr), + "ultratb_verbose": lambda: ultratb.VerboseTB(ostream=sys.stderr), + } + + parser = argparse.ArgumentParser() + parser.add_argument("hook", choices=sorted(hooks), default="default") + + args = parser.parse_args() + + sys.excepthook = hooks[args.hook]() + + print("__name__ =", __name__) + print("__file__ =", __file__) + + time.time = lambda: 1531996624.0 # Freeze time + sys.executable = "<traceback test>" + + one() -- cgit v1.2.3