Actions
Feature #7328
open[Crunch] [UX] Standard excepthook to help debug job problems
Status:
New
Priority:
Normal
Assigned To:
-
Category:
Crunch
Target version:
-
Start date:
09/14/2015
Due date:
% Done:
0%
Estimated time:
Story points:
1.0
Description
Original report¶
for example, a simple "ls" in the directory that they are currently in or looking into would help. Working with collections is a new concept, so users can easily run into file not found issues. Also, if they are piping commands and lose track half way, it would be great to get more insight into what is being created/deleted/etc.
Implementation¶
Overview: Add an excepthook function to the Python SDK that saves the contents of the $TASK_WORK directory as the task's output, and mark it failed. The SDK automatically installs this function as sys.excepthook when it's running under a job that has a debugging runtime constraint set.
- Add a new function to the arvados.crunch Python SDK module.
- It will be installed as sys.excepthook and must take the same signature:
(exc_type, exc_value, traceback)
- It creates a new collection from the contents of the $TASK_WORK directory, and updates arvados.current_task() so that the task's output is the manifest of that collection, and success is false.
- run-command already has most of the code to do this.
- No matter what happens in the above step(s), the last thing it does is always call sys.__excepthook__ to get the usual exception handling behavior. Ensure this happens using a try/finally block.
- It will be installed as sys.excepthook and must take the same signature:
- Add this code or the functional equivalent to
__init__.py
:
if os.environ.get('TASK_UUID'): try: _want_debughook = current_job()['runtime_constraints']['debug_exceptions'] except (errors.ApiError, KeyError): # The job doesn't exist or doesn't define the constraint. pass else: if _want_debughook: sys.excepthook = arvados.crunch.your_new_function del _want_debughook
- Add documentation for the new runtime constraint to the Job schema page.
Actions