fix: Dispose supabase client after flutter web hot-restart #1142
+65
−17
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What kind of change does this PR introduce?
Bug fix
What is the current behavior?
WebSocket and braodcast channel connections are not closed when Flutter is hot-restarted on web.
This causes old dart code that is still associated with the WebSocket connection to be still running and causes unexpected behavior like type errors and the fact that the events of the old connection may still be logged.
What is the new behavior?
I'm storing a function in js to disconnect the previous supabase client.
I further noticed that the
longtimerPollerTimeout
was never actually used, becausestream.timeout()
returns a new stream with that timeout, but doesn't change the actually stream that timeout is called on. This could easily be fixed, but I found no usage of such timeout in realtime-js in a quick search, so I removed it instead.I as well noticed that the broadcast channel didn't work, so I fixed the migration from #1135
Additional context
I worked a lot to find the cause for #1126, and I noticed that the event and code that is causing the type error is old code after a hot-restart. So I tried to solve #1088 and I think I succeeded. I'm no longer seeing the error from #1126 now.close #1088