diff --git a/res/xml/gentle_notification_settings.xml b/res/xml/gentle_notification_settings.xml
deleted file mode 100644
index 56c3c406494..00000000000
--- a/res/xml/gentle_notification_settings.xml
+++ /dev/null
@@ -1,57 +0,0 @@
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/src/com/android/settings/enterprise/EnterprisePrivacyFeatureProviderImpl.java b/src/com/android/settings/enterprise/EnterprisePrivacyFeatureProviderImpl.java
index d095d880385..675795e7549 100644
--- a/src/com/android/settings/enterprise/EnterprisePrivacyFeatureProviderImpl.java
+++ b/src/com/android/settings/enterprise/EnterprisePrivacyFeatureProviderImpl.java
@@ -279,7 +279,8 @@ public class EnterprisePrivacyFeatureProviderImpl implements EnterprisePrivacyFe
// Only search for the required action in the Device Owner's package
final Intent intent =
new Intent(mResources.getString(R.string.config_work_policy_info_intent_action))
- .setPackage(ownerComponent.getPackageName());
+ .setPackage(ownerComponent.getPackageName())
+ .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
final List activities = mPm.queryIntentActivities(intent, 0);
if (activities.size() != 0) {
return intent;
@@ -302,7 +303,8 @@ public class EnterprisePrivacyFeatureProviderImpl implements EnterprisePrivacyFe
// Only search for the required action in the Profile Owner's package
final Intent intent =
new Intent(mResources.getString(R.string.config_work_policy_info_intent_action))
- .setPackage(ownerComponent.getPackageName());
+ .setPackage(ownerComponent.getPackageName())
+ .addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
final List activities = mPm.queryIntentActivitiesAsUser(intent, 0, userId);
if (activities.size() != 0) {
return intent;
diff --git a/src/com/android/settings/notification/GentleDrawablePreferenceController.java b/src/com/android/settings/notification/GentleDrawablePreferenceController.java
deleted file mode 100644
index b4e18db27d3..00000000000
--- a/src/com/android/settings/notification/GentleDrawablePreferenceController.java
+++ /dev/null
@@ -1,81 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import android.content.Context;
-import android.provider.Settings;
-import android.widget.ImageView;
-
-import com.android.settings.R;
-import com.android.settings.core.BasePreferenceController;
-import com.android.settingslib.widget.LayoutPreference;
-
-import androidx.annotation.VisibleForTesting;
-import androidx.preference.Preference;
-
-public class GentleDrawablePreferenceController extends BasePreferenceController {
-
- @VisibleForTesting
- static final int ON = 1;
-
- private NotificationBackend mBackend;
-
- public GentleDrawablePreferenceController(Context context, String preferenceKey) {
- super(context, preferenceKey);
- mBackend = new NotificationBackend();
- }
-
- @VisibleForTesting
- void setBackend(NotificationBackend backend) {
- mBackend = backend;
- }
-
- @Override
- public void updateState(Preference preference) {
- LayoutPreference pref = (LayoutPreference) preference;
- boolean showOnLockscreen = showOnLockscreen();
- boolean showOnStatusBar = showOnStatusBar();
-
- ImageView view = pref.findViewById(R.id.drawable);
-
- if (showOnLockscreen) {
- if (showOnStatusBar) {
- view.setImageResource(R.drawable.gentle_notifications_shade_status_lock);
- } else {
- view.setImageResource(R.drawable.gentle_notifications_shade_lock);
- }
- } else if (showOnStatusBar) {
- view.setImageResource(R.drawable.gentle_notifications_shade_status);
- } else {
- view.setImageResource(R.drawable.gentle_notifications_shade);
- }
- }
-
- @Override
- public int getAvailabilityStatus() {
- return AVAILABLE;
- }
-
- private boolean showOnLockscreen() {
- return Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, ON) == ON;
- }
-
- private boolean showOnStatusBar() {
- return !mBackend.shouldHideSilentStatusBarIcons(mContext);
- }
-}
diff --git a/src/com/android/settings/notification/GentleNotificationSettings.java b/src/com/android/settings/notification/GentleNotificationSettings.java
deleted file mode 100644
index 5de6ab787a3..00000000000
--- a/src/com/android/settings/notification/GentleNotificationSettings.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import android.app.settings.SettingsEnums;
-import android.content.Context;
-import android.provider.SearchIndexableResource;
-
-import com.android.settings.R;
-import com.android.settings.dashboard.DashboardFragment;
-import com.android.settings.search.BaseSearchIndexProvider;
-import com.android.settingslib.search.SearchIndexable;
-
-import java.util.Arrays;
-import java.util.List;
-
-@SearchIndexable
-public class GentleNotificationSettings extends DashboardFragment {
- private static final String TAG = "GentleNotiSettings";
-
- @Override
- public int getMetricsCategory() {
- return SettingsEnums.GENTLE_NOTIFICATIONS_SCREEN;
- }
-
- @Override
- protected String getLogTag() {
- return TAG;
- }
-
- @Override
- protected int getPreferenceScreenResId() {
- return R.xml.gentle_notification_settings;
- }
-
- @Override
- public void onAttach(Context context) {
- super.onAttach(context);
-
- use(SilentStatusBarPreferenceController.class).setListener(
- shown -> updatePreferenceStates());
-
- use(SilentLockscreenPreferenceController.class).setListener(
- shown -> updatePreferenceStates());
- }
-
- /**
- * For Search.
- */
- public static final SearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
- new BaseSearchIndexProvider() {
- @Override
- public List getXmlResourcesToIndex(
- Context context, boolean enabled) {
- final SearchIndexableResource sir = new SearchIndexableResource(context);
- sir.xmlResId = R.xml.gentle_notification_settings;
- return Arrays.asList(sir);
- }
- };
-}
diff --git a/src/com/android/settings/notification/SilentLockscreenPreferenceController.java b/src/com/android/settings/notification/SilentLockscreenPreferenceController.java
deleted file mode 100644
index 317f7da6e33..00000000000
--- a/src/com/android/settings/notification/SilentLockscreenPreferenceController.java
+++ /dev/null
@@ -1,70 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import android.content.Context;
-import android.os.UserHandle;
-import android.provider.Settings;
-
-import com.android.settings.core.TogglePreferenceController;
-
-import com.google.common.annotations.VisibleForTesting;
-
-public class SilentLockscreenPreferenceController extends TogglePreferenceController {
-
- private static final String KEY = "lock_screen";
- private Listener mListener;
-
- public SilentLockscreenPreferenceController(Context context) {
- super(context, KEY);
- }
-
- @Override
- public boolean isChecked() {
- return Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1) == 1;
- }
-
- @Override
- public boolean setChecked(boolean isChecked) {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, isChecked ? 1 : 0);
- if (mListener != null) {
- mListener.onChange(isChecked);
- }
- return true;
- }
-
- @Override
- public int getAvailabilityStatus() {
- return Settings.Secure.getInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1) != 0
- ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
- }
-
- public void setListener(Listener listener) {
- mListener = listener;
- }
-
- interface Listener {
- void onChange(boolean shown);
- }
-}
-
-
diff --git a/src/com/android/settings/notification/SilentStatusBarPreferenceController.java b/src/com/android/settings/notification/SilentStatusBarPreferenceController.java
deleted file mode 100644
index e561508014e..00000000000
--- a/src/com/android/settings/notification/SilentStatusBarPreferenceController.java
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import android.content.Context;
-import android.os.UserHandle;
-import android.provider.Settings;
-
-import com.android.settings.core.TogglePreferenceController;
-
-import com.google.common.annotations.VisibleForTesting;
-
-public class SilentStatusBarPreferenceController extends TogglePreferenceController {
-
- private static final String KEY = "silent_icons";
- private static final int MY_USER_ID = UserHandle.myUserId();
- private NotificationBackend mBackend;
- private Listener mListener;
-
- public SilentStatusBarPreferenceController(Context context) {
- super(context, KEY);
- mBackend = new NotificationBackend();
- }
-
- @VisibleForTesting
- void setBackend(NotificationBackend backend) {
- mBackend = backend;
- }
-
- @Override
- public boolean isChecked() {
- return !mBackend.shouldHideSilentStatusBarIcons(mContext);
- }
-
- @Override
- public boolean setChecked(boolean isChecked) {
- mBackend.setHideSilentStatusIcons(!isChecked);
- if (mListener != null) {
- mListener.onChange(isChecked);
- }
- return true;
- }
-
- @Override
- public int getAvailabilityStatus() {
- return Settings.Secure.getInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1) != 0
- ? AVAILABLE : UNSUPPORTED_ON_DEVICE;
- }
-
- public void setListener(Listener listener) {
- mListener = listener;
- }
-
- interface Listener {
- void onChange(boolean shown);
- }
-
-}
-
-
diff --git a/src/com/android/settings/tts/TtsEnginePreference.java b/src/com/android/settings/tts/TtsEnginePreference.java
index 6ea414dd4b7..8f15db266e2 100644
--- a/src/com/android/settings/tts/TtsEnginePreference.java
+++ b/src/com/android/settings/tts/TtsEnginePreference.java
@@ -30,6 +30,8 @@ import androidx.preference.PreferenceViewHolder;
import com.android.settings.R;
+import androidx.annotation.VisibleForTesting;
+
public class TtsEnginePreference extends Preference {
@@ -45,6 +47,7 @@ public class TtsEnginePreference extends Preference {
* The shared radio button state, which button is checked etc.
*/
private final RadioButtonGroupState mSharedState;
+ private RadioButton mRadioButton;
/**
* When true, the change callbacks on the radio button will not
@@ -95,6 +98,12 @@ public class TtsEnginePreference extends Preference {
mPreventRadioButtonCallbacks = true;
rb.setChecked(isChecked);
mPreventRadioButtonCallbacks = false;
+ mRadioButton = rb;
+ }
+
+ @Override
+ public void onClick() {
+ mRadioButton.setChecked(true);
}
private boolean shouldDisplayDataAlert() {
diff --git a/tests/robotests/src/com/android/settings/notification/GentleDrawablePreferenceControllerTest.java b/tests/robotests/src/com/android/settings/notification/GentleDrawablePreferenceControllerTest.java
deleted file mode 100644
index c8d1e018bea..00000000000
--- a/tests/robotests/src/com/android/settings/notification/GentleDrawablePreferenceControllerTest.java
+++ /dev/null
@@ -1,113 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import static com.google.common.truth.Truth.assertThat;
-
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import android.content.Context;
-import android.provider.Settings;
-import android.widget.ImageView;
-
-import com.android.settings.R;
-import com.android.settingslib.widget.LayoutPreference;
-
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Mock;
-import org.mockito.MockitoAnnotations;
-import org.robolectric.RobolectricTestRunner;
-import org.robolectric.RuntimeEnvironment;
-
-import androidx.preference.Preference;
-
-@RunWith(RobolectricTestRunner.class)
-public class GentleDrawablePreferenceControllerTest {
-
- private Context mContext;
-
- private GentleDrawablePreferenceController mController;
- @Mock
- private LayoutPreference mPreference;
- @Mock
- NotificationBackend mBackend;
- @Mock
- ImageView mView;
-
- private static final String KEY = "gentle_notifications";
-
- @Before
- public void setUp() {
- MockitoAnnotations.initMocks(this);
- mContext = RuntimeEnvironment.application;
- mController = new GentleDrawablePreferenceController(mContext, KEY);
- mController.setBackend(mBackend);
- when(mPreference.findViewById(R.id.drawable)).thenReturn(mView);
- }
-
- @Test
- public void display_shouldDisplay() {
- assertThat(mController.isAvailable()).isTrue();
- }
-
- @Test
- public void updateState_lock() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(true);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade_lock);
- }
-
- @Test
- public void updateState_status() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(false);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade_status);
- }
-
- @Test
- public void updateState_both() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(false);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade_status_lock);
- }
-
- @Test
- public void updateState_neither() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0);
- when(mBackend.shouldHideSilentStatusBarIcons(mContext)).thenReturn(true);
-
- mController.updateState(mPreference);
-
- verify(mView).setImageResource(R.drawable.gentle_notifications_shade);
- }
-}
diff --git a/tests/robotests/src/com/android/settings/notification/SilentLockscreenPreferenceControllerTest.java b/tests/robotests/src/com/android/settings/notification/SilentLockscreenPreferenceControllerTest.java
deleted file mode 100644
index dcfdea59a8a..00000000000
--- a/tests/robotests/src/com/android/settings/notification/SilentLockscreenPreferenceControllerTest.java
+++ /dev/null
@@ -1,117 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import static com.google.common.truth.Truth.assertThat;
-
-import static org.mockito.ArgumentMatchers.any;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import android.content.Context;
-import android.provider.Settings;
-
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Mock;
-import org.mockito.MockitoAnnotations;
-import org.robolectric.RobolectricTestRunner;
-import org.robolectric.RuntimeEnvironment;
-
-import androidx.preference.Preference;
-import androidx.preference.PreferenceScreen;
-
-@RunWith(RobolectricTestRunner.class)
-public class SilentLockscreenPreferenceControllerTest {
-
- @Mock
- private PreferenceScreen mScreen;
-
- private Context mContext;
- private SilentLockscreenPreferenceController mController;
- private Preference mPreference;
-
- @Before
- public void setUp() {
- MockitoAnnotations.initMocks(this);
- mContext = RuntimeEnvironment.application;
- mController = new SilentLockscreenPreferenceController(mContext);
- mPreference = new Preference(mContext);
- mPreference.setKey(mController.getPreferenceKey());
- when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
- }
-
- @Test
- public void isAvailable_featureEnabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1);
- assertThat(mController.isAvailable()).isTrue();
- }
-
- @Test
- public void isAvailable_featureDisabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 0);
- assertThat(mController.isAvailable()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOff_false() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0);
- assertThat(mController.isChecked()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOn_true() {
- Settings.Secure.putInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1);
- assertThat(mController.isChecked()).isTrue();
- }
-
- @Test
- public void onPreferenceChange_on() {
- mController.onPreferenceChange(mPreference, true);
- assertThat(Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 0)).isEqualTo(1);
- }
-
- @Test
- public void onPreferenceChange_off() {
- mController.onPreferenceChange(mPreference, false);
- assertThat(Settings.Secure.getInt(mContext.getContentResolver(),
- Settings.Secure.LOCK_SCREEN_SHOW_SILENT_NOTIFICATIONS, 1)).isEqualTo(0);
- }
-
- @Test
- public void listenerTriggered() {
- SilentLockscreenPreferenceController.Listener listener = mock(
- SilentLockscreenPreferenceController.Listener.class);
- mController.setListener(listener);
-
- mController.setChecked(false);
- verify(listener).onChange(false);
-
- mController.setChecked(true);
- verify(listener).onChange(true);
- }
-}
-
diff --git a/tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java b/tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java
deleted file mode 100644
index 55a85494e43..00000000000
--- a/tests/robotests/src/com/android/settings/notification/SilentStatusBarPreferenceControllerTest.java
+++ /dev/null
@@ -1,118 +0,0 @@
-/*
- * Copyright (C) 2019 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-package com.android.settings.notification;
-
-import static android.provider.Settings.Secure.NOTIFICATION_NEW_INTERRUPTION_MODEL;
-
-import static com.google.common.truth.Truth.assertThat;
-
-import static org.mockito.ArgumentMatchers.any;
-import static org.mockito.Mockito.mock;
-import static org.mockito.Mockito.verify;
-import static org.mockito.Mockito.when;
-
-import android.content.Context;
-import android.provider.Settings;
-
-import com.android.settings.testutils.FakeFeatureFactory;
-
-import org.junit.Before;
-import org.junit.Test;
-import org.junit.runner.RunWith;
-import org.mockito.Mock;
-import org.mockito.MockitoAnnotations;
-import org.robolectric.RobolectricTestRunner;
-import org.robolectric.RuntimeEnvironment;
-
-import androidx.preference.Preference;
-import androidx.preference.PreferenceScreen;
-
-@RunWith(RobolectricTestRunner.class)
-public class SilentStatusBarPreferenceControllerTest {
-
- @Mock
- private NotificationBackend mBackend;
- @Mock
- private PreferenceScreen mScreen;
-
- private Context mContext;
- private SilentStatusBarPreferenceController mController;
- private Preference mPreference;
-
- @Before
- public void setUp() {
- MockitoAnnotations.initMocks(this);
- mContext = RuntimeEnvironment.application;
- mController = new SilentStatusBarPreferenceController(mContext);
- mController.setBackend(mBackend);
- mPreference = new Preference(mContext);
- mPreference.setKey(mController.getPreferenceKey());
- when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference);
- }
-
- @Test
- public void isAvailable_featureEnabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 1);
- assertThat(mController.isAvailable()).isTrue();
- }
-
- @Test
- public void isAvailable_featureDisabled() {
- Settings.Secure.putInt(
- mContext.getContentResolver(), NOTIFICATION_NEW_INTERRUPTION_MODEL, 0);
- assertThat(mController.isAvailable()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOff_false() {
- when(mBackend.shouldHideSilentStatusBarIcons(any())).thenReturn(true);
- assertThat(mController.isChecked()).isFalse();
- }
-
- @Test
- public void isChecked_settingIsOn_true() {
- when(mBackend.shouldHideSilentStatusBarIcons(any())).thenReturn(false);
- assertThat(mController.isChecked()).isTrue();
- }
-
- @Test
- public void onPreferenceChange_on() {
- mController.onPreferenceChange(mPreference, true);
- verify(mBackend).setHideSilentStatusIcons(false);
- }
-
- @Test
- public void onPreferenceChange_off() {
- mController.onPreferenceChange(mPreference, false);
- verify(mBackend).setHideSilentStatusIcons(true);
- }
-
- @Test
- public void listenerTriggered() {
- SilentStatusBarPreferenceController.Listener listener = mock(
- SilentStatusBarPreferenceController.Listener.class);
- mController.setListener(listener);
-
- mController.setChecked(false);
- verify(listener).onChange(false);
-
- mController.setChecked(true);
- verify(listener).onChange(true);
- }
-}
-
diff --git a/tests/robotests/src/com/android/settings/tts/TtsEnginePreferenceTest.java b/tests/robotests/src/com/android/settings/tts/TtsEnginePreferenceTest.java
new file mode 100644
index 00000000000..5cd948824a9
--- /dev/null
+++ b/tests/robotests/src/com/android/settings/tts/TtsEnginePreferenceTest.java
@@ -0,0 +1,98 @@
+/*
+ * Copyright (C) 2019 The Android Open Source Project
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package com.android.settings.tts;
+
+import static com.google.common.truth.Truth.assertThat;
+
+import android.content.Context;
+import android.speech.tts.TextToSpeech;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.Checkable;
+
+import androidx.preference.PreferenceViewHolder;
+
+import org.junit.Before;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+import org.robolectric.RobolectricTestRunner;
+import org.robolectric.RuntimeEnvironment;
+
+@RunWith(RobolectricTestRunner.class)
+public class TtsEnginePreferenceTest {
+
+ private static final String KEY = "test_key";
+
+ private TtsEnginePreference mPreference;
+ private Context mContext;
+ private PreferenceViewHolder mViewHolder;
+ private View mRootView;
+ private FakeRadioButtonGroupState mState;
+
+ @Before
+ public void setUp() {
+ mContext = RuntimeEnvironment.application;
+
+ final TextToSpeech.EngineInfo info = new TextToSpeech.EngineInfo();
+ info.system = true;
+ mState = new FakeRadioButtonGroupState();
+ mPreference = new TtsEnginePreference(mContext, info, mState);
+ mPreference.setKey(KEY);
+
+ // Create preference view holder
+ final LayoutInflater inflater = LayoutInflater.from(mContext);
+ mRootView = View.inflate(mContext, mPreference.getLayoutResource(), null /* parent */);
+ final ViewGroup widgetFrame = mRootView.findViewById(android.R.id.widget_frame);
+ inflater.inflate(mPreference.getWidgetLayoutResource(), widgetFrame);
+ mViewHolder = PreferenceViewHolder.createInstanceForTests(mRootView);
+ }
+
+ @Test
+ public void onClick_shouldInvokeOnCheckedChangeListener() {
+ mPreference.onBindViewHolder(mViewHolder);
+
+ mPreference.onClick();
+
+ assertThat(mState.getCurrentKey()).isEqualTo(mPreference.getKey());
+ }
+
+ public static class FakeRadioButtonGroupState implements
+ TtsEnginePreference.RadioButtonGroupState {
+
+ private String mKey;
+
+ @Override
+ public Checkable getCurrentChecked() {
+ return null;
+ }
+
+ @Override
+ public String getCurrentKey() {
+ return mKey;
+ }
+
+ @Override
+ public void setCurrentChecked(Checkable current) {
+ }
+
+ @Override
+ public void setCurrentKey(String key) {
+ mKey = key;
+ }
+ }
+}