fix task v2 download issue (#3220)
This commit is contained in:
@@ -739,8 +739,9 @@ class BaseTaskBlock(Block):
|
||||
async with asyncio.timeout(GET_DOWNLOADED_FILES_TIMEOUT):
|
||||
downloaded_files = await app.STORAGE.get_downloaded_files(
|
||||
organization_id=workflow_run.organization_id,
|
||||
task_id=updated_task.task_id,
|
||||
workflow_run_id=workflow_run_id,
|
||||
run_id=current_context.run_id
|
||||
if current_context and current_context.run_id
|
||||
else workflow_run_id or updated_task.task_id,
|
||||
)
|
||||
except asyncio.TimeoutError:
|
||||
LOG.warning("Timeout getting downloaded files", task_id=updated_task.task_id)
|
||||
@@ -798,8 +799,9 @@ class BaseTaskBlock(Block):
|
||||
async with asyncio.timeout(GET_DOWNLOADED_FILES_TIMEOUT):
|
||||
downloaded_files = await app.STORAGE.get_downloaded_files(
|
||||
organization_id=workflow_run.organization_id,
|
||||
task_id=updated_task.task_id,
|
||||
workflow_run_id=workflow_run_id,
|
||||
run_id=current_context.run_id
|
||||
if current_context and current_context.run_id
|
||||
else workflow_run_id or updated_task.task_id,
|
||||
)
|
||||
|
||||
except asyncio.TimeoutError:
|
||||
@@ -1816,7 +1818,12 @@ class UploadToS3Block(Block):
|
||||
self.path = file_path_parameter_value
|
||||
# if the path is WORKFLOW_DOWNLOAD_DIRECTORY_PARAMETER_KEY, use the download directory for the workflow run
|
||||
elif self.path == settings.WORKFLOW_DOWNLOAD_DIRECTORY_PARAMETER_KEY:
|
||||
self.path = str(get_path_for_workflow_download_directory(workflow_run_id).absolute())
|
||||
context = skyvern_context.current()
|
||||
self.path = str(
|
||||
get_path_for_workflow_download_directory(
|
||||
context.run_id if context and context.run_id else workflow_run_id
|
||||
).absolute()
|
||||
)
|
||||
|
||||
try:
|
||||
self.format_potential_template_parameters(workflow_run_context)
|
||||
@@ -2011,7 +2018,12 @@ class FileUploadBlock(Block):
|
||||
organization_id=organization_id,
|
||||
)
|
||||
|
||||
download_files_path = str(get_path_for_workflow_download_directory(workflow_run_id).absolute())
|
||||
context = skyvern_context.current()
|
||||
download_files_path = str(
|
||||
get_path_for_workflow_download_directory(
|
||||
context.run_id if context and context.run_id else workflow_run_id
|
||||
).absolute()
|
||||
)
|
||||
|
||||
uploaded_uris = []
|
||||
try:
|
||||
@@ -2197,7 +2209,12 @@ class SendEmailBlock(Block):
|
||||
|
||||
if path == settings.WORKFLOW_DOWNLOAD_DIRECTORY_PARAMETER_KEY:
|
||||
# if the path is WORKFLOW_DOWNLOAD_DIRECTORY_PARAMETER_KEY, use download directory for the workflow run
|
||||
path = str(get_path_for_workflow_download_directory(workflow_run_id).absolute())
|
||||
context = skyvern_context.current()
|
||||
path = str(
|
||||
get_path_for_workflow_download_directory(
|
||||
context.run_id if context and context.run_id else workflow_run_id
|
||||
).absolute()
|
||||
)
|
||||
LOG.info(
|
||||
"SendEmailBlock: Using download directory for the workflow run",
|
||||
workflow_run_id=workflow_run_id,
|
||||
|
||||
@@ -1155,6 +1155,11 @@ class WorkflowService:
|
||||
raise WorkflowNotFound(workflow_permanent_id=workflow_permanent_id)
|
||||
|
||||
workflow_run = await self.get_workflow_run(workflow_run_id=workflow_run_id, organization_id=organization_id)
|
||||
|
||||
task_v2 = await app.DATABASE.get_task_v2_by_workflow_run_id(
|
||||
workflow_run_id=workflow_run_id,
|
||||
organization_id=organization_id,
|
||||
)
|
||||
workflow_run_tasks = await app.DATABASE.get_tasks_by_workflow_run_id(workflow_run_id=workflow_run_id)
|
||||
screenshot_artifacts = []
|
||||
screenshot_urls: list[str] | None = None
|
||||
@@ -1184,15 +1189,22 @@ class WorkflowService:
|
||||
if recording_artifact:
|
||||
recording_url = await app.ARTIFACT_MANAGER.get_share_link(recording_artifact)
|
||||
|
||||
downloaded_files: list[FileInfo] | None = None
|
||||
downloaded_files: list[FileInfo] = []
|
||||
downloaded_file_urls: list[str] | None = None
|
||||
try:
|
||||
async with asyncio.timeout(GET_DOWNLOADED_FILES_TIMEOUT):
|
||||
context = skyvern_context.current()
|
||||
downloaded_files = await app.STORAGE.get_downloaded_files(
|
||||
organization_id=workflow_run.organization_id,
|
||||
task_id=None,
|
||||
workflow_run_id=workflow_run.workflow_run_id,
|
||||
run_id=context.run_id if context and context.run_id else workflow_run.workflow_run_id,
|
||||
)
|
||||
if task_v2:
|
||||
task_v2_downloaded_files = await app.STORAGE.get_downloaded_files(
|
||||
organization_id=workflow_run.organization_id,
|
||||
run_id=task_v2.observer_cruise_id,
|
||||
)
|
||||
if task_v2_downloaded_files:
|
||||
downloaded_files.extend(task_v2_downloaded_files)
|
||||
if downloaded_files:
|
||||
downloaded_file_urls = [file_info.url for file_info in downloaded_files]
|
||||
except asyncio.TimeoutError:
|
||||
@@ -1267,6 +1279,7 @@ class WorkflowService:
|
||||
workflow_title=workflow.title,
|
||||
browser_session_id=workflow_run.browser_session_id,
|
||||
max_screenshot_scrolls=workflow_run.max_screenshot_scrolls,
|
||||
task_v2=task_v2,
|
||||
)
|
||||
|
||||
async def clean_up_workflow(
|
||||
@@ -1304,8 +1317,10 @@ class WorkflowService:
|
||||
|
||||
try:
|
||||
async with asyncio.timeout(SAVE_DOWNLOADED_FILES_TIMEOUT):
|
||||
context = skyvern_context.current()
|
||||
await app.STORAGE.save_downloaded_files(
|
||||
workflow_run.organization_id, task_id=None, workflow_run_id=workflow_run.workflow_run_id
|
||||
organization_id=workflow_run.organization_id,
|
||||
run_id=context.run_id if context and context.run_id else workflow_run.workflow_run_id,
|
||||
)
|
||||
except asyncio.TimeoutError:
|
||||
LOG.warning(
|
||||
|
||||
Reference in New Issue
Block a user