-
Notifications
You must be signed in to change notification settings - Fork 893
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
Mutating data with Firestore multi-tab-persistence from a browser tab which is not the leader tab causes stale data to emit #6511
Comments
Hi @jorroll. Thank you for taking the time make a thorough bug report. I'll take a look. |
I've been able to reproduce this issue for myself using a much simpler repro app: https://github.com/dconeybe/FirestoreJsIssue6511. There is definitely a bug here and I'll dig into it further. |
@jorroll Through bisection, it appears that this bug was introduced in v9.6.10. Could you try downgrading to v9.6.9 and see if that fixes this bug for you, as a temporary workaround? |
One workaround that came to mind would be to add a field to the documents with the value |
Thanks so much for tracking this down @dconeybe! It looks like downgrading to
We already set an |
As an aside, because of a separate issue in the |
@jorroll Thanks for confirming that downgrading to 9.6.9 fixes the bug for you. You are right that deploying a new version of your app that downgrades from 9.9.2 to 9.6.9 would have issues with persistence. So you're right, that's probably not a viable option. The serverSnapshot workaround should still be usable despite that rxfire issue, no? The heuristic would be that if the serverTimestamp is null then you consider that snapshot to be new data. And then when you get a subsequent snapshot you'd compare that new snapshot's serverTimestamp with the serverTimestamp value before the null one. In any case, I'm continuing to investigate and will keep you posted. |
Just an update that investigation is continuing. No updates yet (I've just returned from vacation). |
Thanks to both of you! |
[REQUIRED] Describe your environment
[REQUIRED] Describe the problem
When using the Firestore SDK with
enableMultiTabIndexedDbPersistence()
, if you open two tabs to the app and you perform a mutation in the second tab (i.e. the tab that was opened second) Firestore will emit an update in response to the change which contains the expected data, then it will emit stale data, then it will emit the correct data again. This happens quickly, I think in less than 100ms (possibly a lot less than 100ms). Meanwhile, the first tab will only emit the correct data (as expected). If you perform the same mutation in the first tab, you do not encounter this error (though the second tab still seems to emit stale data briefly).My theory is that the bug is triggered when enableMultiTabIndexedDbPersistence is turned on and a client tab which is not the Firestore internal "leader tab" attempts to make a change.
Receiving correct data, then stale data, then correct data again is proving very problematic because there doesn't appear to be a good way for the app to tell that the data is stale (other than, perhaps, debouncing Firestore emissions which feels potentially brittle and will slow the UI down). It's possible I'll need to disable
enableMultiTabIndexedDbPersistence
as a work around.I'll also note that, in attempting to diagnose this issue, I may have been able to recreate it when persistence was turned off (still using two tabs), but I'm not positive and, regardless, this reproduction only focuses on the scenerio where multi-tab-persistence is enabled.Note: I ran into this bug in production, though the included repository (below) reproduces the bug using the emulators.
Steps to reproduce:
See this video showing the bug
Here is a repository that can be cloned to reproduce the bug. Note it has an included
.devcontainer
configuration for VSCode if you're into that sort of thing.Relevant Code:
See the included video and repository.
The text was updated successfully, but these errors were encountered: