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

How to capture fetch errors? #28

Closed
toniengelhardt opened this issue Jul 11, 2024 · 12 comments
Closed

How to capture fetch errors? #28

toniengelhardt opened this issue Jul 11, 2024 · 12 comments

Comments

@toniengelhardt
Copy link

toniengelhardt commented Jul 11, 2024

I'm getting a lot of TypeError: Failed to fetch in Sentry from failing Plausible fetch requests:

Screenshot 2024-07-11 at 22 43 22

I tried wrapping the useTrackEvent composable into a try/catch like so:

Screenshot 2024-07-11 at 22 42 52

But the events still get logged and spam Sentry.

Not sure why exactly the requests to the Plausible API fail, but is there a way to properly catch/handle/ignore them?

Might be an upstream issue in plausible-tracker?

@johannschopplich
Copy link
Collaborator

We're not using the Plausible tracker package anymore, since it has been abandoned for years. Instead, we use a fork by @Barbapapazes. Maybe he can tell use more why wrapping the composable won't catch a failing fetch promise? 👀

@Barbapapazes
Copy link
Contributor

Hello 👋,

It's related to this function https://github.com/Barbapapazes/plausible-tracker/blob/main/src/event.ts#L72

Do you think I should add a .catch and let the dev passing a callback to handle it?

@Barbapapazes
Copy link
Contributor

And @toniengelhardt, I think the try...catch does not work because I do not await the event

@Barbapapazes
Copy link
Contributor

Barbapapazes commented Jul 12, 2024

Do you know if every request fails or if it is only some of them (like someone using a blocker) or does Plausible change something to their API?

@toniengelhardt
Copy link
Author

@johannschopplich @Barbapapazes thanks for investigating 🙏🏽

Only very few events fail – not sure if bc of a blocker or bc the Plausible API drops them for some reason – but with a couple thousand events this still leads to quite some noise in Sentry (and unfortunately fetch errors are hard to decipher there).

For me, awaiting the event would make a lot of sense, so that wrapping the composable like in the example would work. But it might be also useful to be able to pass an error handler, ideally globally in the config and directly in the useTrackEvent composable in case it is only needed occasionally.

A failSilently flag would also work, but is probably the most limiting solution.

Any of the above would work for my use case as long as I can somehow prevent errors from being thrown.

@Barbapapazes
Copy link
Contributor

I will need to tackle this in my fork because there trackEvent does not return a promise.

@Barbapapazes
Copy link
Contributor

related to Barbapapazes/plausible-tracker#11

@Barbapapazes
Copy link
Contributor

@toniengelhardt I think you can use the patch (do no hesitate to ping me if it's not working for you) in the issue above because I'll need to add tests to ensure the quality and the future of this fork (and it could takes some times)

@toniengelhardt
Copy link
Author

Thanks @Barbapapazes 🙏🏽

@Barbapapazes
Copy link
Contributor

You can follow the progression with this PR: Barbapapazes/plausible-tracker#13

@Barbapapazes
Copy link
Contributor

Test have been merged, I can now fix this issue.

@obulat obulat mentioned this issue Aug 2, 2024
6 tasks
@johannschopplich
Copy link
Collaborator

This should be resolved with the latest version v1.0.1, which uses the latest version of @Barbapapazes's tracker library. Thanks for the updates!

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

Successfully merging a pull request may close this issue.

3 participants