Skip to content
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

[Bug]: [ios] Some Native -> JS messages appear to drop after extended time with app in background #7810

Open
1 of 3 tasks
gabeschine opened this issue Dec 18, 2024 · 3 comments
Assignees
Labels

Comments

@gabeschine
Copy link

Capacitor Version

💊 Capacitor Doctor 💊

Latest Dependencies:

@capacitor/cli: 6.2.0
@capacitor/core: 6.2.0
@capacitor/android: 6.2.0
@capacitor/ios: 6.2.0

Installed Dependencies:

@capacitor/android: not installed
@capacitor/core: 6.2.0
@capacitor/ios: 6.2.0
@capacitor/cli: 6.2.0

[success] iOS looking great! 👌

Other API Details

yarn --version: 1.22.11
node --version: v20.10.0

Platforms Affected

  • iOS
  • Android
  • Web

Current Behavior

If a Capacitor app is backgrounded for a long time, and during this time a notification is delivered to the device and clicked or a deeplink open request is received, when the app is foregrounded the relevant message (either the notification payload from a plugin like @capacitor/push-notifications or the appUrlOpen event from @capacitor/app) is sometimes dropped.

In the field when this occurs, we observe the app's web view reload immediately upon foregrounding.

In testing, it is possible to reproduce the behavior, and it appears to be tied to the timing of iOS notifying the native app through webViewWebContentProcessDidTerminate [1]: if the notification happens immediately, messages are delivered successfully; if the notification is delayed until the app is foregrounded, the messages are not delivered.

[1] https://developer.apple.com/documentation/webkit/wknavigationdelegate/webviewwebcontentprocessdidterminate(_:)

Expected Behavior

The messages are delivered in all scenarios.

Project Reproduction

https://github.com/watch-duty/capacitor-message-bug-repro

Additional Information

The reproduction is not a perfect mirror of what happens in production.

In production: it appears that iOS is killing the WebContent process on its own. Based on reading this can happen to reduce memory pressure or other resource pressure, or based on other conditions unknown to me.

In the reproduction: killing the WebContent process is performed explicitly, since it is impossible to deterministically trigger the same resource pressure conditions encountered in production.

The reproduction is assuming that while the trigger is different, the subsequent symptoms and bug mechanism are shared. Based on many, many user reports of the bug, and associated data gather that we have performed, this appears to be a sound assumption.

@davidemerritt
Copy link

+1 here - this reflects what I've seen in our application as well, affecting push notification handling.

@markemer markemer self-assigned this Jan 6, 2025
@markemer
Copy link
Member

This is somewhat expected behavior from iOS. iOS will kill you for any reason at any time. But, we shouldn't be dropping Native to JS calls, but I expect this is gonna be an interesting one to solve.

@gabeschine and @davidemerritt have you investigated using ionic-team/capacitor-background-runner? while I investigate?

Also, @davidemerritt, if you could add a reproduction to this ticket as well, I'd appreciate it. The more data the better.

@gabeschine
Copy link
Author

gabeschine commented Jan 13, 2025

This is somewhat expected behavior from iOS. iOS will kill you for any reason at any time. But, we shouldn't be dropping Native to JS calls, but I expect this is gonna be an interesting one to solve.

Understood - expected given the systems in question. I agree with your qualifier, though :). Let me know if you'd like to chat through possible approaches.

@gabeschine and @davidemerritt have you investigated using ionic-team/capacitor-background-runner? while I investigate?

Took a quick look. After processing a notification, we will need to communicate with the JS process in the WebView to mutate the router to set the window location to the correct path. Given that requirement, I'm not immediately seeing how a background task would help: it looks like the background task would have a chance to process the notification payload, but then that information would still need to be sent to the foreground WebView once it's spun back up.

Also, @davidemerritt, if you could add a reproduction to this ticket as well, I'd appreciate it. The more data the better.

Dave works with me 😇. Apologies if that was misleading. The reproduction I attached here went through many iterations: I believe it's pretty robust.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

3 participants