This commit *only* changes imports and optimize imports.
We don't do anything else.
This patch can't compile pass and run test case.
We will update other patches to fix these problem.
Change list.
1. import android.app.Fragment; ->
import androidx.fragment.app.Fragment;
2. import android.app.DialogFragment; ->
import androidx.fragment.app.DialogFragment;
3. import android.app.ListFragment; ->
import androidx.fragment.app.ListFragment;
4. import android.app.LoaderManager; ->
import androidx.loader.app.LoaderManager;
5. import android.content.AsyncTaskLoader; ->
import androidx.loader.content.AsyncTaskLoader;
6. import android.content.Loader; ->
import androidx.loader.content.Loader;
7. import android.app.FragmentTransaction; ->
import androidx.fragment.app.FragmentTransaction;
8. import android.app.FragmentManager; ->
import androidx.fragment.app.FragmentManager;
9. import android.app.LoaderManager.LoaderCallbacks; ->
import androidx.loader.app.LoaderManager.LoaderCallbacks;
Bug: 110259478
Test: Can't test it.
Change-Id: I0a3f98fff34a3494a839c3c42aeabcec3df2c8b3
160 lines
6.5 KiB
Java
160 lines
6.5 KiB
Java
/*
|
|
* Copyright (C) 2017 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.display;
|
|
|
|
import static android.provider.Settings.System.SCREEN_OFF_TIMEOUT;
|
|
import static com.google.common.truth.Truth.assertThat;
|
|
import static org.mockito.Mockito.anyInt;
|
|
import static org.mockito.Mockito.spy;
|
|
import static org.mockito.Mockito.times;
|
|
import static org.mockito.Mockito.verify;
|
|
import static org.mockito.Mockito.when;
|
|
|
|
import android.content.Context;
|
|
import android.os.UserHandle;
|
|
import android.os.UserManager;
|
|
import android.provider.Settings;
|
|
|
|
import com.android.settings.R;
|
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
|
import com.android.settings.testutils.shadow.ShadowDevicePolicyManager;
|
|
import com.android.settings.testutils.shadow.ShadowRestrictedLockUtils;
|
|
import com.android.settingslib.RestrictedLockUtils.EnforcedAdmin;
|
|
|
|
import org.junit.After;
|
|
import org.junit.Before;
|
|
import org.junit.Test;
|
|
import org.junit.runner.RunWith;
|
|
import org.mockito.ArgumentCaptor;
|
|
import org.mockito.Mock;
|
|
import org.mockito.MockitoAnnotations;
|
|
import org.robolectric.RuntimeEnvironment;
|
|
import org.robolectric.annotation.Config;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
|
|
@RunWith(SettingsRobolectricTestRunner.class)
|
|
@Config(shadows = ShadowDevicePolicyManager.class)
|
|
public class TimeoutPreferenceControllerTest {
|
|
|
|
private static final int TIMEOUT = 30;
|
|
private static final String KEY_SCREEN_TIMEOUT = "screen_timeout";
|
|
private static final String DEFAULT_TIMEOUT = "300000"; // 5 minutes
|
|
|
|
private Context mContext;
|
|
@Mock
|
|
private TimeoutListPreference mPreference;
|
|
@Mock
|
|
private UserManager mUserManager;
|
|
|
|
private TimeoutPreferenceController mController;
|
|
|
|
@Before
|
|
public void setUp() {
|
|
MockitoAnnotations.initMocks(this);
|
|
mContext = spy(RuntimeEnvironment.application);
|
|
when(mContext.getSystemService(Context.USER_SERVICE)).thenReturn(mUserManager);
|
|
when(mPreference.getValue()).thenReturn(DEFAULT_TIMEOUT);
|
|
mController = new TimeoutPreferenceController(mContext, KEY_SCREEN_TIMEOUT);
|
|
}
|
|
|
|
@After
|
|
public void tearDown() {
|
|
ShadowRestrictedLockUtils.reset();
|
|
}
|
|
|
|
@Test
|
|
public void testOnPreferenceChange_SetTimeout_ReturnCorrectTimeout() {
|
|
mController.onPreferenceChange(mPreference, Integer.toString(TIMEOUT));
|
|
|
|
final int mode = Settings.System.getInt(mContext.getContentResolver(),
|
|
SCREEN_OFF_TIMEOUT, 0);
|
|
assertThat(mode).isEqualTo(TIMEOUT);
|
|
}
|
|
|
|
@Test
|
|
public void testUpdateStateNoAdminTimeouts() {
|
|
when(mUserManager.getProfiles(anyInt())).thenReturn(Collections.emptyList());
|
|
mController.updateState(mPreference);
|
|
verify(mPreference).removeUnusableTimeouts(0, null);
|
|
}
|
|
|
|
@Test
|
|
public void testUpdateStateWithAdminTimeouts() {
|
|
final int profileUserId = UserHandle.myUserId();
|
|
final long timeout = 10000;
|
|
when(mUserManager.getProfiles(profileUserId)).thenReturn(Collections.emptyList());
|
|
ShadowDevicePolicyManager.getShadow().setMaximumTimeToLock(profileUserId, timeout);
|
|
|
|
mController.updateState(mPreference);
|
|
verify(mPreference).removeUnusableTimeouts(timeout, null);
|
|
}
|
|
|
|
@Test
|
|
public void testUpdateStateWithAdminTimeoutsAndRestriction() {
|
|
final int profileUserId = UserHandle.myUserId();
|
|
final long timeout = 100;
|
|
when(mUserManager.getProfiles(profileUserId)).thenReturn(Collections.emptyList());
|
|
ShadowDevicePolicyManager.getShadow().setMaximumTimeToLock(profileUserId, timeout);
|
|
|
|
int userId = UserHandle.myUserId();
|
|
List<UserManager.EnforcingUser> enforcingUsers = new ArrayList<>();
|
|
// Add two enforcing users so that RestrictedLockUtils.checkIfRestrictionEnforced returns
|
|
// non-null.
|
|
enforcingUsers.add(new UserManager.EnforcingUser(userId,
|
|
UserManager.RESTRICTION_SOURCE_DEVICE_OWNER));
|
|
enforcingUsers.add(new UserManager.EnforcingUser(userId,
|
|
UserManager.RESTRICTION_SOURCE_PROFILE_OWNER));
|
|
when(mUserManager.getUserRestrictionSources(
|
|
UserManager.DISALLOW_CONFIG_SCREEN_TIMEOUT, UserHandle.of(userId)))
|
|
.thenReturn(enforcingUsers);
|
|
|
|
mController.updateState(mPreference);
|
|
|
|
ArgumentCaptor<Long> longCaptor = ArgumentCaptor.forClass(Long.class);
|
|
ArgumentCaptor<EnforcedAdmin> adminCaptor = ArgumentCaptor.forClass(EnforcedAdmin.class);
|
|
|
|
verify(mPreference, times(2))
|
|
.removeUnusableTimeouts(longCaptor.capture(), adminCaptor.capture());
|
|
assertThat((long) longCaptor.getValue()).isEqualTo(0);
|
|
assertThat(adminCaptor.getValue()).isNotNull();
|
|
}
|
|
|
|
@Test
|
|
@Config(shadows = ShadowRestrictedLockUtils.class)
|
|
public void updateState_selectedTimeoutLargerThanAdminMax_shouldSetSummaryToUpdatedPrefValue() {
|
|
final int profileUserId = UserHandle.myUserId();
|
|
final long allowedTimeout = 480000L; // 8 minutes
|
|
when(mUserManager.getProfiles(profileUserId)).thenReturn(Collections.emptyList());
|
|
ShadowDevicePolicyManager.getShadow().setMaximumTimeToLock(profileUserId, allowedTimeout);
|
|
ShadowRestrictedLockUtils.setMaximumTimeToLockIsSet(true);
|
|
final CharSequence[] timeouts = {"15000", "30000", "60000", "120000", "300000", "600000"};
|
|
final CharSequence[] summaries = {"15s", "30s", "1m", "2m", "5m", "10m"};
|
|
// set current timeout to be 10 minutes, which is longer than the allowed 8 minutes
|
|
Settings.System.putLong(mContext.getContentResolver(), SCREEN_OFF_TIMEOUT, 600000L);
|
|
when(mPreference.getEntries()).thenReturn(summaries);
|
|
when(mPreference.getEntryValues()).thenReturn(timeouts);
|
|
when(mPreference.getValue()).thenReturn("300000");
|
|
|
|
mController.updateState(mPreference);
|
|
|
|
verify(mPreference).setSummary(mContext.getString(R.string.screen_timeout_summary, "5m"));
|
|
}
|
|
}
|