Fix metro websocket reconnect logic
Summary: This diff fixes the reconnect logic with the metro websockets which is causing the app to not re-connect when metro crashes. To demonstrate the issue, consider the following video: {F156029086} On the left we have metro, on the right is the xcode console with some logging to show the reconnecting phase. When we kill the metro server you can see the app tries to reconnect once and that's it - when metro is started back up, you can see the notification that there are no apps running and can also see that cmd+opt+r doesn't work anymore I updated the logic to optimistically start the connection and if it's still unavailable to retry again after the timeout [iOS][Fixed] - Metro websocket reconnect logic Reviewed By: shergin Differential Revision: D14961433 fbshipit-source-id: 0569aa169dc9f538a7e4a8d04e99de39f2e9b3f9
This commit is contained in:
parent
f71357aa81
commit
c286769d28
|
@ -148,9 +148,9 @@ static void my_os_log_error_impl(void *dso, os_log_t log, os_log_type_t type, co
|
|||
{
|
||||
__weak RCTSRWebSocket *socket = _socket;
|
||||
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
|
||||
// Only reconnect if the observer wasn't stoppped while we were waiting
|
||||
if (socket) {
|
||||
[self start];
|
||||
[self start];
|
||||
if (!socket) {
|
||||
[self reconnect];
|
||||
}
|
||||
});
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue