Loading src/com/android/settings/notification/app/SoundPreferenceController.java +2 −0 Original line number Diff line number Diff line Loading @@ -101,6 +101,8 @@ public class SoundPreferenceController extends NotificationPreferenceController public boolean handlePreferenceTreeClick(Preference preference) { if (KEY_SOUND.equals(preference.getKey()) && mFragment != null) { NotificationSoundPreference pref = (NotificationSoundPreference) preference; // default to notification pref.setRingtoneType(RingtoneManager.TYPE_NOTIFICATION); if (mChannel != null && mChannel.getAudioAttributes() != null) { if (USAGE_ALARM == mChannel.getAudioAttributes().getUsage()) { pref.setRingtoneType(RingtoneManager.TYPE_ALARM); Loading tests/robotests/src/com/android/settings/notification/app/SoundPreferenceControllerTest.java +20 −0 Original line number Diff line number Diff line Loading @@ -302,6 +302,26 @@ public class SoundPreferenceControllerTest { RingtoneManager.EXTRA_RINGTONE_TYPE, 0)); } @Test public void testOnPreferenceTreeClick_noAudioAttributes() { NotificationBackend.AppRow appRow = new NotificationBackend.AppRow(); NotificationChannel channel = new NotificationChannel("", "", IMPORTANCE_HIGH); channel.setSound(null, null); mController.onResume(appRow, channel, null, null, null, null, null); AttributeSet attributeSet = Robolectric.buildAttributeSet().build(); NotificationSoundPreference pref = spy(new NotificationSoundPreference(mContext, attributeSet)); pref.setKey(mController.getPreferenceKey()); mController.handlePreferenceTreeClick(pref); ArgumentCaptor<Intent> intentArgumentCaptor = ArgumentCaptor.forClass(Intent.class); verify(pref, times(1)).onPrepareRingtonePickerIntent(intentArgumentCaptor.capture()); assertEquals(RingtoneManager.TYPE_NOTIFICATION, intentArgumentCaptor.getValue().getIntExtra( RingtoneManager.EXTRA_RINGTONE_TYPE, 0)); } @Test public void testOnActivityResult() { NotificationSoundPreference pref = mock(NotificationSoundPreference.class); Loading Loading
src/com/android/settings/notification/app/SoundPreferenceController.java +2 −0 Original line number Diff line number Diff line Loading @@ -101,6 +101,8 @@ public class SoundPreferenceController extends NotificationPreferenceController public boolean handlePreferenceTreeClick(Preference preference) { if (KEY_SOUND.equals(preference.getKey()) && mFragment != null) { NotificationSoundPreference pref = (NotificationSoundPreference) preference; // default to notification pref.setRingtoneType(RingtoneManager.TYPE_NOTIFICATION); if (mChannel != null && mChannel.getAudioAttributes() != null) { if (USAGE_ALARM == mChannel.getAudioAttributes().getUsage()) { pref.setRingtoneType(RingtoneManager.TYPE_ALARM); Loading
tests/robotests/src/com/android/settings/notification/app/SoundPreferenceControllerTest.java +20 −0 Original line number Diff line number Diff line Loading @@ -302,6 +302,26 @@ public class SoundPreferenceControllerTest { RingtoneManager.EXTRA_RINGTONE_TYPE, 0)); } @Test public void testOnPreferenceTreeClick_noAudioAttributes() { NotificationBackend.AppRow appRow = new NotificationBackend.AppRow(); NotificationChannel channel = new NotificationChannel("", "", IMPORTANCE_HIGH); channel.setSound(null, null); mController.onResume(appRow, channel, null, null, null, null, null); AttributeSet attributeSet = Robolectric.buildAttributeSet().build(); NotificationSoundPreference pref = spy(new NotificationSoundPreference(mContext, attributeSet)); pref.setKey(mController.getPreferenceKey()); mController.handlePreferenceTreeClick(pref); ArgumentCaptor<Intent> intentArgumentCaptor = ArgumentCaptor.forClass(Intent.class); verify(pref, times(1)).onPrepareRingtonePickerIntent(intentArgumentCaptor.capture()); assertEquals(RingtoneManager.TYPE_NOTIFICATION, intentArgumentCaptor.getValue().getIntExtra( RingtoneManager.EXTRA_RINGTONE_TYPE, 0)); } @Test public void testOnActivityResult() { NotificationSoundPreference pref = mock(NotificationSoundPreference.class); Loading