Merge "[Network Connection] Call NetworkRequestUserSelectionCallback#reject() if user quit activity without selection" into qt-qpr1-dev
am: 17cbea0112
Change-Id: Icc3c00f542746c1ffa423c04c160ba85e53ad834
This commit is contained in:
@@ -340,6 +340,7 @@ public class NetworkRequestDialogFragment extends InstrumentedDialogFragment imp
|
|||||||
// Throws error dialog.
|
// Throws error dialog.
|
||||||
final NetworkRequestErrorDialogFragment fragment = NetworkRequestErrorDialogFragment
|
final NetworkRequestErrorDialogFragment fragment = NetworkRequestErrorDialogFragment
|
||||||
.newInstance();
|
.newInstance();
|
||||||
|
fragment.setRejectCallback(mUserSelectionCallback);
|
||||||
final Bundle bundle = new Bundle();
|
final Bundle bundle = new Bundle();
|
||||||
bundle.putSerializable(NetworkRequestErrorDialogFragment.DIALOG_TYPE, type);
|
bundle.putSerializable(NetworkRequestErrorDialogFragment.DIALOG_TYPE, type);
|
||||||
fragment.setArguments(bundle);
|
fragment.setArguments(bundle);
|
||||||
|
@@ -20,8 +20,10 @@ import android.app.Dialog;
|
|||||||
import android.app.settings.SettingsEnums;
|
import android.app.settings.SettingsEnums;
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.net.wifi.WifiManager.NetworkRequestUserSelectionCallback;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
import androidx.appcompat.app.AlertDialog;
|
import androidx.appcompat.app.AlertDialog;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
@@ -36,6 +38,8 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
|||||||
public static final String DIALOG_TYPE = "DIALOG_ERROR_TYPE";
|
public static final String DIALOG_TYPE = "DIALOG_ERROR_TYPE";
|
||||||
|
|
||||||
public enum ERROR_DIALOG_TYPE {TIME_OUT, ABORT}
|
public enum ERROR_DIALOG_TYPE {TIME_OUT, ABORT}
|
||||||
|
@Nullable
|
||||||
|
private NetworkRequestUserSelectionCallback mRejectCallback;
|
||||||
|
|
||||||
public static NetworkRequestErrorDialogFragment newInstance() {
|
public static NetworkRequestErrorDialogFragment newInstance() {
|
||||||
return new NetworkRequestErrorDialogFragment();
|
return new NetworkRequestErrorDialogFragment();
|
||||||
@@ -49,7 +53,7 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
|||||||
public void onCancel(@NonNull DialogInterface dialog) {
|
public void onCancel(@NonNull DialogInterface dialog) {
|
||||||
super.onCancel(dialog);
|
super.onCancel(dialog);
|
||||||
// Wants to finish the activity when user clicks back key or outside of the dialog.
|
// Wants to finish the activity when user clicks back key or outside of the dialog.
|
||||||
getActivity().finish();
|
rejectNetworkRequestAndFinish();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -65,10 +69,12 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
|||||||
builder.setMessage(R.string.network_connection_timeout_dialog_message)
|
builder.setMessage(R.string.network_connection_timeout_dialog_message)
|
||||||
.setPositiveButton(R.string.network_connection_timeout_dialog_ok,
|
.setPositiveButton(R.string.network_connection_timeout_dialog_ok,
|
||||||
(dialog, which) -> startScanningDialog())
|
(dialog, which) -> startScanningDialog())
|
||||||
.setNegativeButton(R.string.cancel, (dialog, which) -> getActivity().finish());
|
.setNegativeButton(R.string.cancel,
|
||||||
|
(dialog, which) -> rejectNetworkRequestAndFinish());
|
||||||
} else {
|
} else {
|
||||||
builder.setMessage(R.string.network_connection_errorstate_dialog_message)
|
builder.setMessage(R.string.network_connection_errorstate_dialog_message)
|
||||||
.setPositiveButton(R.string.okay, (dialog, which) -> getActivity().finish());
|
.setPositiveButton(R.string.okay,
|
||||||
|
(dialog, which) -> rejectNetworkRequestAndFinish());
|
||||||
}
|
}
|
||||||
return builder.create();
|
return builder.create();
|
||||||
}
|
}
|
||||||
@@ -78,9 +84,23 @@ public class NetworkRequestErrorDialogFragment extends InstrumentedDialogFragmen
|
|||||||
return SettingsEnums.WIFI_SCANNING_NEEDED_DIALOG;
|
return SettingsEnums.WIFI_SCANNING_NEEDED_DIALOG;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Sets the callback for fragment to reject this request.
|
||||||
|
public void setRejectCallback(NetworkRequestUserSelectionCallback rejectCallback) {
|
||||||
|
mRejectCallback = rejectCallback;
|
||||||
|
}
|
||||||
|
|
||||||
protected void startScanningDialog() {
|
protected void startScanningDialog() {
|
||||||
final NetworkRequestDialogFragment fragment = NetworkRequestDialogFragment.newInstance();
|
final NetworkRequestDialogFragment fragment = NetworkRequestDialogFragment.newInstance();
|
||||||
fragment.show(getActivity().getSupportFragmentManager(),
|
fragment.show(getActivity().getSupportFragmentManager(),
|
||||||
NetworkRequestErrorDialogFragment.class.getSimpleName());
|
NetworkRequestErrorDialogFragment.class.getSimpleName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void rejectNetworkRequestAndFinish() {
|
||||||
|
if (getActivity() != null) {
|
||||||
|
if (mRejectCallback != null) {
|
||||||
|
mRejectCallback.reject();
|
||||||
|
}
|
||||||
|
getActivity().finish();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -18,11 +18,13 @@ package com.android.settings.wifi;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.internal.verification.VerificationModeFactory.times;
|
import static org.mockito.internal.verification.VerificationModeFactory.times;
|
||||||
|
|
||||||
import android.content.DialogInterface;
|
import android.content.DialogInterface;
|
||||||
|
import android.net.wifi.WifiManager.NetworkRequestUserSelectionCallback;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
|
|
||||||
@@ -32,6 +34,8 @@ import androidx.fragment.app.FragmentActivity;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.shadow.ShadowAlertDialogCompat;
|
import com.android.settings.testutils.shadow.ShadowAlertDialogCompat;
|
||||||
import com.android.settings.wifi.NetworkRequestErrorDialogFragment.ERROR_DIALOG_TYPE;
|
import com.android.settings.wifi.NetworkRequestErrorDialogFragment.ERROR_DIALOG_TYPE;
|
||||||
|
import com.android.settingslib.wifi.WifiTracker;
|
||||||
|
import com.android.settingslib.wifi.WifiTrackerFactory;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -47,12 +51,17 @@ public class NetworkRequestErrorDialogFragmentTest {
|
|||||||
|
|
||||||
private FragmentActivity mActivity;
|
private FragmentActivity mActivity;
|
||||||
private NetworkRequestErrorDialogFragment mFragment;
|
private NetworkRequestErrorDialogFragment mFragment;
|
||||||
|
private WifiTracker mWifiTracker;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
mActivity = Robolectric.setupActivity(FragmentActivity.class);
|
mActivity = Robolectric.setupActivity(FragmentActivity.class);
|
||||||
mFragment = spy(NetworkRequestErrorDialogFragment.newInstance());
|
mFragment = spy(NetworkRequestErrorDialogFragment.newInstance());
|
||||||
mFragment.show(mActivity.getSupportFragmentManager(), null);
|
mFragment.show(mActivity.getSupportFragmentManager(), null);
|
||||||
|
|
||||||
|
// Prevents NPE when calling up NetworkRequestDialogFragment.
|
||||||
|
mWifiTracker = mock(WifiTracker.class);
|
||||||
|
WifiTrackerFactory.setTestingWifiTracker(mWifiTracker);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -111,4 +120,17 @@ public class NetworkRequestErrorDialogFragmentTest {
|
|||||||
negativeButton.performClick();
|
negativeButton.performClick();
|
||||||
assertThat(alertDialog.isShowing()).isFalse();
|
assertThat(alertDialog.isShowing()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void clickNegativeButton_shouldCallReject() {
|
||||||
|
final NetworkRequestUserSelectionCallback rejectCallback =
|
||||||
|
mock(NetworkRequestUserSelectionCallback.class);
|
||||||
|
mFragment.setRejectCallback(rejectCallback);
|
||||||
|
|
||||||
|
final AlertDialog alertDialog = ShadowAlertDialogCompat.getLatestAlertDialog();
|
||||||
|
final Button negativeButton = alertDialog.getButton(DialogInterface.BUTTON_NEGATIVE);
|
||||||
|
negativeButton.performClick();
|
||||||
|
|
||||||
|
verify(rejectCallback, times(1)).reject();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user