Commit 34c2513d authored by Timo Koch's avatar Timo Koch Committed by Dennis Gläser
Browse files

[ci][getpiplineinfo] improve traceback handling

parent 90dd0156
Pipeline #4729 waiting for manual action with stages
......@@ -2,6 +2,7 @@ import os
import sys
import functools
import subprocess
import traceback
def getCommandErrorHints(command):
......@@ -19,19 +20,19 @@ def runCommand(command, suppressTraceBack=False, errorMessage=''):
shell=True, check=True,
text=True, capture_output=True).stdout
except Exception:
eType, eValue, eTraceback = sys.exc_info()
if suppressTraceBack:
sys.excepthook(Exception, Exception(errorMessage), None)
elif not errorMessage:
traceback.print_exception(eType, eType(errorMessage), None)
elif errorMessage:
traceback.print_exception(eType, eType(errorMessage), eTraceback)
print("An error occurred during subprocess run:")
print("-- command: {}".format(command))
print("-- folder: {}".format(os.getcwd()))
print("-- error: {}".format(sys.exc_info()[1]))
traceback.print_exception(eType, eValue, eTraceback)
hints = getCommandErrorHints(command)
if hints is not None:
raise Exception(errorMessage)
# decorator to call function from within the given path
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment