Merge "Avoid double quiet mode requests" into udc-dev
This commit is contained in:
@@ -16,31 +16,42 @@
|
|||||||
package com.android.settings.accounts;
|
package com.android.settings.accounts;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.widget.Switch;
|
||||||
|
|
||||||
import androidx.lifecycle.DefaultLifecycleObserver;
|
import androidx.lifecycle.DefaultLifecycleObserver;
|
||||||
import androidx.lifecycle.LifecycleOwner;
|
import androidx.lifecycle.LifecycleOwner;
|
||||||
import androidx.preference.Preference;
|
import androidx.preference.Preference;
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.internal.annotations.VisibleForTesting;
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.slices.SliceData;
|
import com.android.settings.slices.SliceData;
|
||||||
import com.android.settings.widget.SettingsMainSwitchPreferenceController;
|
|
||||||
import com.android.settingslib.widget.MainSwitchPreference;
|
import com.android.settingslib.widget.MainSwitchPreference;
|
||||||
|
import com.android.settingslib.widget.OnMainSwitchChangeListener;
|
||||||
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
|
||||||
public class WorkModePreferenceController extends SettingsMainSwitchPreferenceController
|
/** Controller for "Work apps" toggle that allows the user to enable/disable quiet mode. */
|
||||||
implements Preference.OnPreferenceChangeListener, DefaultLifecycleObserver,
|
public class WorkModePreferenceController extends BasePreferenceController
|
||||||
|
implements OnMainSwitchChangeListener, DefaultLifecycleObserver,
|
||||||
ManagedProfileQuietModeEnabler.QuietModeChangeListener {
|
ManagedProfileQuietModeEnabler.QuietModeChangeListener {
|
||||||
|
|
||||||
private final ManagedProfileQuietModeEnabler mQuietModeEnabler;
|
private final ManagedProfileQuietModeEnabler mQuietModeEnabler;
|
||||||
|
private MainSwitchPreference mPreference;
|
||||||
|
|
||||||
public WorkModePreferenceController(Context context, String key) {
|
public WorkModePreferenceController(Context context, String key) {
|
||||||
super(context, key);
|
super(context, key);
|
||||||
mQuietModeEnabler = new ManagedProfileQuietModeEnabler(context, this);
|
mQuietModeEnabler = new ManagedProfileQuietModeEnabler(context, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void displayPreference(PreferenceScreen screen) {
|
||||||
|
super.displayPreference(screen);
|
||||||
|
mPreference = screen.findPreference(getPreferenceKey());
|
||||||
|
mPreference.addOnSwitchChangeListener(this);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getAvailabilityStatus() {
|
public int getAvailabilityStatus() {
|
||||||
return (mQuietModeEnabler.isAvailable()) ? AVAILABLE : DISABLED_FOR_USER;
|
return (mQuietModeEnabler.isAvailable()) ? AVAILABLE : DISABLED_FOR_USER;
|
||||||
@@ -57,19 +68,18 @@ public class WorkModePreferenceController extends SettingsMainSwitchPreferenceCo
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isChecked() {
|
public void onSwitchChanged(Switch switchView, boolean isChecked) {
|
||||||
return !mQuietModeEnabler.isQuietModeEnabled();
|
mQuietModeEnabler.setQuietModeEnabled(!isChecked);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean setChecked(boolean isChecked) {
|
public final void updateState(Preference preference) {
|
||||||
mQuietModeEnabler.setQuietModeEnabled(!isChecked);
|
mPreference.updateStatus(!mQuietModeEnabler.isQuietModeEnabled());
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onQuietModeChanged() {
|
public void onQuietModeChanged() {
|
||||||
updateState(mSwitchPreference);
|
updateState(mPreference);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -82,9 +92,4 @@ public class WorkModePreferenceController extends SettingsMainSwitchPreferenceCo
|
|||||||
public int getSliceHighlightMenuRes() {
|
public int getSliceHighlightMenuRes() {
|
||||||
return R.string.menu_key_accounts;
|
return R.string.menu_key_accounts;
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
|
||||||
void setPreference(MainSwitchPreference preference) {
|
|
||||||
mSwitchPreference = preference;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -19,6 +19,7 @@ import static com.google.common.truth.Truth.assertThat;
|
|||||||
|
|
||||||
import static org.mockito.ArgumentMatchers.any;
|
import static org.mockito.ArgumentMatchers.any;
|
||||||
import static org.mockito.ArgumentMatchers.anyInt;
|
import static org.mockito.ArgumentMatchers.anyInt;
|
||||||
|
import static org.mockito.ArgumentMatchers.anyString;
|
||||||
import static org.mockito.Mockito.spy;
|
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;
|
||||||
@@ -27,7 +28,9 @@ import android.content.Context;
|
|||||||
import android.content.pm.UserInfo;
|
import android.content.pm.UserInfo;
|
||||||
import android.os.UserHandle;
|
import android.os.UserHandle;
|
||||||
import android.os.UserManager;
|
import android.os.UserManager;
|
||||||
|
import android.widget.Switch;
|
||||||
|
|
||||||
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
|
|
||||||
import com.android.settingslib.widget.MainSwitchPreference;
|
import com.android.settingslib.widget.MainSwitchPreference;
|
||||||
@@ -57,6 +60,10 @@ public class WorkModePreferenceControllerTest {
|
|||||||
private UserHandle mManagedUser;
|
private UserHandle mManagedUser;
|
||||||
@Mock
|
@Mock
|
||||||
private UserInfo mUserInfo;
|
private UserInfo mUserInfo;
|
||||||
|
@Mock
|
||||||
|
private PreferenceScreen mScreen;
|
||||||
|
@Mock
|
||||||
|
Switch mSwitch;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
@@ -69,7 +76,9 @@ public class WorkModePreferenceControllerTest {
|
|||||||
when(mUserManager.getProcessUserId()).thenReturn(0);
|
when(mUserManager.getProcessUserId()).thenReturn(0);
|
||||||
when(mUserManager.getUserProfiles()).thenReturn(Collections.singletonList(mManagedUser));
|
when(mUserManager.getUserProfiles()).thenReturn(Collections.singletonList(mManagedUser));
|
||||||
when(mManagedUser.getIdentifier()).thenReturn(MANAGED_USER_ID);
|
when(mManagedUser.getIdentifier()).thenReturn(MANAGED_USER_ID);
|
||||||
|
when(mScreen.findPreference(anyString())).thenReturn(mPreference);
|
||||||
mController = new WorkModePreferenceController(mContext, PREF_KEY);
|
mController = new WorkModePreferenceController(mContext, PREF_KEY);
|
||||||
|
mController.displayPreference(mScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -106,13 +115,11 @@ public class WorkModePreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onPreferenceChange_shouldRequestQuietModeEnabled() {
|
public void onPreferenceChange_shouldRequestQuietModeEnabled() {
|
||||||
mController.setPreference(mPreference);
|
mController.onSwitchChanged(mSwitch, true);
|
||||||
|
|
||||||
mController.onPreferenceChange(mPreference, true);
|
|
||||||
|
|
||||||
verify(mUserManager).requestQuietModeEnabled(false, mManagedUser);
|
verify(mUserManager).requestQuietModeEnabled(false, mManagedUser);
|
||||||
|
|
||||||
mController.onPreferenceChange(mPreference, false);
|
mController.onSwitchChanged(mSwitch, false);
|
||||||
|
|
||||||
verify(mUserManager).requestQuietModeEnabled(true, mManagedUser);
|
verify(mUserManager).requestQuietModeEnabled(true, mManagedUser);
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user