From 76d9b5304880450f6d13c9fbb383bd14842acc06 Mon Sep 17 00:00:00 2001 From: Matthew Fritze Date: Thu, 11 May 2017 18:27:56 -0700 Subject: [PATCH] Remove Special App Access duplicate from Setting search Bug: 33701673 Test: make RunSettingsRoboTests Change-Id: I7f6a466c0551828c319c2da541fbeb0e428c62f8 --- .../AppAndNotificationDashboardFragment.java | 8 +++ ...pAndNotificationDashboardFragmentTest.java | 56 +++++++++++++++++++ 2 files changed, 64 insertions(+) create mode 100644 tests/robotests/src/com/android/settings/applications/AppAndNotificationDashboardFragmentTest.java diff --git a/src/com/android/settings/applications/AppAndNotificationDashboardFragment.java b/src/com/android/settings/applications/AppAndNotificationDashboardFragment.java index 249947839b7..63e8be75f93 100644 --- a/src/com/android/settings/applications/AppAndNotificationDashboardFragment.java +++ b/src/com/android/settings/applications/AppAndNotificationDashboardFragment.java @@ -82,5 +82,13 @@ public class AppAndNotificationDashboardFragment extends DashboardFragment { public List getPreferenceControllers(Context context) { return buildPreferenceControllers(context); } + + @Override + public List getNonIndexableKeys(Context context) { + List keys = super.getNonIndexableKeys(context); + keys.add((new SpecialAppAccessPreferenceController(context)) + .getPreferenceKey()); + return keys; + } }; } diff --git a/tests/robotests/src/com/android/settings/applications/AppAndNotificationDashboardFragmentTest.java b/tests/robotests/src/com/android/settings/applications/AppAndNotificationDashboardFragmentTest.java new file mode 100644 index 00000000000..32b447a5bc9 --- /dev/null +++ b/tests/robotests/src/com/android/settings/applications/AppAndNotificationDashboardFragmentTest.java @@ -0,0 +1,56 @@ +/* + * Copyright (C) 2017 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.applications; + +import android.content.Context; + +import android.os.UserManager; +import com.android.settings.SettingsRobolectricTestRunner; +import com.android.settings.TestConfig; +import com.android.settings.testutils.XmlTestUtils; + +import org.junit.Test; +import org.junit.runner.RunWith; +import org.robolectric.RuntimeEnvironment; +import org.robolectric.annotation.Config; + +import java.util.List; + +import static com.google.common.truth.Truth.assertThat; +import static org.mockito.Mockito.mock; +import static org.mockito.Mockito.spy; +import static org.mockito.Mockito.when; + +@RunWith(SettingsRobolectricTestRunner.class) +@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION) +public class AppAndNotificationDashboardFragmentTest { + + @Test + public void testNonIndexableKeys_existInXmlLayout() { + final Context context = spy(RuntimeEnvironment.application); + UserManager manager = mock(UserManager.class); + when(manager.isAdminUser()).thenReturn(true); + when(context.getSystemService(Context.USER_SERVICE)).thenReturn(manager); + final List niks = AppAndNotificationDashboardFragment.SEARCH_INDEX_DATA_PROVIDER + .getNonIndexableKeys(context); + final int xmlId = (new AppAndNotificationDashboardFragment()).getPreferenceScreenResId(); + + final List keys = XmlTestUtils.getKeysFromPreferenceXml(context, xmlId); + + assertThat(keys).containsAllIn(niks); + } +}