Merge "Avoid double quiet mode requests" into udc-dev

This commit is contained in:
Pavel Grafov
2023-06-01 15:31:13 +00:00
committed by Android (Google) Code Review
2 changed files with 31 additions and 19 deletions

View File

@@ -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;
}
} }

View File

@@ -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);
} }