Loading src/com/android/settings/notification/SilentStatusBarPreferenceController.java +2 −1 Original line number Diff line number Diff line Loading @@ -17,6 +17,7 @@ package com.android.settings.notification; import android.content.Context; import android.os.UserManager; import com.android.settings.R; import com.android.settings.core.TogglePreferenceController; Loading Loading @@ -51,7 +52,7 @@ public class SilentStatusBarPreferenceController extends TogglePreferenceControl @Override public int getAvailabilityStatus() { return AVAILABLE; return UserManager.get(mContext).isGuestUser() ? DISABLED_FOR_USER : AVAILABLE; } @Override Loading tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java +29 −0 Original line number Diff line number Diff line Loading @@ -16,14 +16,21 @@ package com.android.settings.notification; import static com.android.settings.core.BasePreferenceController.AVAILABLE; import static com.android.settings.core.BasePreferenceController.DISABLED_FOR_USER; import static com.google.common.truth.Truth.assertThat; import static org.mockito.ArgumentMatchers.any; import static org.mockito.Mockito.times; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; import static org.robolectric.Shadows.shadowOf; import android.content.Context; import android.content.pm.UserInfo; import android.os.UserHandle; import android.os.UserManager; import androidx.preference.Preference; import androidx.preference.PreferenceScreen; Loading @@ -35,6 +42,7 @@ import org.mockito.Mock; import org.mockito.MockitoAnnotations; import org.robolectric.RobolectricTestRunner; import org.robolectric.RuntimeEnvironment; import org.robolectric.shadows.ShadowUserManager; @RunWith(RobolectricTestRunner.class) public class SilentStatusBarPreferenceControllerTest { Loading @@ -59,6 +67,27 @@ public class SilentStatusBarPreferenceControllerTest { when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference); } @Test public void isAvailable_systemUser_available() { assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE); } @Test public void isAvailable_extraUser_available() { ShadowUserManager um = shadowOf(mContext.getSystemService(UserManager.class)); um.addUser(UserHandle.myUserId(), "Another User", UserInfo.FLAG_FULL); assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE); } @Test public void isAvailable_guestUser_disabled() { ShadowUserManager um = shadowOf(mContext.getSystemService(UserManager.class)); um.addUser(UserHandle.myUserId(), "Guest", UserInfo.FLAG_GUEST); assertThat(mController.getAvailabilityStatus()).isEqualTo(DISABLED_FOR_USER); } @Test public void isChecked_settingIsOff() { when(mBackend.shouldHideSilentStatusBarIcons(any())).thenReturn(false); Loading Loading
src/com/android/settings/notification/SilentStatusBarPreferenceController.java +2 −1 Original line number Diff line number Diff line Loading @@ -17,6 +17,7 @@ package com.android.settings.notification; import android.content.Context; import android.os.UserManager; import com.android.settings.R; import com.android.settings.core.TogglePreferenceController; Loading Loading @@ -51,7 +52,7 @@ public class SilentStatusBarPreferenceController extends TogglePreferenceControl @Override public int getAvailabilityStatus() { return AVAILABLE; return UserManager.get(mContext).isGuestUser() ? DISABLED_FOR_USER : AVAILABLE; } @Override Loading
tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java +29 −0 Original line number Diff line number Diff line Loading @@ -16,14 +16,21 @@ package com.android.settings.notification; import static com.android.settings.core.BasePreferenceController.AVAILABLE; import static com.android.settings.core.BasePreferenceController.DISABLED_FOR_USER; import static com.google.common.truth.Truth.assertThat; import static org.mockito.ArgumentMatchers.any; import static org.mockito.Mockito.times; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; import static org.robolectric.Shadows.shadowOf; import android.content.Context; import android.content.pm.UserInfo; import android.os.UserHandle; import android.os.UserManager; import androidx.preference.Preference; import androidx.preference.PreferenceScreen; Loading @@ -35,6 +42,7 @@ import org.mockito.Mock; import org.mockito.MockitoAnnotations; import org.robolectric.RobolectricTestRunner; import org.robolectric.RuntimeEnvironment; import org.robolectric.shadows.ShadowUserManager; @RunWith(RobolectricTestRunner.class) public class SilentStatusBarPreferenceControllerTest { Loading @@ -59,6 +67,27 @@ public class SilentStatusBarPreferenceControllerTest { when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference); } @Test public void isAvailable_systemUser_available() { assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE); } @Test public void isAvailable_extraUser_available() { ShadowUserManager um = shadowOf(mContext.getSystemService(UserManager.class)); um.addUser(UserHandle.myUserId(), "Another User", UserInfo.FLAG_FULL); assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE); } @Test public void isAvailable_guestUser_disabled() { ShadowUserManager um = shadowOf(mContext.getSystemService(UserManager.class)); um.addUser(UserHandle.myUserId(), "Guest", UserInfo.FLAG_GUEST); assertThat(mController.getAvailabilityStatus()).isEqualTo(DISABLED_FOR_USER); } @Test public void isChecked_settingIsOff() { when(mBackend.shouldHideSilentStatusBarIcons(any())).thenReturn(false); Loading