-
Notifications
You must be signed in to change notification settings - Fork 1k
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
feat: Notify JS-layer when webview crashed #2379
Comments
Since appRestoredResult is Android only, we could just try to implement it for iOS too, but that won't work for your user case as it passes info from the last plugin call and you are not using a plugin. |
@jcesarmobile Yeah, I looked at that event too, but seems like it has slightly different semantics/meaning. It's more of a switching thing. Maybe a separate event for crashes would make more sense, e.g. |
Would it be so crazy to crash the app if |
Yeah, it’s crazy to crash an iOS app, apple will reject apps if they crash |
In that case I support @sandstrom 's idea of something like a |
Just another though – silently restarting the webview can leave plugins in an inconsistent state. For example, if you have called I have been running Capacitor in development with the below modification for months now, and I would love to see this behaviour behind a configuration option. diff --git a/CAPBridgeViewController.swift b/CAPBridgeViewController.swift
index 431c46ae..fb1c8bdd 100644
--- a/CAPBridgeViewController.swift
+++ b/CAPBridgeViewController.swift
@@ -344,7 +344,7 @@ public class CAPBridgeViewController: UIViewController, CAPBridgeDelegate, WKScr
}
public func webViewWebContentProcessDidTerminate(_ webView: WKWebView) {
- webView.reload()
+ fatalError("webViewWebContentProcessDidTerminate")
} |
Does this work?
|
I believe that is the default behaviour... |
@diachedelic cannot find this function at Capacitor 3.3.4 @capacitor/ios/Capacitor/Capacitor/CapacitorBridge.swift |
Oh wow. So what happens now when the webview crashes on iOS? |
Not sure what happens now, but it appears the reload was just added back in #5391 I'm glad it was added back as we've had issues where the OS kills the WebView process and we need to recover (JetSam or what-have-you). We plan to very soon add logging to Sentry when it occurs so we can learn more about it happening in production and make better informed decisions on our technical approaches. That's why I'm interested in this issue. Not sure exactly what we'll do at the moment to capture the automatic reload event but I have some not-amazing ideas to try out. 🙂 |
We have found the iOS WebView to be very sensitive to memory usage. It crashes quite often on startup, possibly due to this bug: https://bugs.webkit.org/show_bug.cgi?id=212790. If you have any memory leaks in the WebView, it will eventually be terminated. WebKit unfortunately has some nasty memory leaks associated with the In general, an automatic reload is necessary in production. But I would prefer a crash in development. And ideally, we should be able to override the default behaviour, so we can maintain the integrity of the app. |
Yep, it can be rough. Using more resource/memory-intensive technologies like WebGL (used in modern map control JS libraries) can exacerbate it as well. We'd like to embrace that technology but are held back. |
Yes! We need a hook in as well to know when this happens. Maybe having a event that I can hook into so I can "embrace the crash" and re-hydrate my application to where they left off? iOS is not getting any better with new devices. It seems the govenator is set with 5 year old specs in mind :( |
I posted a Q&A Discussion item related to detecting the involuntary reload for anyone who's curious. It also summarizes our approach to informing the JS layer about the reload (albeit not with an event). |
We're also running into the webview crash when switching back to our backgrounded app after using an intensive app (such as a game). We suspect it's due to low RAM. We've found that for our Angular application Interestingly, |
@rossholdway what you are describing in the last comment here is exactly what we are currently experiencing. We have built an Ionic app that crashes when coming back from the background mode after a heavy load in a separate app like the camera or a game. So far we are not able to correctly restart our application to be in a working state again. Therefore it would be very interesting to know, if you have been able to solve this issue? |
Just as a point of interest, I have a patch up for Android at least that works to expose this crash event through the plugin interfaces. Hypothetically, it should be possible to build a plugin that catches and restarts the app when this case is detected: #6416 |
Has anyone found a stable resolution ? DescriptionWhen the iOS app is sent to background for an extended period (e.g., overnight) and then brought back to foreground, the WebView enters an inconsistent state where it shows the login screen despite the user being authenticated. Reproduction Steps
Expected Behavior
Actual Behavior
Technical Context
Environment
|
@Eric-Savvi did you fix ? I have same issue |
@ZachooBuilds Not 100% sure why it works, but we resolved this by using We have a hack / patch we use on open func webViewWebContentProcessDidTerminate(_ webView: WKWebView) {
- webView.reload()
+ let defaultUrl = URL(string:"capacitor://localhost")
+ let request = URLRequest(url: webView.url ?? defaultUrl!)
+ webView.load(request)
} |
|
Feature Request
It would be great if the JS-layer (Capacitor app) could know that the underlying web view crashed and subsequently restarted. Right now there is nothing to discern these from a regular app startup and users won't be aware that data was lost.
More concretely, an issue that occur frequently is that we take a photograph via an
<input capture>
element and do on-the-fly resize using JS and canvas, and the web view crashes, causing the page to reload. But for the user this isn't obvious, it's just a short flash when the web view reloads, and they don't know that the photograph failed and they've just lost data.If we could listen to these events we could show a warning to the user.
This is the code on iOS today:
capacitor/ios/Capacitor/Capacitor/CAPBridgeViewController.swift
Lines 279 to 281 in 0a25cce
Platform Support Requested
Describe Preferred Solution
There are multiple solutions, but one could be a listener similar to
appRestoredResult
, that would let us know that the app restored after a crash.We'd then have the ability to show a warning to the user.
Additional Context
This related issue about the web view crashing when taking photos: #2265
The text was updated successfully, but these errors were encountered: