From 91610ddbb06210ad61ea9083e55e8c7b9dbad287 Mon Sep 17 00:00:00 2001 From: mvdbeek Date: Mon, 3 Jun 2024 17:05:48 +0200 Subject: [PATCH] Don't serialize display application links for deleted datasets Doing that often requires datasets on disk, which we shouldn't guarantee for deleted datasets. Fixes https://sentry.galaxyproject.org/share/issue/0ae7a9d9ad564054bd11c9a43aa6994c/: ``` Message Unexpected error Stack Trace Newest FileNotFoundError: [Errno 2] No such file or directory: '' File "galaxy/datatypes/interval.py", line 914, in get_estimated_display_viewport with compression_utils.get_fileobj(dataset.get_file_name()) as fh: File "galaxy/util/compression_utils.py", line 79, in get_fileobj return get_fileobj_raw(filename, mode, compressed_formats)[1] File "galaxy/util/compression_utils.py", line 139, in get_fileobj_raw return compressed_format, open(filename, mode, encoding="utf-8") ``` --- lib/galaxy/managers/hdas.py | 67 +++++++++++++++++++------------------ 1 file changed, 35 insertions(+), 32 deletions(-) diff --git a/lib/galaxy/managers/hdas.py b/lib/galaxy/managers/hdas.py index f92a75b56f24..5dc7da8eb348 100644 --- a/lib/galaxy/managers/hdas.py +++ b/lib/galaxy/managers/hdas.py @@ -617,18 +617,19 @@ def serialize_display_apps(self, item, key, trans=None, **context): """ hda = item display_apps: List[Dict[str, Any]] = [] - for display_app in hda.get_display_applications(trans).values(): - app_links = [] - for link_app in display_app.links.values(): - app_links.append( - { - "target": link_app.url.get("target_frame", "_blank"), - "href": link_app.get_display_url(hda, trans), - "text": gettext.gettext(link_app.name), - } - ) - if app_links: - display_apps.append(dict(label=display_app.name, links=app_links)) + if hda.state == model.HistoryDatasetAssociation.states.OK and not hda.deleted: + for display_app in hda.get_display_applications(trans).values(): + app_links = [] + for link_app in display_app.links.values(): + app_links.append( + { + "target": link_app.url.get("target_frame", "_blank"), + "href": link_app.get_display_url(hda, trans), + "text": gettext.gettext(link_app.name), + } + ) + if app_links: + display_apps.append(dict(label=display_app.name, links=app_links)) return display_apps @@ -638,28 +639,30 @@ def serialize_old_display_applications(self, item, key, trans=None, **context): """ hda = item display_apps: List[Dict[str, Any]] = [] - if not self.app.config.enable_old_display_applications: - return display_apps - - display_link_fn = hda.datatype.get_display_links - for display_app in hda.datatype.get_display_types(): - target_frame, display_links = display_link_fn( - hda, - display_app, - self.app, - trans.request.base, - ) + if ( + self.app.config.enable_old_display_applications + and hda.state == model.HistoryDatasetAssociation.states.OK + and not hda.deleted + ): + display_link_fn = hda.datatype.get_display_links + for display_app in hda.datatype.get_display_types(): + target_frame, display_links = display_link_fn( + hda, + display_app, + self.app, + trans.request.base, + ) - if len(display_links) > 0: - display_label = hda.datatype.get_display_label(display_app) + if len(display_links) > 0: + display_label = hda.datatype.get_display_label(display_app) - app_links = [] - for display_name, display_link in display_links: - app_links.append( - {"target": target_frame, "href": display_link, "text": gettext.gettext(display_name)} - ) - if app_links: - display_apps.append(dict(label=display_label, links=app_links)) + app_links = [] + for display_name, display_link in display_links: + app_links.append( + {"target": target_frame, "href": display_link, "text": gettext.gettext(display_name)} + ) + if app_links: + display_apps.append(dict(label=display_label, links=app_links)) return display_apps