Fixed crash issues in Emergency Callback Mode
- Avoid using controllers when Catalyst design is enabled Bug: 394015881 Flag: EXEMPT bugfix Test: Manual testing atest NetworkDashboardFragmentTest Change-Id: I4393be5e76c0328f2a53f1d828814491991557f1
This commit is contained in:
@@ -59,7 +59,7 @@ public class NetworkDashboardFragment extends DashboardFragment implements
|
|||||||
public void onAttach(Context context) {
|
public void onAttach(Context context) {
|
||||||
super.onAttach(context);
|
super.onAttach(context);
|
||||||
|
|
||||||
if (isCatalystEnabled()) {
|
if (!isCatalystEnabled()) {
|
||||||
use(AirplaneModePreferenceController.class).setFragment(this);
|
use(AirplaneModePreferenceController.class).setFragment(this);
|
||||||
}
|
}
|
||||||
use(NetworkProviderCallsSmsController.class).init(this);
|
use(NetworkProviderCallsSmsController.class).init(this);
|
||||||
@@ -104,7 +104,7 @@ public class NetworkDashboardFragment extends DashboardFragment implements
|
|||||||
|
|
||||||
switch (requestCode) {
|
switch (requestCode) {
|
||||||
case AirplaneModePreferenceController.REQUEST_CODE_EXIT_ECM:
|
case AirplaneModePreferenceController.REQUEST_CODE_EXIT_ECM:
|
||||||
if (isCatalystEnabled()) {
|
if (!isCatalystEnabled()) {
|
||||||
use(AirplaneModePreferenceController.class)
|
use(AirplaneModePreferenceController.class)
|
||||||
.onActivityResult(requestCode, resultCode, data);
|
.onActivityResult(requestCode, resultCode, data);
|
||||||
}
|
}
|
||||||
|
@@ -15,10 +15,19 @@
|
|||||||
*/
|
*/
|
||||||
package com.android.settings.network;
|
package com.android.settings.network;
|
||||||
|
|
||||||
|
import static android.platform.test.flag.junit.SetFlagsRule.DefaultInitValueType.DEVICE_DEFAULT;
|
||||||
|
|
||||||
|
import static com.android.settings.flags.Flags.FLAG_CATALYST;
|
||||||
|
import static com.android.settings.network.AirplaneModePreferenceController.REQUEST_CODE_EXIT_ECM;
|
||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
import android.app.Instrumentation;
|
import android.app.Instrumentation;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.platform.test.flag.junit.SetFlagsRule;
|
||||||
import android.provider.SearchIndexableResource;
|
import android.provider.SearchIndexableResource;
|
||||||
|
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
@@ -28,21 +37,29 @@ import androidx.test.platform.app.InstrumentationRegistry;
|
|||||||
import com.android.settingslib.drawer.CategoryKey;
|
import com.android.settingslib.drawer.CategoryKey;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
|
import org.junit.Rule;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.Spy;
|
||||||
|
import org.mockito.junit.MockitoJUnit;
|
||||||
|
import org.mockito.junit.MockitoRule;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@RunWith(AndroidJUnit4.class)
|
@RunWith(AndroidJUnit4.class)
|
||||||
public class NetworkDashboardFragmentTest {
|
public class NetworkDashboardFragmentTest {
|
||||||
|
|
||||||
private Context mContext;
|
@Rule
|
||||||
|
public final MockitoRule mMockitoRule = MockitoJUnit.rule();
|
||||||
|
@Rule
|
||||||
|
public final SetFlagsRule mSetFlagsRule = new SetFlagsRule(DEVICE_DEFAULT);
|
||||||
|
@Spy
|
||||||
|
private Context mContext = ApplicationProvider.getApplicationContext();
|
||||||
|
|
||||||
private NetworkDashboardFragment mFragment;
|
private NetworkDashboardFragment mFragment;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mContext = ApplicationProvider.getApplicationContext();
|
|
||||||
final Instrumentation instrumentation = InstrumentationRegistry.getInstrumentation();
|
final Instrumentation instrumentation = InstrumentationRegistry.getInstrumentation();
|
||||||
|
|
||||||
instrumentation.runOnMainSync(() -> {
|
instrumentation.runOnMainSync(() -> {
|
||||||
@@ -65,4 +82,13 @@ public class NetworkDashboardFragmentTest {
|
|||||||
assertThat(indexRes).hasSize(1);
|
assertThat(indexRes).hasSize(1);
|
||||||
assertThat(indexRes.get(0).xmlResId).isEqualTo(mFragment.getPreferenceScreenResId());
|
assertThat(indexRes.get(0).xmlResId).isEqualTo(mFragment.getPreferenceScreenResId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void onActivityResult_catalystIsEnabled_doNotCrash() {
|
||||||
|
mSetFlagsRule.enableFlags(FLAG_CATALYST);
|
||||||
|
NetworkDashboardFragment spyFragment = spy(mFragment);
|
||||||
|
when(spyFragment.getContext()).thenReturn(mContext);
|
||||||
|
|
||||||
|
spyFragment.onActivityResult(REQUEST_CODE_EXIT_ECM, 0, null);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user