From f60f0ae6e3710a85fca7110f55bd722e8d0fe43c Mon Sep 17 00:00:00 2001 From: davelopez <46503462+davelopez@users.noreply.github.com> Date: Wed, 7 Feb 2024 14:58:52 +0100 Subject: [PATCH] Fix new edge case where all items might be already deleted This case was previously prevented at the UI level but should be considered here. --- lib/galaxy/webapps/galaxy/services/history_contents.py | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/lib/galaxy/webapps/galaxy/services/history_contents.py b/lib/galaxy/webapps/galaxy/services/history_contents.py index 669361389068..68f5c789ea22 100644 --- a/lib/galaxy/webapps/galaxy/services/history_contents.py +++ b/lib/galaxy/webapps/galaxy/services/history_contents.py @@ -1417,8 +1417,12 @@ def _unhide(self, item: HistoryItemModel): def _delete(self, item: HistoryItemModel, trans: ProvidesHistoryContext): if isinstance(item, HistoryDatasetCollectionAssociation): - return self.dataset_collection_manager.delete(trans, "history", item.id, recursive=True, purge=False) - return self.hda_manager.delete(item, flush=self.flush) + self.dataset_collection_manager.delete(trans, "history", item.id, recursive=True, purge=False) + else: + self.hda_manager.delete(item, flush=self.flush) + # In the edge case where all selected items are already deleted we need to force an update + # otherwise the history will wait indefinitely for the items to be deleted + item.update() def _undelete(self, item: HistoryItemModel): if getattr(item, "purged", False):