Merge "Remove the replaced activity checking to impact launching performance" into sc-v2-dev am: 6dbc3835f8
Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/16426486 Change-Id: Iadc95c4f5961003d562982148f9e916cf2cf97c6
This commit is contained in:
@@ -18,7 +18,6 @@ package com.android.settings.fuelgauge;
|
|||||||
|
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
@@ -32,8 +31,6 @@ import com.android.settingslib.core.lifecycle.events.OnStart;
|
|||||||
import com.android.settingslib.core.lifecycle.events.OnStop;
|
import com.android.settingslib.core.lifecycle.events.OnStop;
|
||||||
import com.android.settingslib.utils.ThreadUtils;
|
import com.android.settingslib.utils.ThreadUtils;
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
|
|
||||||
public class TopLevelBatteryPreferenceController extends BasePreferenceController implements
|
public class TopLevelBatteryPreferenceController extends BasePreferenceController implements
|
||||||
LifecycleObserver, OnStart, OnStop, BatteryPreferenceController {
|
LifecycleObserver, OnStart, OnStop, BatteryPreferenceController {
|
||||||
|
|
||||||
@@ -43,13 +40,9 @@ public class TopLevelBatteryPreferenceController extends BasePreferenceControlle
|
|||||||
Preference mPreference;
|
Preference mPreference;
|
||||||
private final BatteryBroadcastReceiver mBatteryBroadcastReceiver;
|
private final BatteryBroadcastReceiver mBatteryBroadcastReceiver;
|
||||||
private BatteryInfo mBatteryInfo;
|
private BatteryInfo mBatteryInfo;
|
||||||
private BatterySettingsFeatureProvider mBatterySettingsFeatureProvider;
|
|
||||||
private BatteryStatusFeatureProvider mBatteryStatusFeatureProvider;
|
private BatteryStatusFeatureProvider mBatteryStatusFeatureProvider;
|
||||||
private String mBatteryStatusLabel;
|
private String mBatteryStatusLabel;
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
protected static HashMap<String, ComponentName> sReplacingActivityMap = new HashMap<>();
|
|
||||||
|
|
||||||
public TopLevelBatteryPreferenceController(Context context, String preferenceKey) {
|
public TopLevelBatteryPreferenceController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mBatteryBroadcastReceiver = new BatteryBroadcastReceiver(mContext);
|
mBatteryBroadcastReceiver = new BatteryBroadcastReceiver(mContext);
|
||||||
@@ -63,8 +56,6 @@ public class TopLevelBatteryPreferenceController extends BasePreferenceControlle
|
|||||||
}, true /* shortString */);
|
}, true /* shortString */);
|
||||||
});
|
});
|
||||||
|
|
||||||
mBatterySettingsFeatureProvider = FeatureFactory.getFactory(context)
|
|
||||||
.getBatterySettingsFeatureProvider(context);
|
|
||||||
mBatteryStatusFeatureProvider = FeatureFactory.getFactory(context)
|
mBatteryStatusFeatureProvider = FeatureFactory.getFactory(context)
|
||||||
.getBatteryStatusFeatureProvider(context);
|
.getBatteryStatusFeatureProvider(context);
|
||||||
}
|
}
|
||||||
@@ -81,37 +72,6 @@ public class TopLevelBatteryPreferenceController extends BasePreferenceControlle
|
|||||||
mPreference = screen.findPreference(getPreferenceKey());
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean handlePreferenceTreeClick(Preference preference) {
|
|
||||||
String prefFrag = preference.getFragment();
|
|
||||||
if (prefFrag == null || prefFrag.isEmpty()) {
|
|
||||||
// Not a redirect, so use the default.
|
|
||||||
return super.handlePreferenceTreeClick(preference);
|
|
||||||
}
|
|
||||||
|
|
||||||
ComponentName currentFragmentName = convertClassPathToComponentName(prefFrag);
|
|
||||||
if (currentFragmentName == null) {
|
|
||||||
return super.handlePreferenceTreeClick(preference);
|
|
||||||
}
|
|
||||||
|
|
||||||
ComponentName replacingActivity;
|
|
||||||
if (sReplacingActivityMap.containsKey(prefFrag)) {
|
|
||||||
replacingActivity = sReplacingActivityMap.get(prefFrag);
|
|
||||||
} else {
|
|
||||||
replacingActivity = mBatterySettingsFeatureProvider.getReplacingActivity(
|
|
||||||
currentFragmentName);
|
|
||||||
sReplacingActivityMap.put(prefFrag, replacingActivity);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (replacingActivity == null || currentFragmentName.compareTo(replacingActivity) == 0) {
|
|
||||||
return super.handlePreferenceTreeClick(preference);
|
|
||||||
}
|
|
||||||
Intent intent = new Intent();
|
|
||||||
intent.setComponent(currentFragmentName);
|
|
||||||
mContext.startActivity(intent);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onStart() {
|
public void onStart() {
|
||||||
mBatteryBroadcastReceiver.register();
|
mBatteryBroadcastReceiver.register();
|
||||||
|
@@ -21,11 +21,7 @@ import static com.android.settings.core.BasePreferenceController.UNSUPPORTED_ON_
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.mockito.Mockito.any;
|
|
||||||
import static org.mockito.Mockito.doNothing;
|
|
||||||
import static org.mockito.Mockito.mock;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.times;
|
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
@@ -36,9 +32,7 @@ import android.content.Context;
|
|||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.FakeFeatureFactory;
|
|
||||||
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -50,23 +44,13 @@ import org.robolectric.annotation.Config;
|
|||||||
@RunWith(RobolectricTestRunner.class)
|
@RunWith(RobolectricTestRunner.class)
|
||||||
public class TopLevelBatteryPreferenceControllerTest {
|
public class TopLevelBatteryPreferenceControllerTest {
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private FakeFeatureFactory mFeatureFactory;
|
|
||||||
private TopLevelBatteryPreferenceController mController;
|
private TopLevelBatteryPreferenceController mController;
|
||||||
private BatterySettingsFeatureProvider mBatterySettingsFeatureProvider;
|
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mFeatureFactory = FakeFeatureFactory.setupForTest();
|
|
||||||
mContext = spy(Robolectric.setupActivity(Activity.class));
|
mContext = spy(Robolectric.setupActivity(Activity.class));
|
||||||
mController = new TopLevelBatteryPreferenceController(mContext, "test_key");
|
mController = new TopLevelBatteryPreferenceController(mContext, "test_key");
|
||||||
mBatterySettingsFeatureProvider =
|
|
||||||
mFeatureFactory.batterySettingsFeatureProvider;
|
|
||||||
}
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void cleanUp() {
|
|
||||||
TopLevelBatteryPreferenceController.sReplacingActivityMap.clear();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -80,54 +64,6 @@ public class TopLevelBatteryPreferenceControllerTest {
|
|||||||
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
assertThat(mController.getAvailabilityStatus()).isEqualTo(UNSUPPORTED_ON_DEVICE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
public void handlePreferenceTreeClick_noFragment_noCustomActivityCalled() {
|
|
||||||
Preference preference = new Preference(mContext);
|
|
||||||
|
|
||||||
assertThat(mController.handlePreferenceTreeClick(preference)).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void handlePreferenceTreeClick_sameActivityReturned_noCustomActivityCalled() {
|
|
||||||
String fragmentPath = "my.fragment.ClassName";
|
|
||||||
Preference preference = mock(Preference.class);
|
|
||||||
when(preference.getFragment()).thenReturn(fragmentPath);
|
|
||||||
ComponentName pathName = mController.convertClassPathToComponentName(fragmentPath);
|
|
||||||
when(mBatterySettingsFeatureProvider.getReplacingActivity(any())).thenReturn(pathName);
|
|
||||||
|
|
||||||
assertThat(mController.handlePreferenceTreeClick(preference)).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void handlePreferenceTreeClick_newActivityReturned_newActivityRedirected() {
|
|
||||||
String fragmentPath = "my.fragment.ClassName";
|
|
||||||
Preference preference = mock(Preference.class);
|
|
||||||
when(preference.getFragment()).thenReturn(fragmentPath);
|
|
||||||
String newFragmentPath = "my.fragment.NewClassName";
|
|
||||||
ComponentName newPathName = mController.convertClassPathToComponentName(newFragmentPath);
|
|
||||||
when(mBatterySettingsFeatureProvider.getReplacingActivity(any())).thenReturn(
|
|
||||||
newPathName);
|
|
||||||
doNothing().when(mContext).startActivity(any());
|
|
||||||
|
|
||||||
assertThat(mController.handlePreferenceTreeClick(preference)).isTrue();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void handlePreferenceTreeClick_calledMultipleTimes_fetchedFromCache() {
|
|
||||||
String fragmentPath = "my.fragment.ClassName";
|
|
||||||
Preference preference = mock(Preference.class);
|
|
||||||
when(preference.getFragment()).thenReturn(fragmentPath);
|
|
||||||
String newFragmentPath = "my.fragment.NewClassName";
|
|
||||||
ComponentName newPathName = mController.convertClassPathToComponentName(newFragmentPath);
|
|
||||||
when(mBatterySettingsFeatureProvider.getReplacingActivity(any())).thenReturn(
|
|
||||||
newPathName);
|
|
||||||
doNothing().when(mContext).startActivity(any());
|
|
||||||
|
|
||||||
assertThat(mController.handlePreferenceTreeClick(preference)).isTrue();
|
|
||||||
assertThat(mController.handlePreferenceTreeClick(preference)).isTrue();
|
|
||||||
verify(mBatterySettingsFeatureProvider, times(1)).getReplacingActivity(any());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void convertClassPathToComponentName_nullInput_returnsNull() {
|
public void convertClassPathToComponentName_nullInput_returnsNull() {
|
||||||
assertThat(mController.convertClassPathToComponentName(null)).isNull();
|
assertThat(mController.convertClassPathToComponentName(null)).isNull();
|
||||||
|
Reference in New Issue
Block a user