Add ability to show/hide Wi-Fi settings, and all related sub-settings.
This adds a new boolean flag, config_show_wifi_settings, which when set to false will hide the "Wi-Fi" page in network & internet (there is no key value associated with this preference page). It will also hide nested pages from search results, such as Wi-Fi preferences. Bug: 62379554 Test: make RunSettingsRoboTests ROBOTEST_FILTER=ConfigureWifiSettingsTest and make RunSettingsRoboTests ROBOTEST_FILTER=WifiSettingsTest and make RunSettingsRoboTests ROBOTEST_FILTER=WifiMasterSwitchPreferenceControllerTest all pass. Change-Id: Iedc6bc272e0cb2b561c6bf25968e70f355aaaa8e
This commit is contained in:
@@ -49,6 +49,11 @@
|
|||||||
<!--Whether help links are defined. -->
|
<!--Whether help links are defined. -->
|
||||||
<bool name="config_has_help">false</bool>
|
<bool name="config_has_help">false</bool>
|
||||||
|
|
||||||
|
<!-- Whether Wi-Fi settings should be shown or not.
|
||||||
|
This also controls whether Wi-fi related sub-settings (e.g. Wi-Fi preferences) will
|
||||||
|
surface in search results or not.-->
|
||||||
|
<bool name="config_show_wifi_settings">true</bool>
|
||||||
|
|
||||||
<!-- Whether location mode is available or not. -->
|
<!-- Whether location mode is available or not. -->
|
||||||
<bool name="config_location_mode_available">true</bool>
|
<bool name="config_location_mode_available">true</bool>
|
||||||
|
|
||||||
|
@@ -44,6 +44,7 @@ public class ConfigureWifiSettings extends DashboardFragment {
|
|||||||
|
|
||||||
private static final String TAG = "ConfigureWifiSettings";
|
private static final String TAG = "ConfigureWifiSettings";
|
||||||
|
|
||||||
|
public static final String KEY_WIFI_CONFIGURE = "wifi_configure_settings_screen";
|
||||||
public static final String KEY_IP_ADDRESS = "current_ip_address";
|
public static final String KEY_IP_ADDRESS = "current_ip_address";
|
||||||
|
|
||||||
private WifiWakeupPreferenceController mWifiWakeupPreferenceController;
|
private WifiWakeupPreferenceController mWifiWakeupPreferenceController;
|
||||||
@@ -134,5 +135,10 @@ public class ConfigureWifiSettings extends DashboardFragment {
|
|||||||
|
|
||||||
return keys;
|
return keys;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected boolean isPageSearchEnabled(Context context) {
|
||||||
|
return context.getResources()
|
||||||
|
.getBoolean(R.bool.config_show_wifi_settings);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@@ -20,6 +20,7 @@ import android.support.v7.preference.PreferenceScreen;
|
|||||||
|
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
import com.android.settings.core.instrumentation.MetricsFeatureProvider;
|
||||||
|
import com.android.settings.R;
|
||||||
import com.android.settings.widget.SummaryUpdater;
|
import com.android.settings.widget.SummaryUpdater;
|
||||||
import com.android.settings.widget.MasterSwitchPreference;
|
import com.android.settings.widget.MasterSwitchPreference;
|
||||||
import com.android.settings.widget.MasterSwitchController;
|
import com.android.settings.widget.MasterSwitchController;
|
||||||
@@ -56,7 +57,7 @@ public class WifiMasterSwitchPreferenceController extends AbstractPreferenceCont
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isAvailable() {
|
public boolean isAvailable() {
|
||||||
return true;
|
return mContext.getResources().getBoolean(R.bool.config_show_wifi_settings);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -167,7 +167,7 @@ public class WifiSettings extends RestrictedSettingsFragment
|
|||||||
private LinkablePreference mStatusMessagePreference;
|
private LinkablePreference mStatusMessagePreference;
|
||||||
|
|
||||||
// For Search
|
// For Search
|
||||||
private static final String DATA_KEY_REFERENCE = "main_toggle_wifi";
|
public static final String DATA_KEY_REFERENCE = "main_toggle_wifi";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tracks whether the user initiated a connection via clicking in order to autoscroll to the
|
* Tracks whether the user initiated a connection via clicking in order to autoscroll to the
|
||||||
@@ -1104,13 +1104,15 @@ public class WifiSettings extends RestrictedSettingsFragment
|
|||||||
final List<SearchIndexableRaw> result = new ArrayList<>();
|
final List<SearchIndexableRaw> result = new ArrayList<>();
|
||||||
final Resources res = context.getResources();
|
final Resources res = context.getResources();
|
||||||
|
|
||||||
// Add fragment title
|
// Add fragment title if we are showing this fragment
|
||||||
SearchIndexableRaw data = new SearchIndexableRaw(context);
|
if (res.getBoolean(R.bool.config_show_wifi_settings)) {
|
||||||
data.title = res.getString(R.string.wifi_settings);
|
SearchIndexableRaw data = new SearchIndexableRaw(context);
|
||||||
data.screenTitle = res.getString(R.string.wifi_settings);
|
data.title = res.getString(R.string.wifi_settings);
|
||||||
data.keywords = res.getString(R.string.keywords_wifi);
|
data.screenTitle = res.getString(R.string.wifi_settings);
|
||||||
data.key = DATA_KEY_REFERENCE;
|
data.keywords = res.getString(R.string.keywords_wifi);
|
||||||
result.add(data);
|
data.key = DATA_KEY_REFERENCE;
|
||||||
|
result.add(data);
|
||||||
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@@ -20,6 +20,7 @@
|
|||||||
<bool name="config_show_camera_laser_sensor">false</bool>
|
<bool name="config_show_camera_laser_sensor">false</bool>
|
||||||
<bool name="config_show_connectivity_monitor">false</bool>
|
<bool name="config_show_connectivity_monitor">false</bool>
|
||||||
<bool name="config_display_recent_apps">false</bool>
|
<bool name="config_display_recent_apps">false</bool>
|
||||||
|
<bool name="config_show_wifi_settings">false</bool>
|
||||||
<bool name="config_location_mode_available">false</bool>
|
<bool name="config_location_mode_available">false</bool>
|
||||||
<bool name="config_show_wallpaper_attribution">false</bool>
|
<bool name="config_show_wallpaper_attribution">false</bool>
|
||||||
<bool name="config_show_default_home">false</bool>
|
<bool name="config_show_default_home">false</bool>
|
||||||
|
@@ -44,6 +44,17 @@ public class ConfigureWifiSettingsTest {
|
|||||||
assertThat(keys).containsAllIn(niks);
|
assertThat(keys).containsAllIn(niks);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(qualifiers = "mcc999")
|
||||||
|
public void testNonIndexableKeys_ifPageDisabled_shouldNotIndexResource() {
|
||||||
|
final List<String> niks = ConfigureWifiSettings.SEARCH_INDEX_DATA_PROVIDER
|
||||||
|
.getNonIndexableKeys(mContext);
|
||||||
|
final int xmlId = new ConfigureWifiSettings().getPreferenceScreenResId();
|
||||||
|
|
||||||
|
final List<String> keys = XmlTestUtils.getKeysFromPreferenceXml(mContext, xmlId);
|
||||||
|
assertThat(niks).containsAllIn(keys);
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testNonIndexableKeys_noConnection_blocksIP() {
|
public void testNonIndexableKeys_noConnection_blocksIP() {
|
||||||
ConnectivityManager manager = mock(ConnectivityManager.class);
|
ConnectivityManager manager = mock(ConnectivityManager.class);
|
||||||
|
@@ -72,10 +72,17 @@ public class WifiMasterSwitchPreferenceControllerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void isAvailable_shouldAlwaysReturnTrue() {
|
public void testWifiMasterSwitch_byDefault_shouldBeShown() {
|
||||||
assertThat(mController.isAvailable()).isTrue();
|
assertThat(mController.isAvailable()).isTrue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(qualifiers = "mcc999")
|
||||||
|
public void testWifiMasterSwitch_ifDisabled_shouldNotBeShown() {
|
||||||
|
assertThat(mController.isAvailable()).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void onResume_shouldRegisterCallback() {
|
public void onResume_shouldRegisterCallback() {
|
||||||
mController.onResume();
|
mController.onResume();
|
||||||
|
@@ -0,0 +1,68 @@
|
|||||||
|
/*
|
||||||
|
* 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.wifi;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import com.android.settings.TestConfig;
|
||||||
|
import com.android.settings.search.SearchIndexableRaw;
|
||||||
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
|
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import org.mockito.MockitoAnnotations;
|
||||||
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.annotation.Config;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@RunWith(SettingsRobolectricTestRunner.class)
|
||||||
|
@Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION)
|
||||||
|
public class WifiSettingsTest {
|
||||||
|
|
||||||
|
private Context mContext;
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
MockitoAnnotations.initMocks(this);
|
||||||
|
mContext = spy(RuntimeEnvironment.application);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testSearchIndexProvider_shouldIndexFragmentTitle() {
|
||||||
|
final List<SearchIndexableRaw> indexRes =
|
||||||
|
WifiSettings.SEARCH_INDEX_DATA_PROVIDER.getRawDataToIndex(mContext,
|
||||||
|
true /* enabled */);
|
||||||
|
|
||||||
|
assertThat(indexRes).isNotNull();
|
||||||
|
assertThat(indexRes.get(0).key).isEqualTo(WifiSettings.DATA_KEY_REFERENCE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@Config(qualifiers = "mcc999")
|
||||||
|
public void testSearchIndexProvider_ifWifiSettingsNotVisible_shouldNotIndexFragmentTitle() {
|
||||||
|
final List<SearchIndexableRaw> indexRes =
|
||||||
|
WifiSettings.SEARCH_INDEX_DATA_PROVIDER.getRawDataToIndex(mContext,
|
||||||
|
true /* enabled */);
|
||||||
|
|
||||||
|
assertThat(indexRes).isEmpty();
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user