Merge "Hide Wi-Fi toggle in the Wi-Fi slice" into tm-dev am: 3fb9c1a24b am: 5a138163b4 am: 4c10d54239 am: 66262e1052

Original change: https://googleplex-android-review.googlesource.com/c/platform/packages/apps/Settings/+/18157802

Change-Id: Ib5b9b4c566d0996c03dd3115aa2e57848444b513
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
TreeHugger Robot
2022-05-04 18:13:09 +00:00
committed by Automerger Merge Worker
2 changed files with 70 additions and 16 deletions

View File

@@ -25,7 +25,6 @@ import static com.google.common.truth.Truth.assertThat;
import static org.mockito.Mockito.doReturn;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.when;
import android.content.ContentResolver;
@@ -37,9 +36,12 @@ import android.net.wifi.WifiManager;
import androidx.slice.Slice;
import androidx.slice.SliceItem;
import androidx.slice.SliceMetadata;
import androidx.slice.SliceProvider;
import androidx.slice.core.SliceQuery;
import androidx.slice.widget.ListContent;
import androidx.slice.widget.SliceLiveData;
import androidx.test.core.app.ApplicationProvider;
import com.android.settings.R;
import com.android.settings.slices.SliceBackgroundWorker;
@@ -49,12 +51,14 @@ import com.android.wifitrackerlib.WifiEntry;
import com.android.wifitrackerlib.WifiEntry.ConnectedState;
import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.mockito.Spy;
import org.mockito.junit.MockitoJUnit;
import org.mockito.junit.MockitoRule;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.RuntimeEnvironment;
import org.robolectric.annotation.Config;
import org.robolectric.annotation.Implementation;
import org.robolectric.annotation.Implements;
@@ -74,26 +78,29 @@ public class WifiSliceTest {
private static final String AP3_NAME = "ap3";
private static final int USER_ID = 1;
@Rule
public final MockitoRule mMockitoRule = MockitoJUnit.rule();
@Spy
Context mContext = ApplicationProvider.getApplicationContext();
@Mock
private WifiManager mWifiManager;
@Mock
private PackageManager mPackageManager;
private Context mContext;
@Mock
private ContentResolver mResolver;
@Mock
private WifiSlice.WifiRestriction mWifiRestriction;
private WifiSlice mWifiSlice;
private String mSIPackageName;
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
mContext = spy(RuntimeEnvironment.application);
mResolver = mock(ContentResolver.class);
doReturn(mResolver).when(mContext).getContentResolver();
doReturn(mWifiManager).when(mContext).getSystemService(WifiManager.class);
doReturn(WifiManager.WIFI_STATE_ENABLED).when(mWifiManager).getWifiState();
when(mContext.getPackageManager()).thenReturn(mPackageManager);
when(mWifiRestriction.isChangeWifiStateAllowed(mContext)).thenReturn(true);
// Set-up specs for SliceMetadata.
SliceProvider.setSpecs(SliceLiveData.SUPPORTED_SPECS);
@@ -102,7 +109,7 @@ public class WifiSliceTest {
ShadowBinder.setCallingUid(USER_ID);
when(mPackageManager.getPackagesForUid(USER_ID)).thenReturn(new String[]{mSIPackageName});
ShadowWifiSlice.setWifiPermissible(true);
mWifiSlice = new WifiSlice(mContext);
mWifiSlice = new WifiSlice(mContext, mWifiRestriction);
}
@Test
@@ -241,6 +248,30 @@ public class WifiSliceTest {
mContext.getString(R.string.wifi_empty_list_wifi_on));
}
@Test
public void getWifiSlice_disallowedChangeWifiState_addSubtitleAndNoToggle() {
when(mWifiRestriction.isChangeWifiStateAllowed(mContext)).thenReturn(false);
final Slice slice = mWifiSlice.getSlice();
final ListContent listContent = SliceMetadata.from(mContext, slice).getListContent();
assertThat(slice).isNotNull();
assertThat(listContent.getHeader().getSubtitleItem()).isNotNull();
assertThat(listContent.getSliceActions()).isNull();
}
@Test
public void getWifiSlice_allowedChangeWifiState_noSubtitleAndAddToggle() {
when(mWifiRestriction.isChangeWifiStateAllowed(mContext)).thenReturn(true);
final Slice slice = mWifiSlice.getSlice();
final ListContent listContent = SliceMetadata.from(mContext, slice).getListContent();
assertThat(slice).isNotNull();
assertThat(listContent.getHeader().getSubtitleItem()).isNull();
assertThat(listContent.getSliceActions()).isNotNull();
}
@Test
public void handleUriChange_updatesWifi() {
final Intent intent = mWifiSlice.getIntent();