Page MenuHomePhabricator

Place call to completionHandler outside rescinding callback so that we avoid app being killed by the system
AbandonedPublic

Authored by marcin on Jul 19 2022, 2:49 AM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Jan 12, 12:10 PM
Unknown Object (File)
Sun, Jan 12, 11:06 AM
Unknown Object (File)
Sun, Jan 12, 11:02 AM
Unknown Object (File)
Sun, Jan 12, 10:58 AM
Unknown Object (File)
Sun, Jan 12, 10:57 AM
Unknown Object (File)
Sun, Jan 12, 10:55 AM
Unknown Object (File)
Sun, Jan 12, 10:53 AM
Unknown Object (File)
Sun, Jan 12, 10:52 AM

Details

Summary

This diff moves call to completionHandler from rescinding callback in AppDelegate in handleBackgroundNotification. As established before rescinding callback is highly unlikely to ever be called, but failure to call completionHandler will result in app being terminated by the system

Test Plan

Launch the app from XCode and put it into background mode. Open two web clients one of which is the same as mobile one. Send messages and read them on web client several times waiting a couple of minutes between each trial. Ensure that app is still running.

Diff Detail

Repository
rCOMM Comm
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

tomek requested changes to this revision.Jul 19 2022, 3:12 AM

This code doesn't work correctly. We need to wait for the loop to finish before calling the completion handler. The code starting with ^ is a block and can return before being completed (just like an async function).

This revision now requires changes to proceed.Jul 19 2022, 3:12 AM

Wait for resdingin loop to complete

So the idea on this diff is that we want to make sure that we call completionHandler before we return YES, as well as calling completionHandler on the main thread? Whereas the idea of D4576 is that we just need to call completionHandler on the main thread, and the order of return YES vs. calling completionHandler does not matter?

So the idea on this diff is that we want to make sure that we call completionHandler before we return YES, as well as calling completionHandler on the main thread? Whereas the idea of D4576 is that we just need to call completionHandler on the main thread, and the order of return YES vs. calling completionHandler does not matter?

Yes, exactly. Your understanding is correct.

ashoat requested changes to this revision.Jul 19 2022, 9:43 AM

I don't think it matters when application:didReceiveRemoteNotification:fetchCompletionHandler: returns, so since both approached seemed to work let's go with D4576 for now. We can bring this one back if D4576 doesn't work

This revision now requires changes to proceed.Jul 19 2022, 9:43 AM

Rebase master before landing

This revision was not accepted when it landed; it landed in state Needs Review.Jul 19 2022, 10:02 AM
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
ashoat requested changes to this revision.Jul 19 2022, 12:00 PM

Thanks for fixing things up!! Removing from my queue until we can confirm it's necessary (we're first testing just D4576 on its own)

This revision now requires changes to proceed.Jul 19 2022, 12:00 PM

This diff was only used to create a release that was supposed to fix a crash: https://linear.app/comm/issue/ENG-1464/ios-build-137-crashes. The solution wasn't correct.