Skip to content

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
@Vinzent03 Vinzent03 merged commit ce582e3 into main Apr 15, 2025
14 checks passed
@Vinzent03 Vinzent03 deleted the fix/web-hot-restart branch April 15, 2025 21:23
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'

3 participants