From 2bc5d3ebd5fb3f9e00ab15c7c9761bf3971d8efe Mon Sep 17 00:00:00 2001 From: James Reggio Date: Wed, 11 Oct 2017 13:22:13 -0400 Subject: [PATCH] Randomize the Android downloaded bundle filename --- .../facebook/react/devsupport/DevSupportManagerImpl.java | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerImpl.java b/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerImpl.java index 2163a63aa6c047..7b36389ba4b0f1 100644 --- a/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerImpl.java +++ b/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerImpl.java @@ -101,7 +101,7 @@ public class DevSupportManagerImpl implements private static final int JAVA_ERROR_COOKIE = -1; private static final int JSEXCEPTION_ERROR_COOKIE = -1; - private static final String JS_BUNDLE_FILE_NAME = "ReactNativeDevBundle.js"; + private static final String JS_BUNDLE_FILE_FORMAT = "ReactNativeDevBundle.%d.js"; private static enum ErrorType { JS, NATIVE @@ -229,11 +229,15 @@ public void onReceive(Context context, Intent intent) { }; // We store JS bundle loaded from dev server in a single destination in app's data dir. + // (We randomize the name in the event that there are multiple JS bridges running.) // In case when someone schedule 2 subsequent reloads it may happen that JS thread will // start reading first reload output while the second reload starts writing to the same // file. As this should only be the case in dev mode we leave it as it is. // TODO(6418010): Fix readers-writers problem in debug reload from HTTP server - mJSBundleTempFile = new File(applicationContext.getFilesDir(), JS_BUNDLE_FILE_NAME); + mJSBundleTempFile = new File( + applicationContext.getFilesDir(), + String.format(JS_BUNDLE_FILE_FORMAT, (int)(Math.random() * 1000000)) + ); mDefaultNativeModuleCallExceptionHandler = new DefaultNativeModuleCallExceptionHandler();