diff --git a/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceController.java b/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceController.java deleted file mode 100644 index ae44b932c0f..00000000000 --- a/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceController.java +++ /dev/null @@ -1,110 +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.wifi; - -import android.content.Context; - -import androidx.preference.PreferenceScreen; - -import com.android.settings.R; -import com.android.settings.core.PreferenceControllerMixin; -import com.android.settings.widget.GenericSwitchController; -import com.android.settings.widget.SummaryUpdater; -import com.android.settingslib.PrimarySwitchPreference; -import com.android.settingslib.core.AbstractPreferenceController; -import com.android.settingslib.core.instrumentation.MetricsFeatureProvider; -import com.android.settingslib.core.lifecycle.LifecycleObserver; -import com.android.settingslib.core.lifecycle.events.OnPause; -import com.android.settingslib.core.lifecycle.events.OnResume; -import com.android.settingslib.core.lifecycle.events.OnStart; -import com.android.settingslib.core.lifecycle.events.OnStop; - -/** - * PreferenceController to update the wifi state. - */ -// TODO(b/167474581): Should clean up this controller when Provider Model finished. -public class WifiPrimarySwitchPreferenceController extends AbstractPreferenceController - implements PreferenceControllerMixin, SummaryUpdater.OnSummaryChangeListener, - LifecycleObserver, OnResume, OnPause, OnStart, OnStop { - //TODO(b/151133650): Replace AbstractPreferenceController with BasePreferenceController. - - public static final String KEY_TOGGLE_WIFI = "main_toggle_wifi"; - - private PrimarySwitchPreference mWifiPreference; - private WifiEnabler mWifiEnabler; - private final WifiSummaryUpdater mSummaryHelper; - private final MetricsFeatureProvider mMetricsFeatureProvider; - - public WifiPrimarySwitchPreferenceController(Context context, - MetricsFeatureProvider metricsFeatureProvider) { - super(context); - mMetricsFeatureProvider = metricsFeatureProvider; - mSummaryHelper = new WifiSummaryUpdater(mContext, this); - } - - @Override - public void displayPreference(PreferenceScreen screen) { - super.displayPreference(screen); - mWifiPreference = screen.findPreference(KEY_TOGGLE_WIFI); - } - - @Override - public boolean isAvailable() { - return mContext.getResources().getBoolean(R.bool.config_show_wifi_settings); - } - - @Override - public String getPreferenceKey() { - return KEY_TOGGLE_WIFI; - } - - @Override - public void onResume() { - mSummaryHelper.register(true); - if (mWifiEnabler != null) { - mWifiEnabler.resume(mContext); - } - } - - @Override - public void onPause() { - if (mWifiEnabler != null) { - mWifiEnabler.pause(); - } - mSummaryHelper.register(false); - } - - @Override - public void onStart() { - mWifiEnabler = new WifiEnabler(mContext, new GenericSwitchController(mWifiPreference), - mMetricsFeatureProvider); - } - - @Override - public void onStop() { - if (mWifiEnabler != null) { - mWifiEnabler.teardownSwitchController(); - } - } - - @Override - public void onSummaryChanged(String summary) { - if (mWifiPreference != null) { - mWifiPreference.setSummary(summary); - } - } - -} diff --git a/tests/robotests/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceControllerTest.java b/tests/robotests/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceControllerTest.java deleted file mode 100644 index 9204d4326f5..00000000000 --- a/tests/robotests/src/com/android/settings/wifi/WifiPrimarySwitchPreferenceControllerTest.java +++ /dev/null @@ -1,153 +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.wifi; - -import static com.google.common.truth.Truth.assertThat; - -import static org.mockito.ArgumentMatchers.any; -import static org.mockito.ArgumentMatchers.anyInt; -import static org.mockito.Mockito.doNothing; -import static org.mockito.Mockito.doReturn; -import static org.mockito.Mockito.spy; -import static org.mockito.Mockito.times; -import static org.mockito.Mockito.verify; -import static org.mockito.Mockito.when; - -import android.content.BroadcastReceiver; -import android.content.Context; -import android.content.Intent; -import android.content.IntentFilter; -import android.net.ConnectivityManager; -import android.net.NetworkRequest; -import android.net.NetworkScoreManager; -import android.net.wifi.WifiManager; -import android.os.Handler; - -import androidx.preference.Preference.OnPreferenceChangeListener; -import androidx.preference.PreferenceScreen; - -import com.android.settings.testutils.FakeFeatureFactory; -import com.android.settings.testutils.shadow.ShadowRestrictedLockUtilsInternal; -import com.android.settingslib.PrimarySwitchPreference; -import com.android.settingslib.core.instrumentation.MetricsFeatureProvider; - -import org.junit.Before; -import org.junit.Test; -import org.junit.runner.RunWith; -import org.mockito.Mock; -import org.mockito.MockitoAnnotations; -import org.robolectric.RobolectricTestRunner; -import org.robolectric.RuntimeEnvironment; -import org.robolectric.annotation.Config; - -@RunWith(RobolectricTestRunner.class) -@Config(shadows = ShadowRestrictedLockUtilsInternal.class) -public class WifiPrimarySwitchPreferenceControllerTest { - - @Mock - private Intent mIntentReceiver; - @Mock - private WifiManager mWifiManager; - @Mock - private PreferenceScreen mScreen; - @Mock - private PrimarySwitchPreference mPreference; - @Mock - private ConnectivityManager mConnectivityManager; - @Mock - private NetworkScoreManager mNetworkScoreManager; - - private Context mContext; - private WifiPrimarySwitchPreferenceController mController; - private MetricsFeatureProvider mMetricsFeatureProvider; - - @Before - public void setUp() { - MockitoAnnotations.initMocks(this); - mMetricsFeatureProvider = FakeFeatureFactory.setupForTest().getMetricsFeatureProvider(); - mContext = spy(RuntimeEnvironment.application.getApplicationContext()); - doReturn(mIntentReceiver).when(mContext) - .registerReceiver(any(BroadcastReceiver.class), any(IntentFilter.class), anyInt()); - doNothing().when(mContext).unregisterReceiver(any(BroadcastReceiver.class)); - when(mContext.getSystemService(ConnectivityManager.class)).thenReturn(mConnectivityManager); - when(mContext.getSystemService(NetworkScoreManager.class)).thenReturn(mNetworkScoreManager); - mController = new WifiPrimarySwitchPreferenceController(mContext, mMetricsFeatureProvider); - when(mScreen.findPreference(mController.getPreferenceKey())).thenReturn(mPreference); - when(mContext.getSystemService(Context.WIFI_SERVICE)).thenReturn(mWifiManager); - when(mWifiManager.getWifiState()).thenReturn(WifiManager.WIFI_STATE_DISABLED); - } - - @Test - public void testWifiPrimarySwitch_byDefault_shouldBeShown() { - assertThat(mController.isAvailable()).isTrue(); - } - - @Test - @Config(qualifiers = "mcc999") - public void testWifiPrimarySwitch_ifDisabled_shouldNotBeShown() { - assertThat(mController.isAvailable()).isFalse(); - } - - @Test - public void onResume_shouldRegisterCallback() { - mController.onResume(); - - verify(mContext).registerReceiver( - any(BroadcastReceiver.class), any(IntentFilter.class), anyInt()); - verify(mConnectivityManager).registerNetworkCallback( - any(NetworkRequest.class), - any(ConnectivityManager.NetworkCallback.class), - any(Handler.class)); - } - - @Test - public void onPause_shouldUnregisterCallback() { - mController.onResume(); - mController.onPause(); - - verify(mContext).unregisterReceiver(any(BroadcastReceiver.class)); - verify(mConnectivityManager, times(2)).unregisterNetworkCallback( - any(ConnectivityManager.NetworkCallback.class)); - } - - @Test - public void onStart_shouldRegisterPreferenceChangeListener() { - mController.displayPreference(mScreen); - mController.onStart(); - - verify(mPreference).setOnPreferenceChangeListener(any(OnPreferenceChangeListener.class)); - } - - @Test - public void onStop_shouldRegisterPreferenceChangeListener() { - mController.displayPreference(mScreen); - mController.onStart(); - - mController.onStop(); - - verify(mPreference).setOnPreferenceChangeListener(null); - } - - @Test - public void onSummaryChanged_shouldUpdatePreferenceSummary() { - mController.displayPreference(mScreen); - - mController.onSummaryChanged("test summary"); - - verify(mPreference).setSummary("test summary"); - } -}