Skip to content
This repository has been archived by the owner on Jul 22, 2024. It is now read-only.

Commit

Permalink
Telemetry crash fix
Browse files Browse the repository at this point in the history
  • Loading branch information
keianhzo committed Jul 7, 2020
1 parent 9a0715b commit 1619e26
Show file tree
Hide file tree
Showing 4 changed files with 29 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
import org.mozilla.vrbrowser.utils.BitmapCache;
import org.mozilla.vrbrowser.utils.EnvironmentsManager;
import org.mozilla.vrbrowser.utils.LocaleUtils;
import org.mozilla.vrbrowser.utils.SystemUtils;

public class VRBrowserApplication extends Application implements AppServicesProvider {

Expand All @@ -42,6 +43,13 @@ public class VRBrowserApplication extends Application implements AppServicesProv
@Override
public void onCreate() {
super.onCreate();

if (!SystemUtils.isMainProcess(this)) {
return;
}

TelemetryWrapper.init(this, EngineProvider.INSTANCE.getDefaultClient(this));
GleanMetricsService.init(this, EngineProvider.INSTANCE.getDefaultClient(this));
}

protected void onActivityCreate(@NonNull Context activityContext) {
Expand All @@ -53,9 +61,6 @@ protected void onActivityCreate(@NonNull Context activityContext) {
mAppExecutors = new AppExecutors();
mBitmapCache = new BitmapCache(this, mAppExecutors.diskIO(), mAppExecutors.mainThread());
mEnvironmentsManager = new EnvironmentsManager(activityContext);

TelemetryWrapper.init(this, EngineProvider.INSTANCE.getDefaultClient(this));
GleanMetricsService.init(this, EngineProvider.INSTANCE.getDefaultClient(this));
}

@Override
Expand Down
14 changes: 14 additions & 0 deletions app/src/common/shared/org/mozilla/vrbrowser/utils/SystemUtils.java
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
package org.mozilla.vrbrowser.utils;

import android.app.ActivityManager;
import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.os.Process;
import android.util.Log;

import androidx.annotation.NonNull;
Expand Down Expand Up @@ -113,4 +115,16 @@ public static void clearCrashFiles(@NonNull Context context, final ArrayList<Str
}
}

public static boolean isMainProcess(@NonNull Context context) {
int pid = Process.myPid();

final ActivityManager activityManager = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
if (activityManager == null) {
return false;
}

return activityManager.getRunningAppProcesses().stream().anyMatch(processInfo ->
processInfo.pid == pid && processInfo.processName.equals(context.getPackageName()));
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -18,15 +18,15 @@ import org.robolectric.annotation.Config


@RunWith(RobolectricTestRunner::class)
@Config(manifest = Config.NONE)
@Config(manifest = Config.NONE, application = TestApplication::class)
class GleanMetricsServiceTest {

@get:Rule
val gleanRule = GleanTestRule(ApplicationProvider.getApplicationContext())

@Before
fun setup() {
val app = ApplicationProvider.getApplicationContext<VRBrowserApplication>()
val app = ApplicationProvider.getApplicationContext<TestApplication>()
// We use the HttpURLConnectionClient for tests as the GeckoWebExecutor based client needs
// full GeckoRuntime initialization and it crashes in the test environment.
val client = HttpURLConnectionClient()
Expand Down
5 changes: 5 additions & 0 deletions app/src/test/java/org/mozilla/vrbrowser/TestApplication.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
package org.mozilla.vrbrowser

import android.app.Application

class TestApplication: Application()

0 comments on commit 1619e26

Please sign in to comment.