Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 54036162 authored by Treehugger Robot's avatar Treehugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Fixed crash issues in Emergency Callback Mode" into main

parents 5cf92e60 af065146
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -59,7 +59,7 @@ public class NetworkDashboardFragment extends DashboardFragment implements
    public void onAttach(Context context) {
        super.onAttach(context);

        if (isCatalystEnabled()) {
        if (!isCatalystEnabled()) {
            use(AirplaneModePreferenceController.class).setFragment(this);
        }
        use(NetworkProviderCallsSmsController.class).init(this);
@@ -104,7 +104,7 @@ public class NetworkDashboardFragment extends DashboardFragment implements

        switch (requestCode) {
            case AirplaneModePreferenceController.REQUEST_CODE_EXIT_ECM:
                if (isCatalystEnabled()) {
                if (!isCatalystEnabled()) {
                    use(AirplaneModePreferenceController.class)
                            .onActivityResult(requestCode, resultCode, data);
                }
+28 −2
Original line number Diff line number Diff line
@@ -15,10 +15,19 @@
 */
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 org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;

import android.app.Instrumentation;
import android.content.Context;
import android.platform.test.flag.junit.SetFlagsRule;
import android.provider.SearchIndexableResource;

import androidx.test.core.app.ApplicationProvider;
@@ -28,21 +37,29 @@ import androidx.test.platform.app.InstrumentationRegistry;
import com.android.settingslib.drawer.CategoryKey;

import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Spy;
import org.mockito.junit.MockitoJUnit;
import org.mockito.junit.MockitoRule;

import java.util.List;

@RunWith(AndroidJUnit4.class)
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;

    @Before
    public void setUp() {
        mContext = ApplicationProvider.getApplicationContext();
        final Instrumentation instrumentation = InstrumentationRegistry.getInstrumentation();

        instrumentation.runOnMainSync(() -> {
@@ -65,4 +82,13 @@ public class NetworkDashboardFragmentTest {
        assertThat(indexRes).hasSize(1);
        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);
    }
}