summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--core/java/android/app/Notification.java30
-rwxr-xr-xservices/tests/uiservicestests/src/com/android/server/notification/NotificationManagerServiceTest.java51
2 files changed, 7 insertions, 74 deletions
diff --git a/core/java/android/app/Notification.java b/core/java/android/app/Notification.java
index 95feec6bde31..489c2e96e74b 100644
--- a/core/java/android/app/Notification.java
+++ b/core/java/android/app/Notification.java
@@ -2476,14 +2476,6 @@ public class Notification implements Parcelable
}
}
- private static void visitIconUri(@NonNull Consumer<Uri> visitor, @Nullable Icon icon) {
- if (icon == null) return;
- final int iconType = icon.getType();
- if (iconType == TYPE_URI || iconType == TYPE_URI_ADAPTIVE_BITMAP) {
- visitor.accept(icon.getUri());
- }
- }
-
/**
* Note all {@link Uri} that are referenced internally, with the expectation
* that Uri permission grants will need to be issued to ensure the recipient
@@ -2499,19 +2491,7 @@ public class Notification implements Parcelable
if (bigContentView != null) bigContentView.visitUris(visitor);
if (headsUpContentView != null) headsUpContentView.visitUris(visitor);
- visitIconUri(visitor, mSmallIcon);
- visitIconUri(visitor, mLargeIcon);
-
- if (actions != null) {
- for (Action action : actions) {
- visitIconUri(visitor, action.getIcon());
- }
- }
-
if (extras != null) {
- visitIconUri(visitor, extras.getParcelable(EXTRA_LARGE_ICON_BIG, Icon.class));
- visitIconUri(visitor, extras.getParcelable(EXTRA_PICTURE_ICON, Icon.class));
-
visitor.accept(extras.getParcelable(EXTRA_AUDIO_CONTENTS_URI));
if (extras.containsKey(EXTRA_BACKGROUND_IMAGE_URI)) {
visitor.accept(Uri.parse(extras.getString(EXTRA_BACKGROUND_IMAGE_URI)));
@@ -2569,12 +2549,14 @@ public class Notification implements Parcelable
}
}
}
-
- visitIconUri(visitor, extras.getParcelable(EXTRA_CONVERSATION_ICON));
}
- if (mBubbleMetadata != null) {
- visitIconUri(visitor, mBubbleMetadata.getIcon());
+ if (mBubbleMetadata != null && mBubbleMetadata.getIcon() != null) {
+ final Icon icon = mBubbleMetadata.getIcon();
+ final int iconType = icon.getType();
+ if (iconType == TYPE_URI_ADAPTIVE_BITMAP || iconType == TYPE_URI) {
+ visitor.accept(icon.getUri());
+ }
}
}
diff --git a/services/tests/uiservicestests/src/com/android/server/notification/NotificationManagerServiceTest.java b/services/tests/uiservicestests/src/com/android/server/notification/NotificationManagerServiceTest.java
index 2ecdc3d5f934..333c6f18e145 100755
--- a/services/tests/uiservicestests/src/com/android/server/notification/NotificationManagerServiceTest.java
+++ b/services/tests/uiservicestests/src/com/android/server/notification/NotificationManagerServiceTest.java
@@ -4268,8 +4268,6 @@ public class NotificationManagerServiceTest extends UiServiceTestCase {
public void testVisitUris() throws Exception {
final Uri audioContents = Uri.parse("content://com.example/audio");
final Uri backgroundImage = Uri.parse("content://com.example/background");
- final Icon smallIcon = Icon.createWithContentUri("content://media/small/icon");
- final Icon largeIcon = Icon.createWithContentUri("content://media/large/icon");
final Icon personIcon1 = Icon.createWithContentUri("content://media/person1");
final Icon personIcon2 = Icon.createWithContentUri("content://media/person2");
final Icon personIcon3 = Icon.createWithContentUri("content://media/person3");
@@ -4303,8 +4301,7 @@ public class NotificationManagerServiceTest extends UiServiceTestCase {
Notification n = new Notification.Builder(mContext, "a")
.setContentTitle("notification with uris")
- .setSmallIcon(smallIcon)
- .setLargeIcon(largeIcon)
+ .setSmallIcon(android.R.drawable.sym_def_app_icon)
.addExtras(extras)
.build();
@@ -4312,8 +4309,6 @@ public class NotificationManagerServiceTest extends UiServiceTestCase {
n.visitUris(visitor);
verify(visitor, times(1)).accept(eq(audioContents));
verify(visitor, times(1)).accept(eq(backgroundImage));
- verify(visitor, times(1)).accept(eq(smallIcon.getUri()));
- verify(visitor, times(1)).accept(eq(largeIcon.getUri()));
verify(visitor, times(1)).accept(eq(personIcon1.getUri()));
verify(visitor, times(1)).accept(eq(personIcon2.getUri()));
verify(visitor, times(1)).accept(eq(personIcon3.getUri()));
@@ -4322,50 +4317,6 @@ public class NotificationManagerServiceTest extends UiServiceTestCase {
}
@Test
- public void testVisitUris_messagingStyle() {
- final Icon personIcon1 = Icon.createWithContentUri("content://media/person1");
- final Icon personIcon2 = Icon.createWithContentUri("content://media/person2");
- final Icon personIcon3 = Icon.createWithContentUri("content://media/person3");
- final Person person1 = new Person.Builder()
- .setName("Messaging Person 1")
- .setIcon(personIcon1)
- .build();
- final Person person2 = new Person.Builder()
- .setName("Messaging Person 2")
- .setIcon(personIcon2)
- .build();
- final Person person3 = new Person.Builder()
- .setName("Messaging Person 3")
- .setIcon(personIcon3)
- .build();
- Icon shortcutIcon = Icon.createWithContentUri("content://media/shortcut");
-
- Notification.Builder builder = new Notification.Builder(mContext, "a")
- .setCategory(Notification.CATEGORY_MESSAGE)
- .setContentTitle("new message!")
- .setContentText("Conversation Notification")
- .setSmallIcon(android.R.drawable.sym_def_app_icon);
- Notification.MessagingStyle.Message message1 = new Notification.MessagingStyle.Message(
- "Marco?", System.currentTimeMillis(), person2);
- Notification.MessagingStyle.Message message2 = new Notification.MessagingStyle.Message(
- "Polo!", System.currentTimeMillis(), person3);
- Notification.MessagingStyle style = new Notification.MessagingStyle(person1)
- .addMessage(message1)
- .addMessage(message2)
- .setShortcutIcon(shortcutIcon);
- builder.setStyle(style);
- Notification n = builder.build();
-
- Consumer<Uri> visitor = (Consumer<Uri>) spy(Consumer.class);
- n.visitUris(visitor);
-
- verify(visitor, times(1)).accept(eq(shortcutIcon.getUri()));
- verify(visitor, times(1)).accept(eq(personIcon1.getUri()));
- verify(visitor, times(1)).accept(eq(personIcon2.getUri()));
- verify(visitor, times(1)).accept(eq(personIcon3.getUri()));
- }
-
- @Test
public void testSetNotificationPolicy_preP_setOldFields() {
ZenModeHelper mZenModeHelper = mock(ZenModeHelper.class);
mService.mZenModeHelper = mZenModeHelper;