Add a default behavior setting for VICs

Test: atest
Bug: 149696991
Change-Id: Ica06f80a02d65294a7b503fd3556add644c61bd7
This commit is contained in:
Julia Reynolds
2020-02-17 21:58:08 -05:00
parent 1ee9dce20c
commit 8949d87be7
25 changed files with 343 additions and 72 deletions

View File

@@ -8277,6 +8277,9 @@
<!-- [CHAR LIMIT=100] preference category title --> <!-- [CHAR LIMIT=100] preference category title -->
<string name="all_conversations">All conversations</string> <string name="all_conversations">All conversations</string>
<!-- [CHAR LIMIT=100] Setting to automatically bubble all notifications from favorite conversations -->
<string name="important_bubble">Bubble important conversations</string>
<!-- [CHAR LIMIT=NONE] description of how notifications from important conversations behave --> <!-- [CHAR LIMIT=NONE] description of how notifications from important conversations behave -->
<string name="important_conversation_behavior_summary">Important conversations show at the top of the pull-down shade. You can also set them to bubble and interrupt Do Not Disturb.</string> <string name="important_conversation_behavior_summary">Important conversations show at the top of the pull-down shade. You can also set them to bubble and interrupt Do Not Disturb.</string>

View File

@@ -27,6 +27,11 @@
<Preference <Preference
android:key="behavior" android:key="behavior"
android:summary="@string/important_conversation_behavior_summary"/> android:summary="@string/important_conversation_behavior_summary"/>
<SwitchPreference
android:key="important_bubble"
android:title="@string/important_bubble"
android:icon="@drawable/ic_create_bubble"
settings:controller="com.android.settings.notification.app.ImportantConversationBubblePreferenceController"/>
<!-- Important conversations added here --> <!-- Important conversations added here -->
<PreferenceCategory <PreferenceCategory
android:key="important_conversations_list" android:key="important_conversations_list"

View File

@@ -35,13 +35,13 @@ public class AllowSoundPreferenceController extends NotificationPreferenceContro
private static final String TAG = "AllowSoundPrefContr"; private static final String TAG = "AllowSoundPrefContr";
private static final String KEY_IMPORTANCE = "allow_sound"; private static final String KEY_IMPORTANCE = "allow_sound";
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
public AllowSoundPreferenceController(Context context, public AllowSoundPreferenceController(Context context,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mImportanceListener = importanceListener; mDependentFieldListener = dependentFieldListener;
} }
@Override @Override
@@ -77,7 +77,7 @@ public class AllowSoundPreferenceController extends NotificationPreferenceContro
mChannel.setImportance(importance); mChannel.setImportance(importance);
mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE); mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE);
saveChannel(); saveChannel();
mImportanceListener.onImportanceChanged(); mDependentFieldListener.onFieldValueChanged();
} }
return true; return true;
} }

View File

@@ -100,18 +100,18 @@ public class AppNotificationSettings extends NotificationSettings {
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) { protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
mControllers = new ArrayList<>(); mControllers = new ArrayList<>();
mControllers.add(new HeaderPreferenceController(context, this)); mControllers.add(new HeaderPreferenceController(context, this));
mControllers.add(new BlockPreferenceController(context, mImportanceListener, mBackend)); mControllers.add(new BlockPreferenceController(context, mDependentFieldListener, mBackend));
mControllers.add(new BadgePreferenceController(context, mBackend)); mControllers.add(new BadgePreferenceController(context, mBackend));
mControllers.add(new AllowSoundPreferenceController( mControllers.add(new AllowSoundPreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new ImportancePreferenceController( mControllers.add(new ImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new MinImportancePreferenceController( mControllers.add(new MinImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new HighImportancePreferenceController( mControllers.add(new HighImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new SoundPreferenceController(context, this, mControllers.add(new SoundPreferenceController(context, this,
mImportanceListener, mBackend)); mDependentFieldListener, mBackend));
mControllers.add(new LightsPreferenceController(context, mBackend)); mControllers.add(new LightsPreferenceController(context, mBackend));
mControllers.add(new VibrationPreferenceController(context, mBackend)); mControllers.add(new VibrationPreferenceController(context, mBackend));
mControllers.add(new VisibilityPreferenceController(context, new LockPatternUtils(context), mControllers.add(new VisibilityPreferenceController(context, new LockPatternUtils(context),

View File

@@ -36,13 +36,13 @@ public class BlockPreferenceController extends NotificationPreferenceController
implements PreferenceControllerMixin, SwitchBar.OnSwitchChangeListener { implements PreferenceControllerMixin, SwitchBar.OnSwitchChangeListener {
private static final String KEY_BLOCK = "block"; private static final String KEY_BLOCK = "block";
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
public BlockPreferenceController(Context context, public BlockPreferenceController(Context context,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mImportanceListener = importanceListener; mDependentFieldListener = dependentFieldListener;
} }
@Override @Override
@@ -124,7 +124,7 @@ public class BlockPreferenceController extends NotificationPreferenceController
mAppRow.banned = blocked; mAppRow.banned = blocked;
mBackend.setNotificationsEnabledForPackage(mAppRow.pkg, mAppRow.uid, !blocked); mBackend.setNotificationsEnabledForPackage(mAppRow.pkg, mAppRow.uid, !blocked);
} }
mImportanceListener.onImportanceChanged(); mDependentFieldListener.onFieldValueChanged();
} }
String getSwitchBarText() { String getSwitchBarText() {

View File

@@ -109,17 +109,17 @@ public class ChannelNotificationSettings extends NotificationSettings {
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) { protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
mControllers = new ArrayList<>(); mControllers = new ArrayList<>();
mControllers.add(new HeaderPreferenceController(context, this)); mControllers.add(new HeaderPreferenceController(context, this));
mControllers.add(new BlockPreferenceController(context, mImportanceListener, mBackend)); mControllers.add(new BlockPreferenceController(context, mDependentFieldListener, mBackend));
mControllers.add(new ImportancePreferenceController( mControllers.add(new ImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new MinImportancePreferenceController( mControllers.add(new MinImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new HighImportancePreferenceController( mControllers.add(new HighImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new AllowSoundPreferenceController( mControllers.add(new AllowSoundPreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new SoundPreferenceController(context, this, mControllers.add(new SoundPreferenceController(context, this,
mImportanceListener, mBackend)); mDependentFieldListener, mBackend));
mControllers.add(new VibrationPreferenceController(context, mBackend)); mControllers.add(new VibrationPreferenceController(context, mBackend));
mControllers.add(new AppLinkPreferenceController(context)); mControllers.add(new AppLinkPreferenceController(context));
mControllers.add(new DescriptionPreferenceController(context)); mControllers.add(new DescriptionPreferenceController(context));

View File

@@ -16,7 +16,10 @@
package com.android.settings.notification.app; package com.android.settings.notification.app;
import static android.provider.Settings.Secure.BUBBLE_IMPORTANT_CONVERSATIONS;
import android.content.Context; import android.content.Context;
import android.provider.Settings;
import androidx.preference.Preference; import androidx.preference.Preference;
@@ -29,10 +32,12 @@ public class ConversationImportantPreferenceController extends NotificationPrefe
private static final String TAG = "ConvoImpPC"; private static final String TAG = "ConvoImpPC";
private static final String KEY = "important"; private static final String KEY = "important";
private final NotificationSettings.DependentFieldListener mDependentFieldListener;
public ConversationImportantPreferenceController(Context context, public ConversationImportantPreferenceController(Context context,
NotificationBackend backend) { NotificationBackend backend, NotificationSettings.DependentFieldListener listener) {
super(context, backend); super(context, backend);
mDependentFieldListener = listener;
} }
@Override @Override
@@ -67,8 +72,17 @@ public class ConversationImportantPreferenceController extends NotificationPrefe
} }
final boolean value = (Boolean) newValue; final boolean value = (Boolean) newValue;
mChannel.setImportantConversation(value); mChannel.setImportantConversation(value);
if (value && bubbleImportantConversations()) {
mChannel.setAllowBubbles(true);
mDependentFieldListener.onFieldValueChanged();
}
saveChannel(); saveChannel();
return true; return true;
} }
private boolean bubbleImportantConversations() {
return Settings.Secure.getInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, 1) == 1;
}
} }

View File

@@ -40,7 +40,7 @@ public class ConversationListSettings extends DashboardFragment {
private static final boolean DEBUG = Log.isLoggable(TAG, Log.DEBUG); private static final boolean DEBUG = Log.isLoggable(TAG, Log.DEBUG);
NotificationBackend mBackend = new NotificationBackend(); NotificationBackend mBackend = new NotificationBackend();
protected List<ConversationListPreferenceController> mControllers = new ArrayList<>(); protected List<AbstractPreferenceController> mControllers = new ArrayList<>();
@Override @Override
public int getMetricsCategory() { public int getMetricsCategory() {

View File

@@ -79,14 +79,15 @@ public class ConversationNotificationSettings extends NotificationSettings {
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) { protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
mControllers = new ArrayList<>(); mControllers = new ArrayList<>();
mControllers.add(new ConversationHeaderPreferenceController(context, this)); mControllers.add(new ConversationHeaderPreferenceController(context, this));
mControllers.add(new ConversationImportantPreferenceController(context, mBackend)); mControllers.add(new ConversationImportantPreferenceController(
context, mBackend, mDependentFieldListener));
mControllers.add(new DefaultImportancePreferenceController( mControllers.add(new DefaultImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new AddToHomeScreenPreferenceController(context, mBackend)); mControllers.add(new AddToHomeScreenPreferenceController(context, mBackend));
mControllers.add(new HighImportancePreferenceController( mControllers.add(new HighImportancePreferenceController(
context, mImportanceListener, mBackend)); context, mDependentFieldListener, mBackend));
mControllers.add(new SoundPreferenceController(context, this, mControllers.add(new SoundPreferenceController(context, this,
mImportanceListener, mBackend)); mDependentFieldListener, mBackend));
mControllers.add(new VibrationPreferenceController(context, mBackend)); mControllers.add(new VibrationPreferenceController(context, mBackend));
mControllers.add(new AppLinkPreferenceController(context)); mControllers.add(new AppLinkPreferenceController(context));
mControllers.add(new DescriptionPreferenceController(context)); mControllers.add(new DescriptionPreferenceController(context));

View File

@@ -32,13 +32,13 @@ public class DefaultImportancePreferenceController extends NotificationPreferenc
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener { implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
private static final String KEY = "alerting"; private static final String KEY = "alerting";
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
public DefaultImportancePreferenceController(Context context, public DefaultImportancePreferenceController(Context context,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mImportanceListener = importanceListener; mDependentFieldListener = dependentFieldListener;
} }
@Override @Override
@@ -78,7 +78,7 @@ public class DefaultImportancePreferenceController extends NotificationPreferenc
mChannel.setImportance(checked ? IMPORTANCE_DEFAULT : IMPORTANCE_LOW); mChannel.setImportance(checked ? IMPORTANCE_DEFAULT : IMPORTANCE_LOW);
mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE); mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE);
saveChannel(); saveChannel();
mImportanceListener.onImportanceChanged(); mDependentFieldListener.onFieldValueChanged();
} }
return true; return true;
} }

View File

@@ -32,13 +32,13 @@ public class HighImportancePreferenceController extends NotificationPreferenceCo
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener { implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
private static final String KEY_IMPORTANCE = "high_importance"; private static final String KEY_IMPORTANCE = "high_importance";
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
public HighImportancePreferenceController(Context context, public HighImportancePreferenceController(Context context,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mImportanceListener = importanceListener; mDependentFieldListener = dependentFieldListener;
} }
@Override @Override
@@ -78,7 +78,7 @@ public class HighImportancePreferenceController extends NotificationPreferenceCo
mChannel.setImportance(checked ? IMPORTANCE_HIGH : IMPORTANCE_DEFAULT); mChannel.setImportance(checked ? IMPORTANCE_HIGH : IMPORTANCE_DEFAULT);
mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE); mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE);
saveChannel(); saveChannel();
mImportanceListener.onImportanceChanged(); mDependentFieldListener.onFieldValueChanged();
} }
return true; return true;
} }

View File

@@ -33,13 +33,13 @@ public class ImportancePreferenceController extends NotificationPreferenceContro
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener { implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
private static final String KEY_IMPORTANCE = "importance"; private static final String KEY_IMPORTANCE = "importance";
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
public ImportancePreferenceController(Context context, public ImportancePreferenceController(Context context,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mImportanceListener = importanceListener; mDependentFieldListener = dependentFieldListener;
} }
@Override @Override
@@ -91,7 +91,7 @@ public class ImportancePreferenceController extends NotificationPreferenceContro
mChannel.setImportance(importance); mChannel.setImportance(importance);
mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE); mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE);
saveChannel(); saveChannel();
mImportanceListener.onImportanceChanged(); mDependentFieldListener.onFieldValueChanged();
} }
return true; return true;
} }

View File

@@ -0,0 +1,71 @@
/*
* Copyright (C) 2020 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.app;
import static android.provider.Settings.Global.NOTIFICATION_BUBBLES;
import static android.provider.Settings.Secure.BUBBLE_IMPORTANT_CONVERSATIONS;
import android.content.Context;
import android.provider.Settings;
import androidx.annotation.VisibleForTesting;
import androidx.preference.Preference;
import com.android.settings.core.PreferenceControllerMixin;
import com.android.settings.core.TogglePreferenceController;
public class ImportantConversationBubblePreferenceController extends TogglePreferenceController
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
private static final String TAG = "ImpConvBubPrefContr";
@VisibleForTesting
static final int ON = 1;
@VisibleForTesting
static final int OFF = 0;
public ImportantConversationBubblePreferenceController(Context context, String preferenceKey) {
super(context, preferenceKey);
}
private boolean isGloballyEnabled() {
return Settings.Global.getInt(mContext.getContentResolver(),
NOTIFICATION_BUBBLES, OFF) == ON;
}
@Override
public int getAvailabilityStatus() {
return isGloballyEnabled() ? AVAILABLE : DISABLED_DEPENDENT_SETTING;
}
@Override
public boolean isSliceable() {
return false;
}
@Override
public boolean isChecked() {
return Settings.Secure.getInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, ON) == ON;
}
@Override
public boolean setChecked(boolean isChecked) {
return Settings.Secure.putInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, isChecked ? ON : OFF);
}
}

View File

@@ -32,13 +32,13 @@ public class MinImportancePreferenceController extends NotificationPreferenceCon
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener { implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener {
private static final String KEY_IMPORTANCE = "min_importance"; private static final String KEY_IMPORTANCE = "min_importance";
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
public MinImportancePreferenceController(Context context, public MinImportancePreferenceController(Context context,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mImportanceListener = importanceListener; mDependentFieldListener = dependentFieldListener;
} }
@Override @Override
@@ -78,7 +78,7 @@ public class MinImportancePreferenceController extends NotificationPreferenceCon
mChannel.setImportance(checked ? IMPORTANCE_MIN : IMPORTANCE_LOW); mChannel.setImportance(checked ? IMPORTANCE_MIN : IMPORTANCE_LOW);
mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE); mChannel.lockFields(NotificationChannel.USER_LOCKED_IMPORTANCE);
saveChannel(); saveChannel();
mImportanceListener.onImportanceChanged(); mDependentFieldListener.onFieldValueChanged();
} }
return true; return true;
} }

View File

@@ -33,7 +33,6 @@ import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException; import android.content.pm.PackageManager.NameNotFoundException;
import android.content.pm.ResolveInfo; import android.content.pm.ResolveInfo;
import android.content.pm.ShortcutInfo; import android.content.pm.ShortcutInfo;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable; import android.graphics.drawable.Drawable;
import android.os.Bundle; import android.os.Bundle;
import android.os.UserHandle; import android.os.UserHandle;
@@ -79,7 +78,7 @@ abstract public class NotificationSettings extends DashboardFragment {
protected boolean mListeningToPackageRemove; protected boolean mListeningToPackageRemove;
protected List<NotificationPreferenceController> mControllers = new ArrayList<>(); protected List<NotificationPreferenceController> mControllers = new ArrayList<>();
protected ImportanceListener mImportanceListener = new ImportanceListener(); protected DependentFieldListener mDependentFieldListener = new DependentFieldListener();
protected Intent mIntent; protected Intent mIntent;
protected Bundle mArgs; protected Bundle mArgs;
@@ -328,8 +327,8 @@ abstract public class NotificationSettings extends DashboardFragment {
} }
}; };
protected class ImportanceListener { protected class DependentFieldListener {
protected void onImportanceChanged() { protected void onFieldValueChanged() {
final PreferenceScreen screen = getPreferenceScreen(); final PreferenceScreen screen = getPreferenceScreen();
for (NotificationPreferenceController controller : mControllers) { for (NotificationPreferenceController controller : mControllers) {
controller.displayPreference(screen); controller.displayPreference(screen);

View File

@@ -40,16 +40,16 @@ public class SoundPreferenceController extends NotificationPreferenceController
private static final String KEY_SOUND = "ringtone"; private static final String KEY_SOUND = "ringtone";
private final SettingsPreferenceFragment mFragment; private final SettingsPreferenceFragment mFragment;
private final NotificationSettings.ImportanceListener mListener; private final NotificationSettings.DependentFieldListener mListener;
private NotificationSoundPreference mPreference; private NotificationSoundPreference mPreference;
protected static final int CODE = 200; protected static final int CODE = 200;
public SoundPreferenceController(Context context, SettingsPreferenceFragment hostFragment, public SoundPreferenceController(Context context, SettingsPreferenceFragment hostFragment,
NotificationSettings.ImportanceListener importanceListener, NotificationSettings.DependentFieldListener dependentFieldListener,
NotificationBackend backend) { NotificationBackend backend) {
super(context, backend); super(context, backend);
mFragment = hostFragment; mFragment = hostFragment;
mListener = importanceListener; mListener = dependentFieldListener;
} }
@Override @Override
@@ -121,7 +121,7 @@ public class SoundPreferenceController extends NotificationPreferenceController
} }
// the importance hasn't changed, but the importance description might as a result of // the importance hasn't changed, but the importance description might as a result of
// user's selection. // user's selection.
mListener.onImportanceChanged(); mListener.onFieldValueChanged();
return true; return true;
} }
return false; return false;

View File

@@ -68,7 +68,7 @@ public class AllowSoundPreferenceControllerTest {
private PreferenceScreen mScreen; private PreferenceScreen mScreen;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
private AllowSoundPreferenceController mController; private AllowSoundPreferenceController mController;
@@ -80,7 +80,7 @@ public class AllowSoundPreferenceControllerTest {
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = mController =
spy(new AllowSoundPreferenceController(mContext, mImportanceListener, mBackend)); spy(new AllowSoundPreferenceController(mContext, mDependentFieldListener, mBackend));
} }
@Test @Test
@@ -213,7 +213,7 @@ public class AllowSoundPreferenceControllerTest {
mController.onPreferenceChange(pref, true); mController.onPreferenceChange(pref, true);
assertEquals(IMPORTANCE_UNSPECIFIED, mController.mChannel.getImportance()); assertEquals(IMPORTANCE_UNSPECIFIED, mController.mChannel.getImportance());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
@Test @Test
@@ -232,6 +232,6 @@ public class AllowSoundPreferenceControllerTest {
verify(mBackend, times(1)).updateChannel(any(), anyInt(), any()); verify(mBackend, times(1)).updateChannel(any(), anyInt(), any());
assertEquals(IMPORTANCE_LOW, mController.mChannel.getImportance()); assertEquals(IMPORTANCE_LOW, mController.mChannel.getImportance());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
} }

View File

@@ -69,7 +69,7 @@ public class BlockPreferenceControllerTest {
private UserManager mUm; private UserManager mUm;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
private BlockPreferenceController mController; private BlockPreferenceController mController;
@Mock @Mock
@@ -83,7 +83,7 @@ public class BlockPreferenceControllerTest {
shadowApplication.setSystemService(Context.NOTIFICATION_SERVICE, mNm); shadowApplication.setSystemService(Context.NOTIFICATION_SERVICE, mNm);
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new BlockPreferenceController(mContext, mImportanceListener, mBackend)); mController = spy(new BlockPreferenceController(mContext, mDependentFieldListener, mBackend));
mSwitch = new SwitchBar(mContext); mSwitch = new SwitchBar(mContext);
when(mPreference.findViewById(R.id.switch_bar)).thenReturn(mSwitch); when(mPreference.findViewById(R.id.switch_bar)).thenReturn(mSwitch);
} }

View File

@@ -19,12 +19,14 @@ package com.android.settings.notification.app;
import static android.app.NotificationChannel.DEFAULT_CHANNEL_ID; import static android.app.NotificationChannel.DEFAULT_CHANNEL_ID;
import static android.app.NotificationManager.IMPORTANCE_DEFAULT; import static android.app.NotificationManager.IMPORTANCE_DEFAULT;
import static android.app.NotificationManager.IMPORTANCE_HIGH; import static android.app.NotificationManager.IMPORTANCE_HIGH;
import static android.provider.Settings.Secure.BUBBLE_IMPORTANT_CONVERSATIONS;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
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.Mockito.mock; import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.never;
import static org.mockito.Mockito.spy; import static org.mockito.Mockito.spy;
import static org.mockito.Mockito.times; import static org.mockito.Mockito.times;
import static org.mockito.Mockito.verify; import static org.mockito.Mockito.verify;
@@ -34,6 +36,7 @@ import android.app.NotificationChannel;
import android.app.NotificationManager; import android.app.NotificationManager;
import android.content.Context; import android.content.Context;
import android.os.UserManager; import android.os.UserManager;
import android.provider.Settings;
import androidx.preference.Preference; import androidx.preference.Preference;
import androidx.preference.PreferenceScreen; import androidx.preference.PreferenceScreen;
@@ -64,6 +67,8 @@ public class ConversationImportantPreferenceControllerTest {
private UserManager mUm; private UserManager mUm;
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
private PreferenceScreen mScreen; private PreferenceScreen mScreen;
@Mock
private NotificationSettings.DependentFieldListener mDependentFieldListener;
private ConversationImportantPreferenceController mController; private ConversationImportantPreferenceController mController;
@@ -74,7 +79,8 @@ public class ConversationImportantPreferenceControllerTest {
shadowApplication.setSystemService(Context.NOTIFICATION_SERVICE, mNm); shadowApplication.setSystemService(Context.NOTIFICATION_SERVICE, mNm);
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new ConversationImportantPreferenceController(mContext, mBackend)); mController = spy(new ConversationImportantPreferenceController(
mContext, mBackend, mDependentFieldListener));
} }
@Test @Test
@@ -133,9 +139,12 @@ public class ConversationImportantPreferenceControllerTest {
@Test @Test
public void testOnPreferenceChange_on() { public void testOnPreferenceChange_on() {
Settings.Secure.putInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, 0);
NotificationChannel channel = NotificationChannel channel =
new NotificationChannel(DEFAULT_CHANNEL_ID, "a", IMPORTANCE_DEFAULT); new NotificationChannel(DEFAULT_CHANNEL_ID, "a", IMPORTANCE_DEFAULT);
channel.setImportantConversation(false); channel.setImportantConversation(false);
channel.setAllowBubbles(false);
mController.onResume(new NotificationBackend.AppRow(), channel, null, null, null, null); mController.onResume(new NotificationBackend.AppRow(), channel, null, null, null, null);
RestrictedSwitchPreference pref = RestrictedSwitchPreference pref =
@@ -145,14 +154,41 @@ public class ConversationImportantPreferenceControllerTest {
mController.onPreferenceChange(pref, true); mController.onPreferenceChange(pref, true);
assertTrue(channel.isImportantConversation()); assertTrue(channel.isImportantConversation());
assertFalse(channel.canBubble());
verify(mBackend, times(1)).updateChannel(any(), anyInt(), any()); verify(mBackend, times(1)).updateChannel(any(), anyInt(), any());
verify(mDependentFieldListener, never()).onFieldValueChanged();
}
@Test
public void testOnPreferenceChange_on_bubble() {
Settings.Secure.putInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, 1);
NotificationChannel channel =
new NotificationChannel(DEFAULT_CHANNEL_ID, "a", IMPORTANCE_DEFAULT);
channel.setImportantConversation(false);
channel.setAllowBubbles(false);
mController.onResume(new NotificationBackend.AppRow(), channel, null, null, null, null);
RestrictedSwitchPreference pref =
new RestrictedSwitchPreference(RuntimeEnvironment.application);
mController.updateState(pref);
mController.onPreferenceChange(pref, true);
assertTrue(channel.isImportantConversation());
assertTrue(channel.canBubble());
verify(mBackend, times(1)).updateChannel(any(), anyInt(), any());
verify(mDependentFieldListener).onFieldValueChanged();
} }
@Test @Test
public void testOnPreferenceChange_off() { public void testOnPreferenceChange_off() {
Settings.Secure.putInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, 1);
NotificationChannel channel = NotificationChannel channel =
new NotificationChannel(DEFAULT_CHANNEL_ID, "a", IMPORTANCE_HIGH); new NotificationChannel(DEFAULT_CHANNEL_ID, "a", IMPORTANCE_HIGH);
channel.setImportantConversation(true); channel.setImportantConversation(true);
channel.setAllowBubbles(false);
mController.onResume(new NotificationBackend.AppRow(), channel, null, null, null, null); mController.onResume(new NotificationBackend.AppRow(), channel, null, null, null, null);
RestrictedSwitchPreference pref = RestrictedSwitchPreference pref =
@@ -164,6 +200,8 @@ public class ConversationImportantPreferenceControllerTest {
mController.onPreferenceChange(pref, false); mController.onPreferenceChange(pref, false);
assertFalse(channel.isImportantConversation()); assertFalse(channel.isImportantConversation());
assertFalse(channel.canBubble());
verify(mBackend, times(1)).updateChannel(any(), anyInt(), any()); verify(mBackend, times(1)).updateChannel(any(), anyInt(), any());
verify(mDependentFieldListener, never()).onFieldValueChanged();
} }
} }

View File

@@ -62,7 +62,7 @@ public class DefaultImportancePreferenceControllerTest {
@Mock @Mock
private NotificationBackend mBackend; private NotificationBackend mBackend;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
@Mock @Mock
private UserManager mUm; private UserManager mUm;
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
@@ -78,7 +78,7 @@ public class DefaultImportancePreferenceControllerTest {
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new DefaultImportancePreferenceController( mController = spy(new DefaultImportancePreferenceController(
mContext, mImportanceListener, mBackend)); mContext, mDependentFieldListener, mBackend));
} }
@Test @Test
@@ -224,7 +224,7 @@ public class DefaultImportancePreferenceControllerTest {
mController.onPreferenceChange(pref, false); mController.onPreferenceChange(pref, false);
assertEquals(IMPORTANCE_LOW, channel.getImportance()); assertEquals(IMPORTANCE_LOW, channel.getImportance());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
@Test @Test
@@ -241,6 +241,6 @@ public class DefaultImportancePreferenceControllerTest {
mController.onPreferenceChange(pref, true); mController.onPreferenceChange(pref, true);
assertEquals(IMPORTANCE_DEFAULT, channel.getImportance()); assertEquals(IMPORTANCE_DEFAULT, channel.getImportance());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
} }

View File

@@ -61,7 +61,7 @@ public class HighImportancePreferenceControllerTest {
@Mock @Mock
private NotificationBackend mBackend; private NotificationBackend mBackend;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
@Mock @Mock
private UserManager mUm; private UserManager mUm;
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
@@ -77,7 +77,7 @@ public class HighImportancePreferenceControllerTest {
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new HighImportancePreferenceController( mController = spy(new HighImportancePreferenceController(
mContext, mImportanceListener, mBackend)); mContext, mDependentFieldListener, mBackend));
} }
@Test @Test
@@ -223,6 +223,6 @@ public class HighImportancePreferenceControllerTest {
mController.onPreferenceChange(pref, false); mController.onPreferenceChange(pref, false);
assertEquals(IMPORTANCE_DEFAULT, channel.getImportance()); assertEquals(IMPORTANCE_DEFAULT, channel.getImportance());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
} }

View File

@@ -67,7 +67,7 @@ public class ImportancePreferenceControllerTest {
@Mock @Mock
private NotificationBackend mBackend; private NotificationBackend mBackend;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
@Mock @Mock
private UserManager mUm; private UserManager mUm;
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
@@ -83,7 +83,7 @@ public class ImportancePreferenceControllerTest {
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new ImportancePreferenceController( mController = spy(new ImportancePreferenceController(
mContext, mImportanceListener, mBackend)); mContext, mDependentFieldListener, mBackend));
} }
@Test @Test

View File

@@ -0,0 +1,140 @@
/*
* Copyright (C) 2020 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.app;
import static android.provider.Settings.Global.NOTIFICATION_BUBBLES;
import static android.provider.Settings.Secure.BUBBLE_IMPORTANT_CONVERSATIONS;
import static com.android.settings.core.BasePreferenceController.AVAILABLE;
import static com.android.settings.core.BasePreferenceController.DISABLED_DEPENDENT_SETTING;
import static com.android.settings.notification.app.ImportantConversationBubblePreferenceController.OFF;
import static com.android.settings.notification.app.ImportantConversationBubblePreferenceController.ON;
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 androidx.preference.PreferenceScreen;
import androidx.preference.TwoStatePreference;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Answers;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.robolectric.RobolectricTestRunner;
@RunWith(RobolectricTestRunner.class)
public class ImportantConversationBubblePreferenceControllerTest {
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
private Context mContext;
@Mock(answer = Answers.RETURNS_DEEP_STUBS)
private PreferenceScreen mScreen;
private ImportantConversationBubblePreferenceController mController;
@Mock
private TwoStatePreference mPreference;
private static final String KEY = "important_bubble";
@Before
public void setUp() {
MockitoAnnotations.initMocks(this);
mController = new ImportantConversationBubblePreferenceController(mContext, KEY);
when(mPreference.getKey()).thenReturn(mController.getPreferenceKey());
when(mScreen.findPreference(mPreference.getKey())).thenReturn(mPreference);
}
@Test
public void testGetAvailabilityStatus_globallyOn() {
Settings.Global.putInt(mContext.getContentResolver(), NOTIFICATION_BUBBLES, ON);
assertThat(mController.getAvailabilityStatus()).isEqualTo(AVAILABLE);
}
@Test
public void testGetAvailabilityStatus_globallyOff() {
Settings.Global.putInt(mContext.getContentResolver(), NOTIFICATION_BUBBLES, OFF);
assertThat(mController.getAvailabilityStatus()).isEqualTo(DISABLED_DEPENDENT_SETTING);
}
@Test
public void updateState_preferenceSetCheckedWhenSettingIsOn() {
Settings.Secure.putInt(mContext.getContentResolver(), BUBBLE_IMPORTANT_CONVERSATIONS, ON);
mController.updateState(mPreference);
verify(mPreference).setChecked(true);
}
@Test
public void updateState_preferenceSetUncheckedWhenSettingIsOff() {
Settings.Secure.putInt(mContext.getContentResolver(), BUBBLE_IMPORTANT_CONVERSATIONS, OFF);
mController.updateState(mPreference);
verify(mPreference).setChecked(false);
}
@Test
public void isChecked_settingIsOff_shouldReturnFalse() {
Settings.Secure.putInt(mContext.getContentResolver(), BUBBLE_IMPORTANT_CONVERSATIONS, OFF);
assertThat(mController.isChecked()).isFalse();
}
@Test
public void isChecked_settingIsOn_shouldReturnTrue() {
Settings.Secure.putInt(mContext.getContentResolver(), BUBBLE_IMPORTANT_CONVERSATIONS, ON);
assertThat(mController.isChecked()).isTrue();
}
@Test
public void setChecked_setFalse_disablesSetting() {
Settings.Secure.putInt(mContext.getContentResolver(), BUBBLE_IMPORTANT_CONVERSATIONS, ON);
mController.setChecked(false);
int updatedValue = Settings.Secure.getInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, -1);
assertThat(updatedValue).isEqualTo(OFF);
}
@Test
public void setChecked_setTrue_enablesSetting() {
Settings.Secure.putInt(mContext.getContentResolver(), BUBBLE_IMPORTANT_CONVERSATIONS, OFF);
mController.setChecked(true);
int updatedValue = Settings.Secure.getInt(mContext.getContentResolver(),
BUBBLE_IMPORTANT_CONVERSATIONS, -1);
assertThat(updatedValue).isEqualTo(ON);
}
@Test
public void isSliceable_returnsFalse() {
assertThat(mController.isSliceable()).isFalse();
}
}

View File

@@ -61,7 +61,7 @@ public class MinImportancePreferenceControllerTest {
@Mock @Mock
private NotificationBackend mBackend; private NotificationBackend mBackend;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
@Mock @Mock
private UserManager mUm; private UserManager mUm;
@Mock(answer = Answers.RETURNS_DEEP_STUBS) @Mock(answer = Answers.RETURNS_DEEP_STUBS)
@@ -77,7 +77,7 @@ public class MinImportancePreferenceControllerTest {
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new MinImportancePreferenceController( mController = spy(new MinImportancePreferenceController(
mContext, mImportanceListener, mBackend)); mContext, mDependentFieldListener, mBackend));
} }
@Test @Test
@@ -223,6 +223,6 @@ public class MinImportancePreferenceControllerTest {
mController.onPreferenceChange(pref, true); mController.onPreferenceChange(pref, true);
assertEquals(IMPORTANCE_MIN, channel.getImportance()); assertEquals(IMPORTANCE_MIN, channel.getImportance());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
} }

View File

@@ -80,7 +80,7 @@ public class SoundPreferenceControllerTest {
@Mock @Mock
private SettingsPreferenceFragment mFragment; private SettingsPreferenceFragment mFragment;
@Mock @Mock
private NotificationSettings.ImportanceListener mImportanceListener; private NotificationSettings.DependentFieldListener mDependentFieldListener;
private SoundPreferenceController mController; private SoundPreferenceController mController;
@@ -92,7 +92,7 @@ public class SoundPreferenceControllerTest {
shadowApplication.setSystemService(Context.USER_SERVICE, mUm); shadowApplication.setSystemService(Context.USER_SERVICE, mUm);
mContext = RuntimeEnvironment.application; mContext = RuntimeEnvironment.application;
mController = spy(new SoundPreferenceController( mController = spy(new SoundPreferenceController(
mContext, mFragment, mImportanceListener, mBackend)); mContext, mFragment, mDependentFieldListener, mBackend));
} }
@Test @Test
@@ -303,7 +303,7 @@ public class SoundPreferenceControllerTest {
mController.onActivityResult(SoundPreferenceController.CODE, 1, new Intent("hi")); mController.onActivityResult(SoundPreferenceController.CODE, 1, new Intent("hi"));
verify(pref, times(1)).onActivityResult(anyInt(), anyInt(), any()); verify(pref, times(1)).onActivityResult(anyInt(), anyInt(), any());
verify(mImportanceListener, times(1)).onImportanceChanged(); verify(mDependentFieldListener, times(1)).onFieldValueChanged();
} }
@Test @Test