Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fixes UI infinite polling after image delete #4389

Merged
merged 1 commit into from
Jan 13, 2025

Conversation

tonytw1
Copy link
Contributor

@tonytw1 tonytw1 commented Dec 29, 2024

What does this change?

After an image is deleted, Kahuna with poll endlessly looking for the deleted image to be removed from the API.
As soft deleted images do not disappear from the API, there is not way for this loop to end other than when the page is next reloaded.

Stopped the infinite polling by updating the polling function to recognise soft deleted as deleted.

Also returns the polling promise rather than void from pollDeleted.
The existing code appears to have been dropping straight instantly, without waiting for the poll to complete.

Delete from list view UI now behaves as expected; there is a noticeable pause then the image is removed from the view.

Delete from single image screen may be slightly better.
This delete triggers a search refresh to remove the deleted image and is probably catching stale Elastic eventually consistent search results most of the time. The deleted image will still be visible in the search results most of the time as per what currently happens.

I think this PR is a net improvement.

How should a reviewer test this change?

How can success be measured?

Who should look at this?

Tested? Documented?

  • locally by committer
  • locally by Guardian reviewer
  • on the Guardian's TEST environment
  • relevant documentation added or amended (if needed)

Recognises soft deleted as a deleted.
Returns promise to that it can be waited on.
@tonytw1 tonytw1 force-pushed the tm/image-delete-polling branch from 34fc99d to db7c10c Compare December 29, 2024 21:48
@tonytw1 tonytw1 marked this pull request as ready for review December 29, 2024 21:54
@tonytw1 tonytw1 requested review from a team as code owners December 29, 2024 21:54
@tonytw1 tonytw1 changed the title Fixes image delete infinite polling after delete Fixes UI infinite polling after image delete Dec 29, 2024
@andrew-nowak
Copy link
Member

andrew-nowak commented Jan 10, 2025

Thanks! I've tested locally and this looks to be working well. I think we have the same problem on the "undelete" button too though - maybe we can add the same logic there too? https://github.com/guardian/grid/blob/main/kahuna/public/js/components/gr-undelete-image/gr-un-delete-image.js

@andrew-nowak
Copy link
Member

Thanks! I've tested locally and this looks to be working well. I think we have the same problem on the "undelete" button too though - maybe we can add the same logic there too? https://github.com/guardian/grid/blob/main/kahuna/public/js/components/gr-undelete-image/gr-un-delete-image.js

Looking again at this, I think there's a different logic problem here, the undelete button is polling until it finds the image has been deleted, where it should probably be polling until it finds the image has been undeleted. I'll merge this and look at that in a different PR.

@prout-bot
Copy link

Seen on cropper (created by @tonytw1 and merged by @andrew-nowak 7 minutes and 33 seconds ago) Please check your changes!

@prout-bot
Copy link

Seen on metadata-editor (created by @tonytw1 and merged by @andrew-nowak 7 minutes and 41 seconds ago) Please check your changes!

@prout-bot
Copy link

Seen on leases, usage (created by @tonytw1 and merged by @andrew-nowak 7 minutes and 54 seconds ago) Please check your changes!

@prout-bot
Copy link

Seen on image-loader, kahuna (created by @tonytw1 and merged by @andrew-nowak 7 minutes and 54 seconds ago) Please check your changes!

@prout-bot
Copy link

Seen on leases, usage (created by @tonytw1 and merged by @andrew-nowak 7 minutes and 54 seconds ago) Please check your changes!

@prout-bot
Copy link

Seen on auth (created by @tonytw1 and merged by @andrew-nowak 7 minutes and 55 seconds ago) Please check your changes!

@prout-bot
Copy link

Seen on leases, usage (created by @tonytw1 and merged by @andrew-nowak 8 minutes ago) Please check your changes!

@prout-bot
Copy link

Seen on leases (created by @tonytw1 and merged by @andrew-nowak 8 minutes ago) Please check your changes!

@prout-bot
Copy link

Seen on leases, usage (created by @tonytw1 and merged by @andrew-nowak 8 minutes ago) Please check your changes!

@prout-bot
Copy link

Seen on usage (created by @tonytw1 and merged by @andrew-nowak 8 minutes and 4 seconds ago) Please check your changes!

@andrew-nowak
Copy link
Member

Thanks! I've tested locally and this looks to be working well. I think we have the same problem on the "undelete" button too though - maybe we can add the same logic there too? https://github.com/guardian/grid/blob/main/kahuna/public/js/components/gr-undelete-image/gr-un-delete-image.js

Looking again at this, I think there's a different logic problem here, the undelete button is polling until it finds the image has been deleted, where it should probably be polling until it finds the image has been undeleted. I'll merge this and look at that in a different PR.

#4397

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants