This means that in some cases RestrictedLockUtils has to be used and in some RestrictedLockUtilsInternal. This causes a lot of trivial code changes. I also updated the ordering of the imports in all affected files. Bug: 110953302 Test: Built make -j RunSettingsRoboTests Change-Id: I9bdf8b89134f853bae4f38c81af436715c73e924
161 lines
5.8 KiB
Java
161 lines
5.8 KiB
Java
/*
|
|
* Copyright (C) 2018 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
package com.android.settings.nfc;
|
|
|
|
import static com.google.common.truth.Truth.assertThat;
|
|
|
|
import static org.mockito.Mockito.spy;
|
|
import static org.mockito.Mockito.when;
|
|
|
|
import android.content.Context;
|
|
import android.nfc.NfcAdapter;
|
|
import android.nfc.NfcManager;
|
|
import android.os.UserHandle;
|
|
import android.os.UserManager;
|
|
import android.provider.Settings;
|
|
|
|
import androidx.preference.PreferenceScreen;
|
|
|
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
|
import com.android.settingslib.RestrictedLockUtilsInternal;
|
|
import com.android.settingslib.RestrictedPreference;
|
|
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.mockito.Mock;
|
|
import org.mockito.MockitoAnnotations;
|
|
import org.robolectric.RuntimeEnvironment;
|
|
import org.robolectric.util.ReflectionHelpers;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
@RunWith(SettingsRobolectricTestRunner.class)
|
|
public class AndroidBeamPreferenceControllerTest {
|
|
|
|
Context mContext;
|
|
@Mock
|
|
private NfcAdapter mNfcAdapter;
|
|
@Mock
|
|
NfcManager mManager;
|
|
@Mock
|
|
private UserManager mUserManager;
|
|
@Mock
|
|
private PreferenceScreen mScreen;
|
|
|
|
private RestrictedPreference mAndroidBeamPreference;
|
|
private AndroidBeamPreferenceController mAndroidBeamController;
|
|
|
|
@Before
|
|
public void setUp() {
|
|
MockitoAnnotations.initMocks(this);
|
|
mContext = spy(RuntimeEnvironment.application);
|
|
|
|
when(mContext.getApplicationContext()).thenReturn(mContext);
|
|
when(mContext.getSystemService(Context.USER_SERVICE)).thenReturn(mUserManager);
|
|
when(mContext.getSystemService(Context.NFC_SERVICE)).thenReturn(mManager);
|
|
when(RestrictedLockUtilsInternal.hasBaseUserRestriction(mContext,
|
|
UserManager.DISALLOW_OUTGOING_BEAM, UserHandle.myUserId())).thenReturn(false);
|
|
when(NfcAdapter.getDefaultAdapter(mContext)).thenReturn(mNfcAdapter);
|
|
|
|
mAndroidBeamController = new AndroidBeamPreferenceController(mContext,
|
|
AndroidBeamPreferenceController.KEY_ANDROID_BEAM_SETTINGS);
|
|
mAndroidBeamPreference = new RestrictedPreference(RuntimeEnvironment.application);
|
|
when(mScreen.findPreference(mAndroidBeamController.getPreferenceKey())).thenReturn(
|
|
mAndroidBeamPreference);
|
|
|
|
Settings.Global.putString(mContext.getContentResolver(),
|
|
Settings.Global.AIRPLANE_MODE_TOGGLEABLE_RADIOS,
|
|
Settings.Global.RADIO_NFC);
|
|
Settings.Global.putInt(mContext.getContentResolver(),
|
|
Settings.Global.AIRPLANE_MODE_ON,
|
|
0);
|
|
mAndroidBeamController.displayPreference(mScreen);
|
|
}
|
|
|
|
@Test
|
|
public void isAvailable_hasNfc_shouldReturnTrue() {
|
|
when(mNfcAdapter.isEnabled()).thenReturn(true);
|
|
assertThat(mAndroidBeamController.isAvailable()).isTrue();
|
|
}
|
|
|
|
@Test
|
|
public void isAvailable_noNfcAdapter_shouldReturnFalse() {
|
|
ReflectionHelpers.setField(mAndroidBeamController, "mNfcAdapter", null);
|
|
assertThat(mAndroidBeamController.isAvailable()).isFalse();
|
|
}
|
|
|
|
@Test
|
|
public void isBeamEnable_disAllowBeam_shouldReturnFalse() {
|
|
when(mNfcAdapter.getAdapterState()).thenReturn(NfcAdapter.STATE_OFF);
|
|
|
|
when(RestrictedLockUtilsInternal.hasBaseUserRestriction(mContext,
|
|
UserManager.DISALLOW_OUTGOING_BEAM, UserHandle.myUserId())).thenReturn(true);
|
|
mAndroidBeamController.displayPreference(mScreen);
|
|
|
|
assertThat(mAndroidBeamPreference.isEnabled()).isFalse();
|
|
}
|
|
|
|
@Test
|
|
public void isBeamEnable_nfcStateOn_shouldReturnTrue() {
|
|
when(mNfcAdapter.getAdapterState()).thenReturn(NfcAdapter.STATE_ON);
|
|
try {
|
|
mAndroidBeamController.onResume();
|
|
} catch (NullPointerException e) {
|
|
// skip because it's just test
|
|
// it will meet NullPointerException in checkRestrictionAndSetDisabled
|
|
}
|
|
assertThat(mAndroidBeamPreference.isEnabled()).isTrue();
|
|
}
|
|
|
|
@Test
|
|
public void isBeamEnable_nfcStateNotOn_shouldReturnFalse() {
|
|
when(mNfcAdapter.getAdapterState()).thenReturn(NfcAdapter.STATE_OFF);
|
|
mAndroidBeamController.onResume();
|
|
assertThat(mAndroidBeamPreference.isEnabled()).isFalse();
|
|
|
|
when(mNfcAdapter.getAdapterState()).thenReturn(NfcAdapter.STATE_TURNING_ON);
|
|
mAndroidBeamController.onResume();
|
|
assertThat(mAndroidBeamPreference.isEnabled()).isFalse();
|
|
|
|
when(mNfcAdapter.getAdapterState()).thenReturn(NfcAdapter.STATE_TURNING_OFF);
|
|
mAndroidBeamController.onResume();
|
|
assertThat(mAndroidBeamPreference.isEnabled()).isFalse();
|
|
}
|
|
|
|
@Test
|
|
public void updateNonIndexableKeys_available_shouldNotUpdate() {
|
|
when(mNfcAdapter.isEnabled()).thenReturn(true);
|
|
final List<String> keys = new ArrayList<>();
|
|
|
|
mAndroidBeamController.updateNonIndexableKeys(keys);
|
|
|
|
assertThat(keys).isEmpty();
|
|
}
|
|
|
|
@Test
|
|
public void updateNonIndexableKeys_notAvailable_shouldUpdate() {
|
|
ReflectionHelpers.setField(mAndroidBeamController, "mNfcAdapter", null);
|
|
final List<String> keys = new ArrayList<>();
|
|
|
|
mAndroidBeamController.updateNonIndexableKeys(keys);
|
|
|
|
assertThat(keys).hasSize(1);
|
|
}
|
|
}
|