Merge "Fix logic used for auto time zone settings"
This commit is contained in:
@@ -16,14 +16,22 @@
|
|||||||
|
|
||||||
package com.android.settings.datetime;
|
package com.android.settings.datetime;
|
||||||
|
|
||||||
import android.content.Context;
|
import static android.app.time.Capabilities.CAPABILITY_NOT_ALLOWED;
|
||||||
import android.provider.Settings;
|
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.TimeManager;
|
||||||
|
import android.app.time.TimeZoneCapabilities;
|
||||||
|
import android.app.time.TimeZoneCapabilitiesAndConfig;
|
||||||
|
import android.app.time.TimeZoneConfiguration;
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import androidx.annotation.VisibleForTesting;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
import androidx.preference.SwitchPreference;
|
import androidx.preference.SwitchPreference;
|
||||||
|
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settingslib.Utils;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
public class AutoTimeZonePreferenceController extends AbstractPreferenceController
|
public class AutoTimeZonePreferenceController extends AbstractPreferenceController
|
||||||
@@ -33,17 +41,37 @@ public class AutoTimeZonePreferenceController extends AbstractPreferenceControll
|
|||||||
|
|
||||||
private final boolean mIsFromSUW;
|
private final boolean mIsFromSUW;
|
||||||
private final UpdateTimeAndDateCallback mCallback;
|
private final UpdateTimeAndDateCallback mCallback;
|
||||||
|
private final TimeManager mTimeManager;
|
||||||
|
|
||||||
public AutoTimeZonePreferenceController(Context context, UpdateTimeAndDateCallback callback,
|
public AutoTimeZonePreferenceController(Context context, UpdateTimeAndDateCallback callback,
|
||||||
boolean isFromSUW) {
|
boolean isFromSUW) {
|
||||||
super(context);
|
super(context);
|
||||||
|
mTimeManager = context.getSystemService(TimeManager.class);
|
||||||
mCallback = callback;
|
mCallback = callback;
|
||||||
mIsFromSUW = isFromSUW;
|
mIsFromSUW = isFromSUW;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public boolean isAvailable() {
|
||||||
return !(Utils.isWifiOnly(mContext) || mIsFromSUW);
|
if (mIsFromSUW) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
TimeZoneCapabilities timeZoneCapabilities =
|
||||||
|
getTimeZoneCapabilitiesAndConfig().getCapabilities();
|
||||||
|
int capability = timeZoneCapabilities.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;
|
||||||
|
} else {
|
||||||
|
throw new IllegalStateException("Unknown capability=" + capability);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -62,14 +90,22 @@ public class AutoTimeZonePreferenceController extends AbstractPreferenceControll
|
|||||||
@Override
|
@Override
|
||||||
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
public boolean onPreferenceChange(Preference preference, Object newValue) {
|
||||||
boolean autoZoneEnabled = (Boolean) newValue;
|
boolean autoZoneEnabled = (Boolean) newValue;
|
||||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME_ZONE,
|
TimeZoneConfiguration configuration = new TimeZoneConfiguration.Builder()
|
||||||
autoZoneEnabled ? 1 : 0);
|
.setAutoDetectionEnabled(autoZoneEnabled)
|
||||||
|
.build();
|
||||||
|
boolean result = mTimeManager.updateTimeZoneConfiguration(configuration);
|
||||||
|
|
||||||
mCallback.updateTimeAndDateDisplay(mContext);
|
mCallback.updateTimeAndDateDisplay(mContext);
|
||||||
return true;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isEnabled() {
|
@VisibleForTesting
|
||||||
return isAvailable() && Settings.Global.getInt(mContext.getContentResolver(),
|
boolean isEnabled() {
|
||||||
Settings.Global.AUTO_TIME_ZONE, 0) > 0;
|
TimeZoneConfiguration config = getTimeZoneCapabilitiesAndConfig().getConfiguration();
|
||||||
|
return config.isAutoDetectionEnabled();
|
||||||
|
}
|
||||||
|
|
||||||
|
private TimeZoneCapabilitiesAndConfig getTimeZoneCapabilitiesAndConfig() {
|
||||||
|
return mTimeManager.getTimeZoneCapabilitiesAndConfig();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -85,8 +85,7 @@ public class DateTimeSettings extends DashboardFragment implements
|
|||||||
|
|
||||||
controllers.add(new TimeFormatPreferenceController(
|
controllers.add(new TimeFormatPreferenceController(
|
||||||
activity, this /* UpdateTimeAndDateCallback */, isFromSUW));
|
activity, this /* UpdateTimeAndDateCallback */, isFromSUW));
|
||||||
controllers.add(new TimeZonePreferenceController(
|
controllers.add(new TimeZonePreferenceController(activity));
|
||||||
activity, autoTimeZonePreferenceController));
|
|
||||||
controllers.add(new TimePreferenceController(
|
controllers.add(new TimePreferenceController(
|
||||||
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
activity, this /* UpdateTimeAndDateCallback */, autoTimePreferenceController));
|
||||||
controllers.add(new DatePreferenceController(
|
controllers.add(new DatePreferenceController(
|
||||||
|
@@ -16,6 +16,10 @@
|
|||||||
|
|
||||||
package com.android.settings.datetime;
|
package com.android.settings.datetime;
|
||||||
|
|
||||||
|
import static android.app.time.Capabilities.CAPABILITY_POSSESSED;
|
||||||
|
|
||||||
|
import android.app.time.TimeManager;
|
||||||
|
import android.app.time.TimeZoneCapabilities;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
|
||||||
import androidx.annotation.VisibleForTesting;
|
import androidx.annotation.VisibleForTesting;
|
||||||
@@ -33,12 +37,11 @@ public class TimeZonePreferenceController extends AbstractPreferenceController
|
|||||||
|
|
||||||
private static final String KEY_TIMEZONE = "timezone";
|
private static final String KEY_TIMEZONE = "timezone";
|
||||||
|
|
||||||
private final AutoTimeZonePreferenceController mAutoTimeZonePreferenceController;
|
private final TimeManager mTimeManager;
|
||||||
|
|
||||||
public TimeZonePreferenceController(Context context,
|
public TimeZonePreferenceController(Context context) {
|
||||||
AutoTimeZonePreferenceController autoTimeZonePreferenceController) {
|
|
||||||
super(context);
|
super(context);
|
||||||
mAutoTimeZonePreferenceController = autoTimeZonePreferenceController;
|
mTimeManager = context.getSystemService(TimeManager.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -47,8 +50,9 @@ public class TimeZonePreferenceController extends AbstractPreferenceController
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
preference.setSummary(getTimeZoneOffsetAndName());
|
preference.setSummary(getTimeZoneOffsetAndName());
|
||||||
if( !((RestrictedPreference) preference).isDisabledByAdmin()) {
|
if (!((RestrictedPreference) preference).isDisabledByAdmin()) {
|
||||||
preference.setEnabled(!mAutoTimeZonePreferenceController.isEnabled());
|
boolean enableManualTimeZoneSelection = shouldEnableManualTimeZoneSelection();
|
||||||
|
preference.setEnabled(enableManualTimeZoneSelection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -68,4 +72,12 @@ public class TimeZonePreferenceController extends AbstractPreferenceController
|
|||||||
return ZoneGetter.getTimeZoneOffsetAndName(mContext,
|
return ZoneGetter.getTimeZoneOffsetAndName(mContext,
|
||||||
now.getTimeZone(), now.getTime());
|
now.getTimeZone(), now.getTime());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean shouldEnableManualTimeZoneSelection() {
|
||||||
|
TimeZoneCapabilities timeZoneCapabilities =
|
||||||
|
mTimeManager.getTimeZoneCapabilitiesAndConfig().getCapabilities();
|
||||||
|
int suggestManualTimeZoneCapability =
|
||||||
|
timeZoneCapabilities.getSuggestManualTimeZoneCapability();
|
||||||
|
return suggestManualTimeZoneCapability == CAPABILITY_POSSESSED;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -22,9 +22,13 @@ 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 static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.time.Capabilities;
|
||||||
|
import android.app.time.TimeManager;
|
||||||
|
import android.app.time.TimeZoneCapabilities;
|
||||||
|
import android.app.time.TimeZoneCapabilitiesAndConfig;
|
||||||
|
import android.app.time.TimeZoneConfiguration;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.provider.Settings;
|
import android.os.UserHandle;
|
||||||
import android.telephony.TelephonyManager;
|
|
||||||
|
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
|
||||||
@@ -32,6 +36,7 @@ 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;
|
||||||
@@ -46,7 +51,7 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
private AutoTimeZonePreferenceController mController;
|
private AutoTimeZonePreferenceController mController;
|
||||||
private Preference mPreference;
|
private Preference mPreference;
|
||||||
@Mock
|
@Mock
|
||||||
private TelephonyManager mTelephonyManager;
|
private TimeManager mTimeManager;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
@@ -55,12 +60,15 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
|
|
||||||
mPreference = new Preference(mContext);
|
mPreference = new Preference(mContext);
|
||||||
|
|
||||||
when(mContext.getSystemService(TelephonyManager.class)).thenReturn(mTelephonyManager);
|
when(mContext.getSystemService(TimeManager.class)).thenReturn(mTimeManager);
|
||||||
when(mTelephonyManager.isDataCapable()).thenReturn(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isFromSUW_notAvailable() {
|
public void isFromSUW_notAvailable() {
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
mController = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, true /* isFromSUW */);
|
mContext, null /* callback */, true /* isFromSUW */);
|
||||||
|
|
||||||
@@ -69,6 +77,10 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void notFromSUW_isAvailable() {
|
public void notFromSUW_isAvailable() {
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
mController = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* isFromSUW */);
|
mContext, null /* callback */, false /* isFromSUW */);
|
||||||
|
|
||||||
@@ -76,8 +88,11 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isWifiOnly_notAvailable() {
|
public void autoTimeZoneNotSupported_notAvailable() {
|
||||||
when(mTelephonyManager.isDataCapable()).thenReturn(false);
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
mController = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* fromSUW */);
|
mContext, null /* callback */, false /* fromSUW */);
|
||||||
|
|
||||||
@@ -86,54 +101,134 @@ public class AutoTimeZonePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isFromSUW_notEnable() {
|
public void isFromSUW_notEnable() {
|
||||||
mController =
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
new AutoTimeZonePreferenceController(mContext, null /* callback */, true /* fromSUW */);
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
mController = new AutoTimeZonePreferenceController(
|
||||||
|
mContext, null /* callback */, true /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isWifiOnly_notEnable() {
|
public void isFromSUW_isEnable() {
|
||||||
when(mTelephonyManager.isDataCapable()).thenReturn(false);
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */false, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
mController = new AutoTimeZonePreferenceController(
|
||||||
mContext, null /* callback */, false /* fromSUW */);
|
mContext, null /* callback */, true /* fromSUW */);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void testIsEnabled_shouldReadFromSettingsProvider() {
|
|
||||||
mController = new AutoTimeZonePreferenceController(
|
|
||||||
mContext, null /* callback */, false /* fromSUW */);
|
|
||||||
|
|
||||||
// Disabled
|
|
||||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME_ZONE, 0);
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
|
||||||
|
|
||||||
// Enabled
|
|
||||||
Settings.Global.putInt(mContext.getContentResolver(), Settings.Global.AUTO_TIME_ZONE, 1);
|
|
||||||
assertThat(mController.isEnabled()).isTrue();
|
assertThat(mController.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void autoTimeZoneNotSupported_notEnable() {
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */false, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
mController = new AutoTimeZonePreferenceController(
|
||||||
|
mContext, null /* callback */, false /* fromSUW */);
|
||||||
|
|
||||||
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testIsEnabled_shouldReadFromTimeManagerConfig() {
|
||||||
|
mController = new AutoTimeZonePreferenceController(
|
||||||
|
mContext, null /* callback */, false /* fromSUW */);
|
||||||
|
|
||||||
|
{
|
||||||
|
// Disabled
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
// Enabled
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
|
/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
|
assertThat(mController.isEnabled()).isTrue();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updatePreferenceChange_prefIsChecked_shouldUpdatePreferenceAndNotifyCallback() {
|
public void updatePreferenceChange_prefIsChecked_shouldUpdatePreferenceAndNotifyCallback() {
|
||||||
mController =
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
new AutoTimeZonePreferenceController(mContext, mCallback, false /* fromSUW */);
|
/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
when(mTimeManager.updateTimeZoneConfiguration(Mockito.any())).thenReturn(true);
|
||||||
|
|
||||||
mController.onPreferenceChange(mPreference, true);
|
mController = new AutoTimeZonePreferenceController(
|
||||||
|
mContext, mCallback, false /* fromSUW */);
|
||||||
|
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, true)).isTrue();
|
||||||
|
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
||||||
|
|
||||||
|
// Check the service was asked to change the configuration correctly.
|
||||||
|
TimeZoneConfiguration timeZoneConfiguration = new TimeZoneConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(true)
|
||||||
|
.build();
|
||||||
|
verify(mTimeManager).updateTimeZoneConfiguration(timeZoneConfiguration);
|
||||||
|
|
||||||
|
// Update the mTimeManager mock so that it now returns the expected updated config.
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfigAfterUpdate =
|
||||||
|
createCapabilitiesAndConfig(/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig())
|
||||||
|
.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 =
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
new AutoTimeZonePreferenceController(mContext, mCallback, false /* fromSUW */);
|
/* autoSupported= */true, /* autoEnabled= */true);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
when(mTimeManager.updateTimeZoneConfiguration(Mockito.any())).thenReturn(true);
|
||||||
|
|
||||||
mController.onPreferenceChange(mPreference, false);
|
mController = new AutoTimeZonePreferenceController(
|
||||||
|
mContext, mCallback, false /* fromSUW */);
|
||||||
|
|
||||||
|
assertThat(mController.onPreferenceChange(mPreference, false)).isTrue();
|
||||||
|
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
||||||
|
|
||||||
|
// Check the service was asked to change the configuration correctly.
|
||||||
|
TimeZoneConfiguration timeZoneConfiguration = new TimeZoneConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(false)
|
||||||
|
.build();
|
||||||
|
verify(mTimeManager).updateTimeZoneConfiguration(timeZoneConfiguration);
|
||||||
|
|
||||||
|
// Update the mTimeManager mock so that it now returns the expected updated config.
|
||||||
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfigAfterUpdate =
|
||||||
|
createCapabilitiesAndConfig(/* autoSupported= */true, /* autoEnabled= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig())
|
||||||
|
.thenReturn(capabilitiesAndConfigAfterUpdate);
|
||||||
|
|
||||||
assertThat(mController.isEnabled()).isFalse();
|
assertThat(mController.isEnabled()).isFalse();
|
||||||
verify(mCallback).updateTimeAndDateDisplay(mContext);
|
}
|
||||||
|
|
||||||
|
private static TimeZoneCapabilitiesAndConfig createCapabilitiesAndConfig(
|
||||||
|
boolean autoSupported, boolean autoEnabled) {
|
||||||
|
int configureAutoDetectionEnabledCapability =
|
||||||
|
autoSupported ? Capabilities.CAPABILITY_POSSESSED
|
||||||
|
: Capabilities.CAPABILITY_NOT_SUPPORTED;
|
||||||
|
TimeZoneCapabilities capabilities = new TimeZoneCapabilities.Builder(UserHandle.SYSTEM)
|
||||||
|
.setConfigureAutoDetectionEnabledCapability(configureAutoDetectionEnabledCapability)
|
||||||
|
.setConfigureGeoDetectionEnabledCapability(Capabilities.CAPABILITY_NOT_SUPPORTED)
|
||||||
|
.setSuggestManualTimeZoneCapability(Capabilities.CAPABILITY_POSSESSED)
|
||||||
|
.build();
|
||||||
|
TimeZoneConfiguration config = new TimeZoneConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(autoEnabled)
|
||||||
|
.setGeoDetectionEnabled(false)
|
||||||
|
.build();
|
||||||
|
return new TimeZoneCapabilitiesAndConfig(capabilities, config);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -22,7 +22,13 @@ import static org.mockito.Mockito.doReturn;
|
|||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
import android.app.time.Capabilities;
|
||||||
|
import android.app.time.TimeManager;
|
||||||
|
import android.app.time.TimeZoneCapabilities;
|
||||||
|
import android.app.time.TimeZoneCapabilitiesAndConfig;
|
||||||
|
import android.app.time.TimeZoneConfiguration;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.os.UserHandle;
|
||||||
|
|
||||||
import com.android.settingslib.RestrictedPreference;
|
import com.android.settingslib.RestrictedPreference;
|
||||||
|
|
||||||
@@ -38,8 +44,7 @@ import org.robolectric.RuntimeEnvironment;
|
|||||||
public class TimeZonePreferenceControllerTest {
|
public class TimeZonePreferenceControllerTest {
|
||||||
|
|
||||||
@Mock
|
@Mock
|
||||||
private AutoTimeZonePreferenceController mAutoTimeZonePreferenceController;
|
private TimeManager mTimeManager;
|
||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
private TimeZonePreferenceController mController;
|
private TimeZonePreferenceController mController;
|
||||||
private RestrictedPreference mPreference;
|
private RestrictedPreference mPreference;
|
||||||
@@ -47,10 +52,14 @@ public class TimeZonePreferenceControllerTest {
|
|||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
|
||||||
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
|
doReturn(mTimeManager).when(mContext).getSystemService(TimeManager.class);
|
||||||
|
|
||||||
mPreference = new RestrictedPreference(mContext);
|
mPreference = new RestrictedPreference(mContext);
|
||||||
mController = spy(new TimeZonePreferenceController(mContext,
|
|
||||||
mAutoTimeZonePreferenceController));
|
mController = spy(new TimeZonePreferenceController(mContext));
|
||||||
|
doReturn("test timezone").when(mController).getTimeZoneOffsetAndName();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -59,26 +68,46 @@ public class TimeZonePreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_autoTimeZoneEnabled_shouldDisablePref() {
|
public void updateState_suggestManualNotAllowed_shouldDisablePref() {
|
||||||
// Make sure not disabled by admin.
|
// Make sure not disabled by admin.
|
||||||
mPreference.setDisabledByAdmin(null);
|
mPreference.setDisabledByAdmin(null);
|
||||||
|
|
||||||
doReturn("test timezone").when(mController).getTimeZoneOffsetAndName();
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
when(mAutoTimeZonePreferenceController.isEnabled()).thenReturn(true);
|
/* suggestManualAllowed= */false);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mPreference.isEnabled()).isFalse();
|
assertThat(mPreference.isEnabled()).isFalse();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_autoTimeZoneDisabled_shouldEnablePref() {
|
public void updateState_suggestManualAllowed_shouldEnablePref() {
|
||||||
// Make sure not disabled by admin.
|
// Make sure not disabled by admin.
|
||||||
mPreference.setDisabledByAdmin(null);
|
mPreference.setDisabledByAdmin(null);
|
||||||
|
|
||||||
doReturn("test timezone").when(mController).getTimeZoneOffsetAndName();
|
TimeZoneCapabilitiesAndConfig capabilitiesAndConfig = createCapabilitiesAndConfig(
|
||||||
when(mAutoTimeZonePreferenceController.isEnabled()).thenReturn(false);
|
/* suggestManualAllowed= */true);
|
||||||
|
when(mTimeManager.getTimeZoneCapabilitiesAndConfig()).thenReturn(capabilitiesAndConfig);
|
||||||
|
|
||||||
mController.updateState(mPreference);
|
mController.updateState(mPreference);
|
||||||
|
|
||||||
assertThat(mPreference.isEnabled()).isTrue();
|
assertThat(mPreference.isEnabled()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static TimeZoneCapabilitiesAndConfig createCapabilitiesAndConfig(
|
||||||
|
boolean suggestManualAllowed) {
|
||||||
|
int suggestManualCapability = suggestManualAllowed ? Capabilities.CAPABILITY_POSSESSED
|
||||||
|
: Capabilities.CAPABILITY_NOT_SUPPORTED;
|
||||||
|
TimeZoneCapabilities capabilities = new TimeZoneCapabilities.Builder(UserHandle.SYSTEM)
|
||||||
|
.setConfigureAutoDetectionEnabledCapability(Capabilities.CAPABILITY_POSSESSED)
|
||||||
|
.setConfigureGeoDetectionEnabledCapability(Capabilities.CAPABILITY_NOT_SUPPORTED)
|
||||||
|
.setSuggestManualTimeZoneCapability(suggestManualCapability)
|
||||||
|
.build();
|
||||||
|
TimeZoneConfiguration config = new TimeZoneConfiguration.Builder()
|
||||||
|
.setAutoDetectionEnabled(!suggestManualAllowed)
|
||||||
|
.setGeoDetectionEnabled(false)
|
||||||
|
.build();
|
||||||
|
return new TimeZoneCapabilitiesAndConfig(capabilities, config);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user