Merge "Switch auto time setting to use APIs"
This commit is contained in:
@@ -16,17 +16,22 @@
|
|||||||
|
|
||||||
package com.android.settings.datetime;
|
package com.android.settings.datetime;
|
||||||
|
|
||||||
|
import static android.app.time.Capabilities.CAPABILITY_NOT_ALLOWED;
|
||||||
|
import static android.app.time.Capabilities.CAPABILITY_NOT_APPLICABLE;
|
||||||
|
import static android.app.time.Capabilities.CAPABILITY_NOT_SUPPORTED;
|
||||||
|
import static android.app.time.Capabilities.CAPABILITY_POSSESSED;
|
||||||
|
|
||||||
|
import android.app.time.TimeCapabilities;
|
||||||
|
import android.app.time.TimeCapabilitiesAndConfig;
|
||||||
|
import android.app.time.TimeConfiguration;
|
||||||
|
import android.app.time.TimeManager;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.UserHandle;
|
|
||||||
import android.os.UserManager;
|
|
||||||
import android.provider.Settings;
|
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
|
import com.android.internal.annotations.VisibleForTesting;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settingslib.RestrictedLockUtils;
|
|
||||||
import com.android.settingslib.RestrictedLockUtilsInternal;
|
|
||||||
import com.android.settingslib.RestrictedSwitchPreference;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
public class AutoTimePreferenceController extends AbstractPreferenceController
|
public class AutoTimePreferenceController extends AbstractPreferenceController
|
||||||
@@ -34,27 +39,39 @@ public class AutoTimePreferenceController extends AbstractPreferenceController
|
|||||||
|
|
||||||
private static final String KEY_AUTO_TIME = "auto_time";
|
private static final String KEY_AUTO_TIME = "auto_time";
|
||||||
private final UpdateTimeAndDateCallback mCallback;
|
private final UpdateTimeAndDateCallback mCallback;
|
||||||
|
private final TimeManager mTimeManager;
|
||||||
|
|
||||||
public AutoTimePreferenceController(Context context, UpdateTimeAndDateCallback callback) {
|
public AutoTimePreferenceController(Context context, UpdateTimeAndDateCallback callback) {
|
||||||
super(context);
|
super(context);
|
||||||
|
mTimeManager = context.getSystemService(TimeManager.class);
|
||||||
mCallback = callback;
|
mCallback = callback;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public boolean isAvailable() {
|
||||||
|
TimeCapabilities timeCapabilities =
|
||||||
|
getTimeCapabilitiesAndConfig().getCapabilities();
|
||||||
|
int capability = timeCapabilities.getConfigureAutoDetectionEnabledCapability();
|
||||||
|
|
||||||
|
// The preference only has two states: present and not present. The preference is never
|
||||||
|
// present but disabled.
|
||||||
|
if (capability == CAPABILITY_NOT_SUPPORTED
|
||||||
|
|| capability == CAPABILITY_NOT_ALLOWED
|
||||||
|
|| capability == CAPABILITY_NOT_APPLICABLE) {
|
||||||
|
return false;
|
||||||
|
} else if (capability == CAPABILITY_POSSESSED) {
|
||||||
return true;
|
return true;
|
||||||
|
} else {
|
||||||
|
throw new IllegalStateException("Unknown capability=" + capability);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void updateState(Preference preference) {
|
public void updateState(Preference preference) {
|
||||||
if (!(preference instanceof RestrictedSwitchPreference)) {
|
if (!(preference instanceof SwitchPreference)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!((RestrictedSwitchPreference) preference).isDisabledByAdmin()) {
|
((SwitchPreference) preference).setChecked(isEnabled());
|
||||||
((RestrictedSwitchPreference) preference).setDisabledByAdmin(
|
|
||||||
getEnforcedAdminProperty());
|
|
||||||
}
|
|
||||||
((RestrictedSwitchPreference) preference).setChecked(isEnabled());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -64,21 +81,24 @@ public class AutoTimePreferenceController extends AbstractPreferenceController
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
boolean autoEnabled = (Boolean) newValue;
|
boolean autoTimeEnabled = (Boolean) newValue;
|
||||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME,
|
TimeConfiguration configuration = new TimeConfiguration.Builder()
|
||||||
autoEnabled ? 1 : 0);
|
.setAutoDetectionEnabled(autoTimeEnabled)
|
||||||
|
.build();
|
||||||
|
boolean result = mTimeManager.updateTimeConfiguration(configuration);
|
||||||
|
|
||||||
mCallback.updateTimeAndDateDisplay(mContext);
|
mCallback.updateTimeAndDateDisplay(mContext);
|
||||||
return true;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Returns whether the preference should be "checked", i.e. set to the "on" position. */
|
||||||
|
@VisibleForTesting
|
||||||
public boolean isEnabled() {
|
public boolean isEnabled() {
|
||||||
return Settings.Global.getInt(mContext.getContentResolver(),
|
TimeConfiguration config = getTimeCapabilitiesAndConfig().getConfiguration();
|
||||||
Settings.Global.AUTO_TIME, 0) > 0;
|
return config.isAutoDetectionEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
private RestrictedLockUtils.EnforcedAdmin getEnforcedAdminProperty() {
|
private TimeCapabilitiesAndConfig getTimeCapabilitiesAndConfig() {
|
||||||
return RestrictedLockUtilsInternal.checkIfRestrictionEnforced(
|
return mTimeManager.getTimeCapabilitiesAndConfig();
|
||||||
mContext, UserManager.DISALLOW_CONFIG_DATE_TIME,
|
|
||||||
UserHandle.myUserId());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,8 +16,12 @@
|
|||||||
|
|
||||||
package com.android.settings.datetime;
|
package com.android.settings.datetime;
|
||||||
|
|
||||||
|
import static android.app.time.Capabilities.CAPABILITY_POSSESSED;
|
||||||
|
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.app.DatePickerDialog;
|
import android.app.DatePickerDialog;
|
||||||
|
import android.app.time.TimeCapabilities;
|
||||||
|
import android.app.time.TimeManager;
|
||||||
import android.app.timedetector.ManualTimeSuggestion;
|
import android.app.timedetector.ManualTimeSuggestion;
|
||||||
import android.app.timedetector.TimeDetector;
|
import android.app.timedetector.TimeDetector;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -46,13 +50,12 @@ public class DatePreferenceController extends AbstractPreferenceController
|
|||||||
private static final String KEY_DATE = "date";
|
private static final String KEY_DATE = "date";
|
||||||
|
|
||||||
private final DatePreferenceHost mHost;
|
private final DatePreferenceHost mHost;
|
||||||
private final AutoTimePreferenceController mAutoTimePreferenceController;
|
private final TimeManager mTimeManager;
|
||||||
|
|
||||||
public DatePreferenceController(Context context, DatePreferenceHost host,
|
public DatePreferenceController(Context context, DatePreferenceHost host) {
|
||||||
AutoTimePreferenceController autoTimePreferenceController) {
|
|
||||||
super(context);
|
super(context);
|
||||||
mHost = host;
|
mHost = host;
|
||||||
mAutoTimePreferenceController = autoTimePreferenceController;
|
mTimeManager = context.getSystemService(TimeManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -68,7 +71,8 @@ public class DatePreferenceController extends AbstractPreferenceController
|
|||||||
final Calendar now = Calendar.getInstance();
|
final Calendar now = Calendar.getInstance();
|
||||||
preference.setSummary(DateFormat.getLongDateFormat(mContext).format(now.getTime()));
|
preference.setSummary(DateFormat.getLongDateFormat(mContext).format(now.getTime()));
|
||||||
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||||
preference.setEnabled(!mAutoTimePreferenceController.isEnabled());
|
boolean enableManualDateSelection = isEnabled();
|
||||||
|
preference.setEnabled(enableManualDateSelection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -126,4 +130,16 @@ public class DatePreferenceController extends AbstractPreferenceController
|
|||||||
timeDetector.suggestManualTime(manualTimeSuggestion);
|
timeDetector.suggestManualTime(manualTimeSuggestion);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether selecting the preference should prompt for the user to enter the date
|
||||||
|
* manually. Exposed as public so that the time controller can easily share the same logic as
|
||||||
|
* the rules are identical for time.
|
||||||
|
*/
|
||||||
|
public boolean isEnabled() {
|
||||||
|
TimeCapabilities timeZoneCapabilities =
|
||||||
|
mTimeManager.getTimeCapabilitiesAndConfig().getCapabilities();
|
||||||
|
int suggestManualTimeCapability = timeZoneCapabilities.getSuggestManualTimeCapability();
|
||||||
|
return suggestManualTimeCapability == CAPABILITY_POSSESSED;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -69,27 +69,28 @@ public class DateTimeSettings extends DashboardFragment implements
|
|||||||
final Intent intent = activity.getIntent();
|
final Intent intent = activity.getIntent();
|
||||||
final boolean isFromSUW = intent.getBooleanExtra(EXTRA_IS_FROM_SUW, false);
|
final boolean isFromSUW = intent.getBooleanExtra(EXTRA_IS_FROM_SUW, false);
|
||||||
|
|
||||||
final AutoTimeZonePreferenceController autoTimeZonePreferenceController =
|
|
||||||
new AutoTimeZonePreferenceController(
|
|
||||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW);
|
|
||||||
final AutoTimePreferenceController autoTimePreferenceController =
|
final AutoTimePreferenceController autoTimePreferenceController =
|
||||||
new AutoTimePreferenceController(
|
new AutoTimePreferenceController(
|
||||||
activity, this /* UpdateTimeAndDateCallback */);
|
activity, this /* UpdateTimeAndDateCallback */);
|
||||||
|
controllers.add(autoTimePreferenceController);
|
||||||
|
DatePreferenceController datePreferenceController = new DatePreferenceController(
|
||||||
|
activity, this /* UpdateTimeAndDateCallback */);
|
||||||
|
controllers.add(datePreferenceController);
|
||||||
|
controllers.add(new TimePreferenceController(
|
||||||
|
activity, this /* UpdateTimeAndDateCallback */, datePreferenceController));
|
||||||
|
|
||||||
|
final AutoTimeZonePreferenceController autoTimeZonePreferenceController =
|
||||||
|
new AutoTimeZonePreferenceController(
|
||||||
|
activity, this /* UpdateTimeAndDateCallback */, isFromSUW);
|
||||||
|
controllers.add(autoTimeZonePreferenceController);
|
||||||
|
controllers.add(new TimeZonePreferenceController(activity));
|
||||||
|
|
||||||
final AutoTimeFormatPreferenceController autoTimeFormatPreferenceController =
|
final AutoTimeFormatPreferenceController autoTimeFormatPreferenceController =
|
||||||
new AutoTimeFormatPreferenceController(
|
new AutoTimeFormatPreferenceController(
|
||||||
activity, this /* UpdateTimeAndDateCallback */);
|
activity, this /* UpdateTimeAndDateCallback */);
|
||||||
|
|
||||||
controllers.add(autoTimeZonePreferenceController);
|
|
||||||
controllers.add(autoTimePreferenceController);
|
|
||||||
controllers.add(autoTimeFormatPreferenceController);
|
controllers.add(autoTimeFormatPreferenceController);
|
||||||
|
|
||||||
controllers.add(new TimeFormatPreferenceController(
|
controllers.add(new TimeFormatPreferenceController(
|
||||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW));
|
activity, this /* UpdateTimeAndDateCallback */, isFromSUW));
|
||||||
controllers.add(new TimeZonePreferenceController(activity));
|
|
||||||
controllers.add(new TimePreferenceController(
|
|
||||||
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
|
||||||
controllers.add(new DatePreferenceController(
|
|
||||||
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
|
||||||
return controllers;
|
return controllers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -44,16 +44,16 @@ public class TimePreferenceController extends AbstractPreferenceController
|
|||||||
|
|
||||||
private static final String KEY_TIME = "time";
|
private static final String KEY_TIME = "time";
|
||||||
|
|
||||||
private final AutoTimePreferenceController mAutoTimePreferenceController;
|
private final DatePreferenceController mDatePreferenceController;
|
||||||
private final TimePreferenceHost mHost;
|
private final TimePreferenceHost mHost;
|
||||||
|
|
||||||
|
|
||||||
public TimePreferenceController(Context context,
|
public TimePreferenceController(Context context,
|
||||||
TimePreferenceHost callback,
|
TimePreferenceHost callback,
|
||||||
AutoTimePreferenceController autoTimePreferenceController) {
|
DatePreferenceController datePreferenceController) {
|
||||||
super(context);
|
super(context);
|
||||||
mHost = callback;
|
mHost = callback;
|
||||||
mAutoTimePreferenceController = autoTimePreferenceController;
|
mDatePreferenceController = datePreferenceController;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -69,7 +69,8 @@ public class TimePreferenceController extends AbstractPreferenceController
|
|||||||
final Calendar now = Calendar.getInstance();
|
final Calendar now = Calendar.getInstance();
|
||||||
preference.setSummary(DateFormat.getTimeFormat(mContext).format(now.getTime()));
|
preference.setSummary(DateFormat.getTimeFormat(mContext).format(now.getTime()));
|
||||||
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||||
preference.setEnabled(!mAutoTimePreferenceController.isEnabled());
|
boolean enableManualTimeSelection = mDatePreferenceController.isEnabled();
|
||||||
|
preference.setEnabled(enableManualTimeSelection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -18,17 +18,25 @@ package com.android.settings.datetime;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.time.Capabilities;
|
||||||
|
import android.app.time.TimeCapabilities;
|
||||||
|
import android.app.time.TimeCapabilitiesAndConfig;
|
||||||
|
import android.app.time.TimeConfiguration;
|
||||||
|
import android.app.time.TimeManager;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.provider.Settings;
|
import android.os.UserHandle;
|
||||||
|
|
||||||
import com.android.settingslib.RestrictedSwitchPreference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
|
import org.mockito.Mockito;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RobolectricTestRunner;
|
import org.robolectric.RobolectricTestRunner;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
@@ -38,43 +46,123 @@ public class AutoTimePreferenceControllerTest {
|
|||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private UpdateTimeAndDateCallback mCallback;
|
private UpdateTimeAndDateCallback mCallback;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private RestrictedSwitchPreference mPreference;
|
|
||||||
private AutoTimePreferenceController mController;
|
private AutoTimePreferenceController mController;
|
||||||
|
private Preference mPreference;
|
||||||
|
@Mock
|
||||||
|
private TimeManager mTimeManager;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
mPreference = new RestrictedSwitchPreference(mContext);
|
mPreference = new Preference(mContext);
|
||||||
|
when(mContext.getSystemService(TimeManager.class)).thenReturn(mTimeManager);
|
||||||
|
|
||||||
mController = new AutoTimePreferenceController(mContext, mCallback);
|
mController = new AutoTimePreferenceController(mContext, mCallback);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsEnabled_shouldReadFromSettingsProvider() {
|
public void autoTimeNotSupported_notAvailable() {
|
||||||
// Disabled
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME, 0);
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
assertThat(mController.isAvailable()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void autoTimeNotSupported_notEnable() {
|
||||||
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testIsEnabled_shouldReadFromTimeManagerConfig() {
|
||||||
|
{
|
||||||
|
// Disabled
|
||||||
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
// Enabled
|
// Enabled
|
||||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME, 1);
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isTrue();
|
assertThat(mController.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updatePreferenceChange_prefIsChecked_shouldUpdatePreferenceAndNotifyCallback() {
|
public void updatePreferenceChange_prefIsChecked_shouldUpdatePreferenceAndNotifyCallback() {
|
||||||
mController.onPreferenceChange(mPreference, true);
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
when(mTimeManager.updateTimeConfiguration(Mockito.any())).thenReturn(true);
|
||||||
|
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, true)).isTrue();
|
||||||
|
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
||||||
|
|
||||||
|
// Check the service was asked to change the configuration correctly.
|
||||||
|
TimeConfiguration timeConfiguration = new TimeConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(true)
|
||||||
|
.build();
|
||||||
|
verify(mTimeManager).updateTimeConfiguration(timeConfiguration);
|
||||||
|
|
||||||
|
// Update the mTimeManager mock so that it now returns the expected updated config.
|
||||||
|
TimeCapabilitiesAndConfig capabilitiesAndConfigAfterUpdate =
|
||||||
|
createCapabilitiesAndConfig(/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig())
|
||||||
|
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isTrue();
|
assertThat(mController.isEnabled()).isTrue();
|
||||||
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updatePreferenceChange_prefIsUnchecked_shouldUpdatePreferenceAndNotifyCallback() {
|
public void updatePreferenceChange_prefIsUnchecked_shouldUpdatePreferenceAndNotifyCallback() {
|
||||||
mController.onPreferenceChange(mPreference, false);
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
when(mTimeManager.updateTimeConfiguration(Mockito.any())).thenReturn(true);
|
||||||
|
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, false)).isTrue();
|
||||||
|
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
||||||
|
|
||||||
|
// Check the service was asked to change the configuration correctly.
|
||||||
|
TimeConfiguration timeConfiguration = new TimeConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(false)
|
||||||
|
.build();
|
||||||
|
verify(mTimeManager).updateTimeConfiguration(timeConfiguration);
|
||||||
|
|
||||||
|
// Update the mTimeManager mock so that it now returns the expected updated config.
|
||||||
|
TimeCapabilitiesAndConfig capabilitiesAndConfigAfterUpdate =
|
||||||
|
createCapabilitiesAndConfig(/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig())
|
||||||
|
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
}
|
||||||
|
|
||||||
|
private static TimeCapabilitiesAndConfig createCapabilitiesAndConfig(
|
||||||
|
boolean autoSupported, boolean autoEnabled) {
|
||||||
|
int configureAutoDetectionEnabledCapability =
|
||||||
|
autoSupported ? Capabilities.CAPABILITY_POSSESSED
|
||||||
|
: Capabilities.CAPABILITY_NOT_SUPPORTED;
|
||||||
|
TimeCapabilities capabilities = new TimeCapabilities.Builder(UserHandle.SYSTEM)
|
||||||
|
.setConfigureAutoDetectionEnabledCapability(configureAutoDetectionEnabledCapability)
|
||||||
|
.setSuggestManualTimeCapability(Capabilities.CAPABILITY_POSSESSED)
|
||||||
|
.build();
|
||||||
|
TimeConfiguration config = new TimeConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(autoEnabled)
|
||||||
|
.build();
|
||||||
|
return new TimeCapabilitiesAndConfig(capabilities, config);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -46,9 +46,7 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private UpdateTimeAndDateCallback mCallback;
|
private UpdateTimeAndDateCallback mCallback;
|
||||||
@Mock
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private AutoTimeZonePreferenceController mController;
|
|
||||||
private Preference mPreference;
|
private Preference mPreference;
|
||||||
@Mock
|
@Mock
|
||||||
private TimeManager mTimeManager;
|
private TimeManager mTimeManager;
|
||||||
@@ -69,10 +67,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */true, /* autoEnabled= */false);
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, true /* isFromSUW */);
|
mContext, null /* callback */, true /* isFromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isFalse();
|
assertThat(controller.isAvailable()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -81,10 +79,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */true, /* autoEnabled= */false);
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* isFromSUW */);
|
mContext, null /* callback */, false /* isFromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isTrue();
|
assertThat(controller.isAvailable()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -93,10 +91,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */false, /* autoEnabled= */false);
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* fromSUW */);
|
mContext, null /* callback */, false /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isFalse();
|
assertThat(controller.isAvailable()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -105,10 +103,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */false, /* autoEnabled= */false);
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, true /* fromSUW */);
|
mContext, null /* callback */, true /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(controller.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -117,10 +115,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */false, /* autoEnabled= */true);
|
/* autoSupported= */false, /* autoEnabled= */true);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, true /* fromSUW */);
|
mContext, null /* callback */, true /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isTrue();
|
assertThat(controller.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -129,15 +127,15 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */false, /* autoEnabled= */false);
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* fromSUW */);
|
mContext, null /* callback */, false /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(controller.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsEnabled_shouldReadFromTimeManagerConfig() {
|
public void testIsEnabled_shouldReadFromTimeManagerConfig() {
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* fromSUW */);
|
mContext, null /* callback */, false /* fromSUW */);
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -146,7 +144,7 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */true, /* autoEnabled= */false);
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(controller.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -155,7 +153,7 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
/* autoSupported= */true, /* autoEnabled= */true);
|
/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isTrue();
|
assertThat(controller.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -166,10 +164,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
when(mTimeManager.updateTimeZoneConfiguration(Mockito.any())).thenReturn(true);
|
when(mTimeManager.updateTimeZoneConfiguration(Mockito.any())).thenReturn(true);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, mCallback, false /* fromSUW */);
|
mContext, mCallback, false /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.onPreferenceChange(mPreference, true)).isTrue();
|
assertThat(controller.onPreferenceChange(mPreference, true)).isTrue();
|
||||||
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
||||||
|
|
||||||
// Check the service was asked to change the configuration correctly.
|
// Check the service was asked to change the configuration correctly.
|
||||||
@@ -184,7 +182,7 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig())
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig())
|
||||||
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isTrue();
|
assertThat(controller.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -194,10 +192,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
when(mTimeManager.updateTimeZoneConfiguration(Mockito.any())).thenReturn(true);
|
when(mTimeManager.updateTimeZoneConfiguration(Mockito.any())).thenReturn(true);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
AutoTimeZonePreferenceController controller = new AutoTimeZonePreferenceController(
|
||||||
mContext, mCallback, false /* fromSUW */);
|
mContext, mCallback, false /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.onPreferenceChange(mPreference, false)).isTrue();
|
assertThat(controller.onPreferenceChange(mPreference, false)).isTrue();
|
||||||
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
||||||
|
|
||||||
// Check the service was asked to change the configuration correctly.
|
// Check the service was asked to change the configuration correctly.
|
||||||
@@ -212,7 +210,7 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
when(mTimeManager.getTimeZoneCapabilitiesAndConfig())
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig())
|
||||||
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(controller.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static TimeZoneCapabilitiesAndConfig createCapabilitiesAndConfig(
|
private static TimeZoneCapabilitiesAndConfig createCapabilitiesAndConfig(
|
||||||
|
@@ -21,8 +21,14 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
import static org.mockito.Mockito.verify;
|
import static org.mockito.Mockito.verify;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.time.Capabilities;
|
||||||
|
import android.app.time.TimeCapabilities;
|
||||||
|
import android.app.time.TimeCapabilitiesAndConfig;
|
||||||
|
import android.app.time.TimeConfiguration;
|
||||||
|
import android.app.time.TimeManager;
|
||||||
import android.app.timedetector.TimeDetector;
|
import android.app.timedetector.TimeDetector;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
|
||||||
import com.android.settingslib.RestrictedPreference;
|
import com.android.settingslib.RestrictedPreference;
|
||||||
|
|
||||||
@@ -42,9 +48,9 @@ public class DatePreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private TimeDetector mTimeDetector;
|
private TimeDetector mTimeDetector;
|
||||||
@Mock
|
@Mock
|
||||||
private DatePreferenceController.DatePreferenceHost mHost;
|
private TimeManager mTimeManager;
|
||||||
@Mock
|
@Mock
|
||||||
private AutoTimePreferenceController mAutoTimePreferenceController;
|
private DatePreferenceController.DatePreferenceHost mHost;
|
||||||
|
|
||||||
private RestrictedPreference mPreference;
|
private RestrictedPreference mPreference;
|
||||||
private DatePreferenceController mController;
|
private DatePreferenceController mController;
|
||||||
@@ -53,8 +59,9 @@ public class DatePreferenceControllerTest {
|
|||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
when(mContext.getSystemService(TimeDetector.class)).thenReturn(mTimeDetector);
|
when(mContext.getSystemService(TimeDetector.class)).thenReturn(mTimeDetector);
|
||||||
|
when(mContext.getSystemService(TimeManager.class)).thenReturn(mTimeManager);
|
||||||
mPreference = new RestrictedPreference(RuntimeEnvironment.application);
|
mPreference = new RestrictedPreference(RuntimeEnvironment.application);
|
||||||
mController = new DatePreferenceController(mContext, mHost, mAutoTimePreferenceController);
|
mController = new DatePreferenceController(mContext, mHost);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -73,7 +80,9 @@ public class DatePreferenceControllerTest {
|
|||||||
// Make sure not disabled by admin.
|
// Make sure not disabled by admin.
|
||||||
mPreference.setDisabledByAdmin(null);
|
mPreference.setDisabledByAdmin(null);
|
||||||
|
|
||||||
when(mAutoTimePreferenceController.isEnabled()).thenReturn(true);
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* suggestManualAllowed= */false);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mPreference.isEnabled()).isFalse();
|
assertThat(mPreference.isEnabled()).isFalse();
|
||||||
@@ -84,7 +93,9 @@ public class DatePreferenceControllerTest {
|
|||||||
// Make sure not disabled by admin.
|
// Make sure not disabled by admin.
|
||||||
mPreference.setDisabledByAdmin(null);
|
mPreference.setDisabledByAdmin(null);
|
||||||
|
|
||||||
when(mAutoTimePreferenceController.isEnabled()).thenReturn(false);
|
TimeCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* suggestManualAllowed= */true);
|
||||||
|
when(mTimeManager.getTimeCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mPreference.isEnabled()).isTrue();
|
assertThat(mPreference.isEnabled()).isTrue();
|
||||||
@@ -102,4 +113,18 @@ public class DatePreferenceControllerTest {
|
|||||||
// Should show date picker
|
// Should show date picker
|
||||||
verify(mHost).showDatePicker();
|
verify(mHost).showDatePicker();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static TimeCapabilitiesAndConfig createCapabilitiesAndConfig(
|
||||||
|
boolean suggestManualAllowed) {
|
||||||
|
int suggestManualCapability = suggestManualAllowed ? Capabilities.CAPABILITY_POSSESSED
|
||||||
|
: Capabilities.CAPABILITY_NOT_SUPPORTED;
|
||||||
|
TimeCapabilities capabilities = new TimeCapabilities.Builder(UserHandle.SYSTEM)
|
||||||
|
.setConfigureAutoDetectionEnabledCapability(Capabilities.CAPABILITY_POSSESSED)
|
||||||
|
.setSuggestManualTimeCapability(suggestManualCapability)
|
||||||
|
.build();
|
||||||
|
TimeConfiguration config = new TimeConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(!suggestManualAllowed)
|
||||||
|
.build();
|
||||||
|
return new TimeCapabilitiesAndConfig(capabilities, config);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -41,7 +41,7 @@ public class TimePreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private TimePreferenceController.TimePreferenceHost mHost;
|
private TimePreferenceController.TimePreferenceHost mHost;
|
||||||
@Mock
|
@Mock
|
||||||
private AutoTimePreferenceController mAutoTimePreferenceController;
|
private DatePreferenceController mDatePreferenceController;
|
||||||
|
|
||||||
private TimePreferenceController mController;
|
private TimePreferenceController mController;
|
||||||
private RestrictedPreference mPreference;
|
private RestrictedPreference mPreference;
|
||||||
@@ -50,7 +50,7 @@ public class TimePreferenceControllerTest {
|
|||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mPreference = new RestrictedPreference(RuntimeEnvironment.application);
|
mPreference = new RestrictedPreference(RuntimeEnvironment.application);
|
||||||
mController = new TimePreferenceController(mContext, mHost, mAutoTimePreferenceController);
|
mController = new TimePreferenceController(mContext, mHost, mDatePreferenceController);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -59,22 +59,22 @@ public class TimePreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_autoTimeEnabled_shouldDisablePref() {
|
public void updateState_dateEntryDisabled_shouldDisablePref() {
|
||||||
// Make sure not disabled by admin.
|
// Make sure not disabled by admin.
|
||||||
mPreference.setDisabledByAdmin(null);
|
mPreference.setDisabledByAdmin(null);
|
||||||
|
|
||||||
when(mAutoTimePreferenceController.isEnabled()).thenReturn(true);
|
when(mDatePreferenceController.isEnabled()).thenReturn(false);
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mPreference.isEnabled()).isFalse();
|
assertThat(mPreference.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_autoTimeDisabled_shouldEnablePref() {
|
public void updateState_dateEntryEnabled_shouldEnablePref() {
|
||||||
// Make sure not disabled by admin.
|
// Make sure not disabled by admin.
|
||||||
mPreference.setDisabledByAdmin(null);
|
mPreference.setDisabledByAdmin(null);
|
||||||
|
|
||||||
when(mAutoTimePreferenceController.isEnabled()).thenReturn(false);
|
when(mDatePreferenceController.isEnabled()).thenReturn(true);
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mPreference.isEnabled()).isTrue();
|
assertThat(mPreference.isEnabled()).isTrue();
|
||||||
|
Reference in New Issue
Block a user