-
-
Notifications
You must be signed in to change notification settings - Fork 725
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
Alert user when error requesting a report #12867
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice one ! we could probably do something a bit nicer than using an alert but that's better than nothing. I hate it when error get swallowed.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually it's causing issue on the bulk product page, if you try to update a product that will fails we get a 422 that we handle nicely on the UI. But with this change we now get an alert !
Oh, that makes sense, thanks for checking that out. It's worrying that the specs didn't pick that up! |
I think the system specs accept alert by default if no behaviour specified. |
app/webpacker/js/turbo.js
Outdated
if(status == 401) { | ||
alert(I18n.t("errors.unauthorized.message")); | ||
} else if(status === undefined) { | ||
alert(I18n.t("errors.network_error.message")); | ||
} else { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looking at this again, I think we should not catch all 4xx (Client errors) with a generic message. They need specific handling and perhaps are handled differently in different parts of the app.
But we can catch all 5xx (server errors) and give a general message.
} else { | |
} else if (status >= 500) { |
(I'm not sure if status is a string or integer, but it will be sorted correctly either way)
How does that sound to you @rioug?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I note that the existing frame-missing
event handler would no longer cover the situation where an unexpected client error results in no turbo-frame response. But Gaetan already tested that a 422 is handled correctly, so it should be fine 👍
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sounds good 👍
I'm not sure why, but Turbo was swallowing the unauthorized error, so I thought we should alert the user to help with debugging. Same with network error, it gave no feedback before. I think this is testable in theory, but I haven't invested the time on it.
32dac1a
to
a3a7968
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice one 👍
Hey @dacook , It seems you've already tested this one on a staging server? I had a look at it anyway.
1.a) After disconnecting WIFI connection Before this PR - left pic, clicking "Go" does nothing 1.b) After logging out and back in with a user with no permissions Redirects the user to the homepage in both before and after this PR.
2.a) After logging out, and back in as a customer profile Before this PR - left pic, clicking "Save Changes" triggers the previous modal 2.b) After logging out, and back in as a hub, with no permissions to edit those products Before this PR - left pic, clicking "Save Changes" triggers the previous modal
Both before and after this PR, the same message is displayed I'm not sure why I was not able to reproduce the "unauthorized" message on the products page. Still, there is clear improvement (test case 1) so I think we could merge this. Moving it to ready to go. |
I'm not sure why, but Turbo was swallowing the
unauthorized
error, so I thought we should alert the user to help with debugging. Same with network error, it gave no feedback before.I think this can be tested with Capybara in theory, but I haven't invested the time on it.
What should we test?
This occurs whenever submitting a form with Turbo. The best example is running any report.
There are three types of errors:
This can be tested with bug Asking a report has no result when the producer is set as profile only (doesn't sell products) #12835. OtherwiseI think you could test this by log out in another tab then log in as a shoppersudo systemctl stop puma
(then start it again).There are other types of errors that aren't handled by this and should be handled differently, for example: