-
Notifications
You must be signed in to change notification settings - Fork 2.7k
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
useQuery
: delay unsubscribe to fix race conditions
#10629
Changes from 5 commits
bdd733f
da9f2c4
be5b90b
c68afa1
6669420
cd8ed84
60dd769
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
--- | ||
"@apollo/client": patch | ||
--- | ||
|
||
`useQuery`: delay unsubscribe to fix race conditions |
Original file line number | Diff line number | Diff line change | ||
---|---|---|---|---|
|
@@ -208,7 +208,11 @@ class InternalState<TData, TVariables extends OperationVariables> { | |||
|
||||
let subscription = obsQuery.subscribe(onNext, onError); | ||||
|
||||
return () => subscription.unsubscribe(); | ||||
// Do the "unsubscribe" with a short delay. | ||||
// This way, an existing subscription can be reused without an additional | ||||
// request if "unsubscribe" and "resubscribe" to the same ObservableQuery | ||||
// happen in very fast succession. | ||||
return () => setTimeout(() => subscription.unsubscribe()); | ||||
Comment on lines
+211
to
+215
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Some precedent for this technique:
If the delay between the last unsubscription and the resubscription ever gets longer than the minimum There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yup, this is mostly good if the unsubscribe and subscribe are called synchronously - for everything else, it's just a band-aid - but at some level of delay, a refetch might actually be intended. |
||||
}, [ | ||||
// We memoize the subscribe function using useCallback and the following | ||||
// dependency keys, because the subscribe function reference is all that | ||||
|
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.
This test tested if a single query was made but never tested if there was any actual polling going on - that's why we never were aware of this bug.