Skip to content

Commit

Permalink
Specify directory to download logs
Browse files Browse the repository at this point in the history
  • Loading branch information
gibchikafa committed Nov 9, 2023
1 parent 1d3dd86 commit 33d0485
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 4 deletions.
4 changes: 4 additions & 0 deletions python/hopsworks/client/exceptions.py
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,10 @@ class OpenSearchException(Exception):
"""Generic opensearch exception"""


class JobExecutionException(Exception):
"""Generic job executions exception"""


class ExternalClientError(TypeError):
"""Raised when external client cannot be initialized due to missing arguments."""

Expand Down
12 changes: 10 additions & 2 deletions python/hopsworks/engine/execution_engine.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,25 +20,33 @@
import time
import uuid

from python.hopsworks.client.exceptions import JobExecutionException


class ExecutionEngine:
def __init__(self, project_id=None):
self._dataset_api = dataset_api.DatasetApi(project_id)
self._execution_api = execution_api.ExecutionsApi(project_id)
self._log = logging.getLogger(__name__)

def download_logs(self, execution):
def download_logs(self, execution, path=None):
"""Download execution logs to current directory
:param path: path to download the logs
:param execution: execution to download logs for
:type execution: Execution
:return: downloaded stdout and stderr log path
:rtype: str, str
:raises: JobExecutionException if path is provided but does not exist
"""
if path is not None and not os.path.exists(path):
raise JobExecutionException("Path {} does not exist".format(path))
elif path is None:
path = os.getcwd()

job_logs_dir = "logs-job-{}-exec-{}_{}".format(
execution.job_name, str(execution.id), str(uuid.uuid4())[:16]
)
download_log_dir = os.path.join(os.getcwd(), job_logs_dir)
download_log_dir = os.path.join(path, job_logs_dir)

if not os.path.exists(download_log_dir):
os.mkdir(download_log_dir)
Expand Down
4 changes: 2 additions & 2 deletions python/hopsworks/execution.py
Original file line number Diff line number Diff line change
Expand Up @@ -178,7 +178,7 @@ def success(self):
return True
return None

def download_logs(self):
def download_logs(self, path=None):
"""Download stdout and stderr logs for the execution
Example for downloading and printing the logs
Expand All @@ -199,7 +199,7 @@ def download_logs(self):
`str`. Path to downloaded log for stdout.
`str`. Path to downloaded log for stderr.
"""
return self._execution_engine.download_logs(self)
return self._execution_engine.download_logs(self, path)

def delete(self):
"""Delete the execution
Expand Down

0 comments on commit 33d0485

Please sign in to comment.