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

fix: Dispose supabase client after flutter web hot-restart #1142

Open
wants to merge 8 commits into
base: main
Choose a base branch
from

Conversation

Vinzent03
Copy link
Collaborator

@Vinzent03 Vinzent03 commented Mar 27, 2025

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, because stream.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

@Vinzent03 Vinzent03 changed the title fix: disconnect open realtime client after flutter web hot-restart fix: Disconnect open realtime client after flutter web hot-restart Mar 27, 2025
@Vinzent03 Vinzent03 force-pushed the fix/web-hot-restart branch from 599ddc3 to 9f3066b Compare March 27, 2025 13:14
@coveralls
Copy link

coveralls commented Mar 27, 2025

Pull Request Test Coverage Report for Build 14173380797

Details

  • 6 of 7 (85.71%) changed or added relevant lines in 5 files are covered.
  • No unchanged relevant lines lost coverage.
  • Overall coverage increased (+0.006%) to 75.432%

Changes Missing Coverage Covered Lines Changed/Added Lines %
packages/gotrue/lib/src/gotrue_client.dart 0 1 0.0%
Totals Coverage Status
Change from base Build 14080727348: 0.006%
Covered Lines: 2840
Relevant Lines: 3765

💛 - Coveralls

@Vinzent03 Vinzent03 requested a review from dshukertjr March 27, 2025 13:18
@Vinzent03 Vinzent03 removed the request for review from dshukertjr March 29, 2025 10:40
@Vinzent03 Vinzent03 marked this pull request as draft March 29, 2025 10:40
@Vinzent03 Vinzent03 changed the title fix: Disconnect open realtime client after flutter web hot-restart fix: Dispose supabase client after flutter web hot-restart Mar 31, 2025
@Vinzent03 Vinzent03 marked this pull request as ready for review March 31, 2025 13:59
@Vinzent03 Vinzent03 requested a review from dshukertjr March 31, 2025 14:00
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 this pull request may close these issues.

Postgres Changes don't closes connection on flutter web 'hot reload'
2 participants