Page MenuHomePhabricator

[native] Add CommSecureStore.set on main thread to resolve race with DB thread
ClosedPublic

Authored by ashoat on Jun 29 2024, 12:27 PM.
Tags
None
Referenced Files
F3893116: D12624.diff
Sat, Jan 25, 1:29 AM
Unknown Object (File)
Sun, Jan 19, 9:10 PM
Unknown Object (File)
Sun, Jan 19, 9:10 PM
Unknown Object (File)
Sun, Jan 19, 9:10 PM
Unknown Object (File)
Sun, Jan 19, 9:10 PM
Unknown Object (File)
Fri, Jan 10, 9:40 AM
Unknown Object (File)
Fri, Jan 10, 9:17 AM
Unknown Object (File)
Dec 16 2024, 7:06 PM
Subscribers
None

Details

Summary

Start by reading the included code comment, which explains why we need it.

This resolves ENG-8069, which was an issue caused by D11702, which was supposed to address ENG-7700.

This Linear comment has some backstory.

Test Plan
  1. Test on physical Android device. Confirm that before this diff it can reproduce ENG-8069
  2. Delete Comm app from phone. Deploy a release build with yarn react-native run-android --variant=release (may need to make sure native/facts/authoritative_keyserver.json is not set)
  3. Repeat the following steps 10 times:
    • Open the app and wait for LoggedOutModal to render
    • Kill the app
    • Open the app again and see if it crashes
    • Between attempts, clear the app's internal storage via settings

Diff Detail

Repository
rCOMM Comm
Branch
ashoat/fixandroid
Lint
No Lint Coverage
Unit
No Test Coverage

Event Timeline

Because this is a major issue affecting end users, I'm going to land this without review and immediately put out a new release.

This revision was not accepted when it landed; it landed in state Needs Review.Jun 29 2024, 12:55 PM
This revision was automatically updated to reflect the committed changes.
ashoat retitled this revision from [native] Add CommSecureStore.get on main thread to resolve race with DB thread to [native] Add CommSecureStore.set on main thread to resolve race with DB thread.Jun 29 2024, 12:58 PM