Remove networkScorer wrapper
Also modified NetworkScorerPickerPreferenceController to register itself in xml directily Bug: 76167422 Test: robotests Change-Id: I4a216b5e6845aecd6aaeed0ed9b3e06c9e0fc590
This commit is contained in:
@@ -56,7 +56,8 @@
|
|||||||
<Preference
|
<Preference
|
||||||
android:key="network_scorer_picker"
|
android:key="network_scorer_picker"
|
||||||
android:title="@string/network_scorer_picker_title"
|
android:title="@string/network_scorer_picker_title"
|
||||||
android:fragment="com.android.settings.network.NetworkScorerPicker"/>
|
android:fragment="com.android.settings.network.NetworkScorerPicker"
|
||||||
|
settings:controller="com.android.settings.network.NetworkScorerPickerPreferenceController" />
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="wifi_direct"
|
android:key="wifi_direct"
|
||||||
|
@@ -26,11 +26,11 @@ import android.text.TextUtils;
|
|||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto;
|
import com.android.internal.logging.nano.MetricsProto;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.InstrumentedPreferenceFragment;
|
import com.android.settings.core.InstrumentedPreferenceFragment;
|
||||||
import com.android.settings.widget.RadioButtonPreference;
|
import com.android.settings.widget.RadioButtonPreference;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@@ -40,7 +40,7 @@ import java.util.List;
|
|||||||
public class NetworkScorerPicker extends InstrumentedPreferenceFragment implements
|
public class NetworkScorerPicker extends InstrumentedPreferenceFragment implements
|
||||||
RadioButtonPreference.OnClickListener {
|
RadioButtonPreference.OnClickListener {
|
||||||
|
|
||||||
private NetworkScoreManagerWrapper mNetworkScoreManager;
|
private NetworkScoreManager mNetworkScoreManager;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getMetricsCategory() {
|
public int getMetricsCategory() {
|
||||||
@@ -56,7 +56,7 @@ public class NetworkScorerPicker extends InstrumentedPreferenceFragment implemen
|
|||||||
@Override
|
@Override
|
||||||
public void onAttach(Context context) {
|
public void onAttach(Context context) {
|
||||||
super.onAttach(context);
|
super.onAttach(context);
|
||||||
mNetworkScoreManager = createNetworkScorerManagerWrapper(context);
|
mNetworkScoreManager = createNetworkScorerManager(context);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -138,7 +138,7 @@ public class NetworkScorerPicker extends InstrumentedPreferenceFragment implemen
|
|||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@VisibleForTesting
|
||||||
NetworkScoreManagerWrapper createNetworkScorerManagerWrapper(Context context) {
|
NetworkScoreManager createNetworkScorerManager(Context context) {
|
||||||
return new NetworkScoreManagerWrapper(context.getSystemService(NetworkScoreManager.class));
|
return (NetworkScoreManager) context.getSystemService(Context.NETWORK_SCORE_SERVICE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,12 +16,12 @@
|
|||||||
package com.android.settings.network;
|
package com.android.settings.network;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.net.NetworkScoreManager;
|
||||||
import android.net.NetworkScorerAppData;
|
import android.net.NetworkScorerAppData;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -30,22 +30,19 @@ import java.util.List;
|
|||||||
* {@link AbstractPreferenceController} that shows the active network scorer and toggles the
|
* {@link AbstractPreferenceController} that shows the active network scorer and toggles the
|
||||||
* preference based on whether or not there are valid scorers installed.
|
* preference based on whether or not there are valid scorers installed.
|
||||||
*/
|
*/
|
||||||
public class NetworkScorerPickerPreferenceController extends AbstractPreferenceController
|
public class NetworkScorerPickerPreferenceController extends BasePreferenceController {
|
||||||
implements PreferenceControllerMixin {
|
|
||||||
|
|
||||||
private static final String KEY_NETWORK_SCORER_PICKER = "network_scorer_picker";
|
private final NetworkScoreManager mNetworkScoreManager;
|
||||||
|
|
||||||
private final NetworkScoreManagerWrapper mNetworkScoreManager;
|
public NetworkScorerPickerPreferenceController(Context context, String key) {
|
||||||
|
super(context, key);
|
||||||
public NetworkScorerPickerPreferenceController(Context context,
|
mNetworkScoreManager =
|
||||||
NetworkScoreManagerWrapper networkScoreManager) {
|
(NetworkScoreManager) mContext.getSystemService(Context.NETWORK_SCORE_SERVICE);
|
||||||
super(context);
|
|
||||||
mNetworkScoreManager = networkScoreManager;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getPreferenceKey() {
|
public int getAvailabilityStatus() {
|
||||||
return KEY_NETWORK_SCORER_PICKER;
|
return AVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -67,9 +64,4 @@ public class NetworkScorerPickerPreferenceController extends AbstractPreferenceC
|
|||||||
preference.setSummary(scorer.getRecommendationServiceLabel());
|
preference.setSummary(scorer.getRecommendationServiceLabel());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public boolean isAvailable() {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@@ -21,18 +21,15 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
import android.net.NetworkScoreManager;
|
|
||||||
import android.net.wifi.WifiManager;
|
import android.net.wifi.WifiManager;
|
||||||
import android.provider.SearchIndexableResource;
|
import android.provider.SearchIndexableResource;
|
||||||
|
|
||||||
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
import com.android.internal.logging.nano.MetricsProto.MetricsEvent;
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.network.NetworkScorerPickerPreferenceController;
|
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
import com.android.settings.search.Indexable;
|
import com.android.settings.search.Indexable;
|
||||||
import com.android.settings.wifi.p2p.WifiP2pPreferenceController;
|
import com.android.settings.wifi.p2p.WifiP2pPreferenceController;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -74,16 +71,12 @@ public class ConfigureWifiSettings extends DashboardFragment {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
||||||
final NetworkScoreManagerWrapper networkScoreManagerWrapper =
|
|
||||||
new NetworkScoreManagerWrapper(context.getSystemService(NetworkScoreManager.class));
|
|
||||||
mWifiWakeupPreferenceController = new WifiWakeupPreferenceController(context);
|
mWifiWakeupPreferenceController = new WifiWakeupPreferenceController(context);
|
||||||
mUseOpenWifiPreferenceController = new UseOpenWifiPreferenceController(context, this,
|
mUseOpenWifiPreferenceController = new UseOpenWifiPreferenceController(context, this,
|
||||||
networkScoreManagerWrapper, getLifecycle());
|
getLifecycle());
|
||||||
final WifiManager wifiManager = (WifiManager) getSystemService(WIFI_SERVICE);
|
final WifiManager wifiManager = (WifiManager) getSystemService(WIFI_SERVICE);
|
||||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
||||||
controllers.add(mWifiWakeupPreferenceController);
|
controllers.add(mWifiWakeupPreferenceController);
|
||||||
controllers.add(new NetworkScorerPickerPreferenceController(context,
|
|
||||||
networkScoreManagerWrapper));
|
|
||||||
controllers.add(new NotifyOpenNetworksPreferenceController(context, getLifecycle()));
|
controllers.add(new NotifyOpenNetworksPreferenceController(context, getLifecycle()));
|
||||||
controllers.add(mUseOpenWifiPreferenceController);
|
controllers.add(mUseOpenWifiPreferenceController);
|
||||||
controllers.add(new WifiInfoPreferenceController(context, getLifecycle(), wifiManager));
|
controllers.add(new WifiInfoPreferenceController(context, getLifecycle(), wifiManager));
|
||||||
|
@@ -21,7 +21,6 @@ import android.text.TextUtils;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
||||||
@@ -38,11 +37,12 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener,
|
implements PreferenceControllerMixin, Preference.OnPreferenceChangeListener,
|
||||||
LifecycleObserver, OnResume, OnPause {
|
LifecycleObserver, OnResume, OnPause {
|
||||||
private static final String KEY_USE_OPEN_WIFI_AUTOMATICALLY = "use_open_wifi_automatically";
|
private static final String KEY_USE_OPEN_WIFI_AUTOMATICALLY = "use_open_wifi_automatically";
|
||||||
@VisibleForTesting static final int REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY = 400;
|
@VisibleForTesting
|
||||||
|
static final int REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY = 400;
|
||||||
|
|
||||||
private final ContentResolver mContentResolver;
|
private final ContentResolver mContentResolver;
|
||||||
private final Fragment mFragment;
|
private final Fragment mFragment;
|
||||||
private final NetworkScoreManagerWrapper mNetworkScoreManagerWrapper;
|
private final NetworkScoreManager mNetworkScoreManager;
|
||||||
private final SettingObserver mSettingObserver;
|
private final SettingObserver mSettingObserver;
|
||||||
|
|
||||||
private Preference mPreference;
|
private Preference mPreference;
|
||||||
@@ -50,11 +50,12 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
private boolean mDoFeatureSupportedScorersExist;
|
private boolean mDoFeatureSupportedScorersExist;
|
||||||
|
|
||||||
public UseOpenWifiPreferenceController(Context context, Fragment fragment,
|
public UseOpenWifiPreferenceController(Context context, Fragment fragment,
|
||||||
NetworkScoreManagerWrapper networkScoreManagerWrapper, Lifecycle lifecycle) {
|
Lifecycle lifecycle) {
|
||||||
super(context);
|
super(context);
|
||||||
mContentResolver = context.getContentResolver();
|
mContentResolver = context.getContentResolver();
|
||||||
mFragment = fragment;
|
mFragment = fragment;
|
||||||
mNetworkScoreManagerWrapper = networkScoreManagerWrapper;
|
mNetworkScoreManager =
|
||||||
|
(NetworkScoreManager) context.getSystemService(Context.NETWORK_SCORE_SERVICE);
|
||||||
mSettingObserver = new SettingObserver();
|
mSettingObserver = new SettingObserver();
|
||||||
updateEnableUseWifiComponentName();
|
updateEnableUseWifiComponentName();
|
||||||
checkForFeatureSupportedScorers();
|
checkForFeatureSupportedScorers();
|
||||||
@@ -62,7 +63,7 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void updateEnableUseWifiComponentName() {
|
private void updateEnableUseWifiComponentName() {
|
||||||
NetworkScorerAppData appData = mNetworkScoreManagerWrapper.getActiveScorer();
|
NetworkScorerAppData appData = mNetworkScoreManager.getActiveScorer();
|
||||||
mEnableUseWifiComponentName =
|
mEnableUseWifiComponentName =
|
||||||
appData == null ? null : appData.getEnableUseOpenWifiActivity();
|
appData == null ? null : appData.getEnableUseOpenWifiActivity();
|
||||||
}
|
}
|
||||||
@@ -72,7 +73,7 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
mDoFeatureSupportedScorersExist = true;
|
mDoFeatureSupportedScorersExist = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
List<NetworkScorerAppData> scorers = mNetworkScoreManagerWrapper.getAllValidScorers();
|
List<NetworkScorerAppData> scorers = mNetworkScoreManager.getAllValidScorers();
|
||||||
for (NetworkScorerAppData scorer : scorers) {
|
for (NetworkScorerAppData scorer : scorers) {
|
||||||
if (scorer.getEnableUseOpenWifiActivity() != null) {
|
if (scorer.getEnableUseOpenWifiActivity() != null) {
|
||||||
mDoFeatureSupportedScorersExist = true;
|
mDoFeatureSupportedScorersExist = true;
|
||||||
@@ -115,7 +116,7 @@ public class UseOpenWifiPreferenceController extends AbstractPreferenceControlle
|
|||||||
}
|
}
|
||||||
final SwitchPreference useOpenWifiPreference = (SwitchPreference) preference;
|
final SwitchPreference useOpenWifiPreference = (SwitchPreference) preference;
|
||||||
|
|
||||||
boolean isScorerSet = mNetworkScoreManagerWrapper.getActiveScorerPackage() != null;
|
boolean isScorerSet = mNetworkScoreManager.getActiveScorerPackage() != null;
|
||||||
boolean doesActiveScorerSupportFeature = mEnableUseWifiComponentName != null;
|
boolean doesActiveScorerSupportFeature = mEnableUseWifiComponentName != null;
|
||||||
|
|
||||||
useOpenWifiPreference.setChecked(isSettingEnabled());
|
useOpenWifiPreference.setChecked(isSettingEnabled());
|
||||||
|
@@ -16,11 +16,7 @@
|
|||||||
|
|
||||||
package com.android.settings.wifi;
|
package com.android.settings.wifi;
|
||||||
|
|
||||||
import android.content.ContentResolver;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.database.ContentObserver;
|
|
||||||
import android.net.Uri;
|
|
||||||
import android.os.Handler;
|
|
||||||
import android.provider.Settings;
|
import android.provider.Settings;
|
||||||
import android.support.v14.preference.SwitchPreference;
|
import android.support.v14.preference.SwitchPreference;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
@@ -29,7 +25,6 @@ import android.text.TextUtils;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.core.PreferenceControllerMixin;
|
import com.android.settings.core.PreferenceControllerMixin;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
import com.android.settingslib.core.AbstractPreferenceController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -1,80 +0,0 @@
|
|||||||
/*
|
|
||||||
* 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.wrapper;
|
|
||||||
|
|
||||||
import android.annotation.Nullable;
|
|
||||||
import android.net.NetworkScoreManager;
|
|
||||||
import android.net.NetworkScorerAppData;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Wrapper around {@link NetworkScoreManager} to facilitate unit testing.
|
|
||||||
*
|
|
||||||
* TODO: delete this class once robolectric supports Android O
|
|
||||||
*/
|
|
||||||
public class NetworkScoreManagerWrapper {
|
|
||||||
private final NetworkScoreManager mNetworkScoreManager;
|
|
||||||
|
|
||||||
public NetworkScoreManagerWrapper(NetworkScoreManager networkScoreManager) {
|
|
||||||
mNetworkScoreManager = networkScoreManager;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the list of available scorer apps. The list will be empty if there are
|
|
||||||
* no valid scorers.
|
|
||||||
*/
|
|
||||||
public List<NetworkScorerAppData> getAllValidScorers() {
|
|
||||||
return mNetworkScoreManager.getAllValidScorers();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Obtain the package name of the current active network scorer.
|
|
||||||
*
|
|
||||||
* <p>At any time, only one scorer application will receive {@link #ACTION_SCORE_NETWORKS}
|
|
||||||
* broadcasts and be allowed to call {@link #updateScores}. Applications may use this method to
|
|
||||||
* determine the current scorer and offer the user the ability to select a different scorer via
|
|
||||||
* the {@link #ACTION_CHANGE_ACTIVE} intent.
|
|
||||||
* @return the full package name of the current active scorer, or null if there is no active
|
|
||||||
* scorer.
|
|
||||||
*/
|
|
||||||
@Nullable
|
|
||||||
public String getActiveScorerPackage() {
|
|
||||||
return mNetworkScoreManager.getActiveScorerPackage();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns metadata about the active scorer or <code>null</code> if there is no active scorer.
|
|
||||||
*/
|
|
||||||
@Nullable
|
|
||||||
public NetworkScorerAppData getActiveScorer() {
|
|
||||||
return mNetworkScoreManager.getActiveScorer();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the active scorer to a new package and clear existing scores.
|
|
||||||
*
|
|
||||||
* <p>Should never be called directly without obtaining user consent. This can be done by using
|
|
||||||
* the {@link #ACTION_CHANGE_ACTIVE} broadcast, or using a custom configuration activity.
|
|
||||||
*
|
|
||||||
* @return true if the operation succeeded, or false if the new package is not a valid scorer.
|
|
||||||
* @throws SecurityException if the caller is not a system process or does not hold the
|
|
||||||
* {@link android.Manifest.permission#REQUEST_NETWORK_SCORES} permission
|
|
||||||
*/
|
|
||||||
public boolean setActiveScorer(String packageName) throws SecurityException {
|
|
||||||
return mNetworkScoreManager.setActiveScorer(packageName);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -23,12 +23,12 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.net.NetworkScoreManager;
|
||||||
import android.net.NetworkScorerAppData;
|
import android.net.NetworkScorerAppData;
|
||||||
import android.support.v7.preference.Preference;
|
import android.support.v7.preference.Preference;
|
||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
@@ -36,6 +36,7 @@ import org.junit.runner.RunWith;
|
|||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.util.ReflectionHelpers;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
|
||||||
@@ -48,14 +49,15 @@ public class NetworkScorerPickerPreferenceControllerTest {
|
|||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@Mock
|
@Mock
|
||||||
private NetworkScoreManagerWrapper mNetworkScorer;
|
private NetworkScoreManager mNetworkScorer;
|
||||||
private NetworkScorerPickerPreferenceController mController;
|
private NetworkScorerPickerPreferenceController mController;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() {
|
public void setUp() {
|
||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
mController = new NetworkScorerPickerPreferenceController(mContext, mNetworkScorer);
|
mController = new NetworkScorerPickerPreferenceController(mContext, "test_key");
|
||||||
|
ReflectionHelpers.setField(mController, "mNetworkScoreManager", mNetworkScorer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@@ -26,6 +26,7 @@ import static org.mockito.Mockito.when;
|
|||||||
|
|
||||||
import android.content.ComponentName;
|
import android.content.ComponentName;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.net.NetworkScoreManager;
|
||||||
import android.net.NetworkScorerAppData;
|
import android.net.NetworkScorerAppData;
|
||||||
import android.support.v7.preference.PreferenceManager;
|
import android.support.v7.preference.PreferenceManager;
|
||||||
import android.support.v7.preference.PreferenceScreen;
|
import android.support.v7.preference.PreferenceScreen;
|
||||||
@@ -33,7 +34,7 @@ import android.support.v7.preference.PreferenceScreen;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.widget.RadioButtonPreference;
|
import com.android.settings.widget.RadioButtonPreference;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
import com.google.android.collect.Lists;
|
import com.google.android.collect.Lists;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -56,7 +57,7 @@ public class NetworkScorerPickerTest {
|
|||||||
|
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@Mock
|
@Mock
|
||||||
private NetworkScoreManagerWrapper mNetworkScoreManager;
|
private NetworkScoreManager mNetworkScoreManager;
|
||||||
@Mock
|
@Mock
|
||||||
private PreferenceScreen mPreferenceScreen;
|
private PreferenceScreen mPreferenceScreen;
|
||||||
|
|
||||||
@@ -169,13 +170,13 @@ public class NetworkScorerPickerTest {
|
|||||||
private final Context mContext;
|
private final Context mContext;
|
||||||
private final PreferenceScreen mScreen;
|
private final PreferenceScreen mScreen;
|
||||||
private final PreferenceManager mPrefManager;
|
private final PreferenceManager mPrefManager;
|
||||||
private final NetworkScoreManagerWrapper mNetworkScoreManagerWrapper;
|
private final NetworkScoreManager mNetworkScoreManager;
|
||||||
|
|
||||||
public TestFragment(Context context, PreferenceScreen preferenceScreen,
|
public TestFragment(Context context, PreferenceScreen preferenceScreen,
|
||||||
NetworkScoreManagerWrapper networkScoreManagerWrapper) {
|
NetworkScoreManager networkScoreManager) {
|
||||||
mContext = context;
|
mContext = context;
|
||||||
mScreen = preferenceScreen;
|
mScreen = preferenceScreen;
|
||||||
mNetworkScoreManagerWrapper = networkScoreManagerWrapper;
|
mNetworkScoreManager = networkScoreManager;
|
||||||
mPrefManager = mock(PreferenceManager.class);
|
mPrefManager = mock(PreferenceManager.class);
|
||||||
when(mPrefManager.getContext()).thenReturn(context);
|
when(mPrefManager.getContext()).thenReturn(context);
|
||||||
}
|
}
|
||||||
@@ -196,8 +197,8 @@ public class NetworkScorerPickerTest {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
NetworkScoreManagerWrapper createNetworkScorerManagerWrapper(Context context) {
|
NetworkScoreManager createNetworkScorerManager(Context context) {
|
||||||
return mNetworkScoreManagerWrapper;
|
return mNetworkScoreManager;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -16,8 +16,10 @@
|
|||||||
|
|
||||||
package com.android.settings.wifi;
|
package com.android.settings.wifi;
|
||||||
|
|
||||||
|
import static android.content.Context.NETWORK_SCORE_SERVICE;
|
||||||
import static android.provider.Settings.Global.USE_OPEN_WIFI_PACKAGE;
|
import static android.provider.Settings.Global.USE_OPEN_WIFI_PACKAGE;
|
||||||
import static com.android.settings.wifi.UseOpenWifiPreferenceController.REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY;
|
import static com.android.settings.wifi.UseOpenWifiPreferenceController
|
||||||
|
.REQUEST_CODE_OPEN_WIFI_AUTOMATICALLY;
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static org.mockito.Matchers.eq;
|
import static org.mockito.Matchers.eq;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
@@ -38,8 +40,8 @@ import android.support.v7.preference.Preference;
|
|||||||
|
|
||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
import com.android.settings.testutils.SettingsRobolectricTestRunner;
|
||||||
import com.android.settings.wrapper.NetworkScoreManagerWrapper;
|
|
||||||
import com.android.settingslib.core.lifecycle.Lifecycle;
|
import com.android.settingslib.core.lifecycle.Lifecycle;
|
||||||
|
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
@@ -51,6 +53,7 @@ import org.mockito.Captor;
|
|||||||
import org.mockito.Mock;
|
import org.mockito.Mock;
|
||||||
import org.mockito.MockitoAnnotations;
|
import org.mockito.MockitoAnnotations;
|
||||||
import org.robolectric.RuntimeEnvironment;
|
import org.robolectric.RuntimeEnvironment;
|
||||||
|
import org.robolectric.shadows.ShadowApplication;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -74,7 +77,7 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
@Mock
|
@Mock
|
||||||
private Fragment mFragment;
|
private Fragment mFragment;
|
||||||
@Mock
|
@Mock
|
||||||
private NetworkScoreManagerWrapper mNetworkScoreManagerWrapper;
|
private NetworkScoreManager mNetworkScoreManager;
|
||||||
@Captor
|
@Captor
|
||||||
private ArgumentCaptor<Intent> mIntentCaptor;
|
private ArgumentCaptor<Intent> mIntentCaptor;
|
||||||
private Context mContext;
|
private Context mContext;
|
||||||
@@ -85,23 +88,25 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
MockitoAnnotations.initMocks(this);
|
MockitoAnnotations.initMocks(this);
|
||||||
|
|
||||||
mContext = RuntimeEnvironment.application;
|
mContext = RuntimeEnvironment.application;
|
||||||
|
ShadowApplication.getInstance()
|
||||||
|
.setSystemService(NETWORK_SCORE_SERVICE, mNetworkScoreManager);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void createController() {
|
private void createController() {
|
||||||
mController = new UseOpenWifiPreferenceController(
|
mController = new UseOpenWifiPreferenceController(mContext, mFragment, mLifecycle);
|
||||||
mContext, mFragment, mNetworkScoreManagerWrapper, mLifecycle);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the scorers.
|
* Sets the scorers.
|
||||||
|
*
|
||||||
* @param scorers list of scorers returned by {@link NetworkScoreManager#getAllValidScorers()}.
|
* @param scorers list of scorers returned by {@link NetworkScoreManager#getAllValidScorers()}.
|
||||||
* First scorer in the list is the active scorer.
|
* First scorer in the list is the active scorer.
|
||||||
*/
|
*/
|
||||||
private void setupScorers(@NonNull List<NetworkScorerAppData> scorers) {
|
private void setupScorers(@NonNull List<NetworkScorerAppData> scorers) {
|
||||||
when(mNetworkScoreManagerWrapper.getActiveScorerPackage())
|
when(mNetworkScoreManager.getActiveScorerPackage())
|
||||||
.thenReturn(sEnableActivityComponent.getPackageName());
|
.thenReturn(sEnableActivityComponent.getPackageName());
|
||||||
when(mNetworkScoreManagerWrapper.getAllValidScorers()).thenReturn(scorers);
|
when(mNetworkScoreManager.getAllValidScorers()).thenReturn(scorers);
|
||||||
when(mNetworkScoreManagerWrapper.getActiveScorer()).thenReturn(scorers.get(0));
|
when(mNetworkScoreManager.getActiveScorer()).thenReturn(scorers.get(0));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
@@ -130,7 +135,7 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
@Test
|
@Test
|
||||||
public void testIsAvailable_returnsTrueIfNonActiveScorerSupported() {
|
public void testIsAvailable_returnsTrueIfNonActiveScorerSupported() {
|
||||||
setupScorers(Lists.newArrayList(sAppDataNoActivity, sAppData));
|
setupScorers(Lists.newArrayList(sAppDataNoActivity, sAppData));
|
||||||
when(mNetworkScoreManagerWrapper.getActiveScorer()).thenReturn(sAppDataNoActivity);
|
when(mNetworkScoreManager.getActiveScorer()).thenReturn(sAppDataNoActivity);
|
||||||
createController();
|
createController();
|
||||||
|
|
||||||
assertThat(mController.isAvailable()).isTrue();
|
assertThat(mController.isAvailable()).isTrue();
|
||||||
@@ -240,7 +245,7 @@ public class UseOpenWifiPreferenceControllerTest {
|
|||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void updateState_noScorer_preferenceDisabled_summaryChanged() {
|
public void updateState_noScorer_preferenceDisabled_summaryChanged() {
|
||||||
when(mNetworkScoreManagerWrapper.getAllValidScorers()).thenReturn(new ArrayList<>());
|
when(mNetworkScoreManager.getAllValidScorers()).thenReturn(new ArrayList<>());
|
||||||
createController();
|
createController();
|
||||||
|
|
||||||
final SwitchPreference preference = mock(SwitchPreference.class);
|
final SwitchPreference preference = mock(SwitchPreference.class);
|
||||||
|
Reference in New Issue
Block a user