| /* |
| * 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.network; |
| |
| |
| import android.bluetooth.BluetoothAdapter; |
| import android.bluetooth.BluetoothPan; |
| import android.bluetooth.BluetoothProfile; |
| import android.content.ContentResolver; |
| import android.content.Context; |
| import android.content.Intent; |
| import android.content.IntentFilter; |
| import android.database.ContentObserver; |
| import android.net.ConnectivityManager; |
| import android.provider.Settings; |
| import android.support.v7.preference.Preference; |
| |
| import com.android.settings.R; |
| import com.android.settings.testutils.SettingsRobolectricTestRunner; |
| import com.android.settings.TestConfig; |
| |
| import org.junit.Before; |
| import org.junit.Test; |
| import org.junit.runner.RunWith; |
| import org.mockito.Mock; |
| import org.mockito.MockitoAnnotations; |
| import org.robolectric.RuntimeEnvironment; |
| import org.robolectric.annotation.Config; |
| import org.robolectric.util.ReflectionHelpers; |
| |
| import java.util.concurrent.atomic.AtomicReference; |
| |
| import static org.mockito.Matchers.any; |
| import static org.mockito.Mockito.mock; |
| import static org.mockito.Mockito.spy; |
| import static org.mockito.Mockito.verify; |
| import static org.mockito.Mockito.verifyNoMoreInteractions; |
| import static org.mockito.Mockito.verifyZeroInteractions; |
| import static org.mockito.Mockito.when; |
| |
| @RunWith(SettingsRobolectricTestRunner.class) |
| @Config(manifest = TestConfig.MANIFEST_PATH, sdk = TestConfig.SDK_VERSION) |
| public class TetherPreferenceControllerTest { |
| |
| @Mock |
| private Context mContext; |
| @Mock |
| private ConnectivityManager mConnectivityManager; |
| @Mock |
| private BluetoothAdapter mBluetoothAdapter; |
| @Mock |
| private Preference mPreference; |
| |
| private TetherPreferenceController mController; |
| |
| @Before |
| public void setUp() { |
| MockitoAnnotations.initMocks(this); |
| mController = spy(TetherPreferenceController.class); |
| ReflectionHelpers.setField(mController, "mContext", mContext); |
| ReflectionHelpers.setField(mController, "mConnectivityManager", mConnectivityManager); |
| ReflectionHelpers.setField(mController, "mBluetoothAdapter", mBluetoothAdapter); |
| ReflectionHelpers.setField(mController, "mPreference", mPreference); |
| } |
| |
| @Test |
| public void goThroughLifecycle_shouldDestoryBluetoothProfile() { |
| final BluetoothPan pan = mock(BluetoothPan.class); |
| final AtomicReference<BluetoothPan> panRef = |
| ReflectionHelpers.getField(mController, "mBluetoothPan"); |
| panRef.set(pan); |
| |
| mController.onDestroy(); |
| |
| verify(mBluetoothAdapter).closeProfileProxy(BluetoothProfile.PAN, pan); |
| } |
| |
| @Test |
| public void updateSummary_noPreference_noInteractionWithConnectivityManager() { |
| ReflectionHelpers.setField(mController, "mPreference", null); |
| mController.updateSummary(); |
| verifyNoMoreInteractions(mConnectivityManager); |
| } |
| |
| @Test |
| public void updateSummary_wifiTethered_shouldShowHotspotMessage() { |
| when(mConnectivityManager.getTetheredIfaces()).thenReturn(new String[]{"123"}); |
| when(mConnectivityManager.getTetherableWifiRegexs()).thenReturn(new String[]{"123"}); |
| |
| mController.updateSummary(); |
| verify(mPreference).setSummary(R.string.tether_settings_summary_hotspot_on_tether_off); |
| } |
| |
| @Test |
| public void updateSummary_btThetherOn_shouldShowTetherMessage() { |
| when(mConnectivityManager.getTetheredIfaces()).thenReturn(new String[]{"123"}); |
| when(mConnectivityManager.getTetherableBluetoothRegexs()).thenReturn(new String[]{"123"}); |
| |
| mController.updateSummary(); |
| verify(mPreference).setSummary(R.string.tether_settings_summary_hotspot_off_tether_on); |
| } |
| |
| @Test |
| public void updateSummary_tetherOff_shouldShowTetherOffMessage() { |
| when(mConnectivityManager.getTetherableBluetoothRegexs()).thenReturn(new String[]{"123"}); |
| when(mConnectivityManager.getTetherableWifiRegexs()).thenReturn(new String[]{"456"}); |
| |
| mController.updateSummary(); |
| verify(mPreference).setSummary(R.string.switch_off_text); |
| } |
| |
| @Test |
| public void updateSummary_wifiBtTetherOn_shouldShowHotspotAndTetherMessage() { |
| when(mConnectivityManager.getTetheredIfaces()).thenReturn(new String[]{"123", "456"}); |
| when(mConnectivityManager.getTetherableWifiRegexs()).thenReturn(new String[]{"456"}); |
| when(mConnectivityManager.getTetherableBluetoothRegexs()).thenReturn(new String[]{"23"}); |
| |
| mController.updateSummary(); |
| verify(mPreference).setSummary(R.string.tether_settings_summary_hotspot_on_tether_on); |
| } |
| |
| @Test |
| public void airplaneModeOn_shouldUpdateSummaryToOff() { |
| ReflectionHelpers.setField(mController, "mContext", RuntimeEnvironment.application); |
| |
| Settings.Global.putInt(RuntimeEnvironment.application.getContentResolver(), |
| Settings.Global.AIRPLANE_MODE_ON, 0); |
| |
| mController.onResume(); |
| |
| verifyZeroInteractions(mPreference); |
| |
| Settings.Global.putInt(RuntimeEnvironment.application.getContentResolver(), |
| Settings.Global.AIRPLANE_MODE_ON, 1); |
| |
| final ContentObserver observer = ReflectionHelpers.getField(mController, |
| "mAirplaneModeObserver"); |
| observer.onChange(true, Settings.Global.getUriFor(Settings.Global.AIRPLANE_MODE_ON)); |
| |
| verify(mPreference).setSummary(R.string.switch_off_text); |
| } |
| |
| @Test |
| public void onResume_shouldRegisterTetherReceiver() { |
| when(mContext.getContentResolver()).thenReturn(mock(ContentResolver.class)); |
| |
| mController.onResume(); |
| |
| verify(mContext).registerReceiver( |
| any(TetherPreferenceController.TetherBroadcastReceiver.class), any(IntentFilter.class)); |
| } |
| |
| @Test |
| public void onPause_shouldUnregisterTetherReceiver() { |
| when(mContext.getContentResolver()).thenReturn(mock(ContentResolver.class)); |
| mController.onResume(); |
| |
| mController.onPause(); |
| |
| verify(mContext).unregisterReceiver( |
| any(TetherPreferenceController.TetherBroadcastReceiver.class)); |
| } |
| |
| @Test |
| public void tetherStatesChanged_shouldUpdateSummary() { |
| final Context context = RuntimeEnvironment.application; |
| ReflectionHelpers.setField(mController, "mContext", context); |
| mController.onResume(); |
| |
| context.sendBroadcast(new Intent(ConnectivityManager.ACTION_TETHER_STATE_CHANGED)); |
| |
| verify(mController).updateSummary(); |
| } |
| |
| } |