Merge "[Catalyst] Migrate Airplane Mode preference" into main
This commit is contained in:
committed by
Android (Google) Code Review
commit
cfd023dc1f
@@ -16,6 +16,10 @@
|
||||
|
||||
package com.android.settings.network;
|
||||
|
||||
import static android.platform.test.flag.junit.SetFlagsRule.DefaultInitValueType.DEVICE_DEFAULT;
|
||||
|
||||
import static com.android.settings.flags.Flags.FLAG_CATALYST_NETWORK_PROVIDER_AND_INTERNET_SCREEN;
|
||||
|
||||
import static com.google.common.truth.Truth.assertThat;
|
||||
|
||||
import static org.mockito.ArgumentMatchers.any;
|
||||
@@ -28,6 +32,7 @@ import android.content.ContentResolver;
|
||||
import android.content.Context;
|
||||
import android.content.pm.PackageManager;
|
||||
import android.os.Looper;
|
||||
import android.platform.test.flag.junit.SetFlagsRule;
|
||||
import android.provider.Settings;
|
||||
import android.provider.SettingsSlicesContract;
|
||||
import android.util.AndroidRuntimeException;
|
||||
@@ -42,6 +47,7 @@ import com.android.settings.core.BasePreferenceController;
|
||||
import com.android.settingslib.RestrictedSwitchPreference;
|
||||
|
||||
import org.junit.Before;
|
||||
import org.junit.Rule;
|
||||
import org.junit.Test;
|
||||
import org.junit.runner.RunWith;
|
||||
import org.mockito.Mock;
|
||||
@@ -49,6 +55,8 @@ import org.mockito.MockitoAnnotations;
|
||||
|
||||
@RunWith(AndroidJUnit4.class)
|
||||
public class AirplaneModePreferenceControllerTest {
|
||||
@Rule
|
||||
public final SetFlagsRule mSetFlagsRule = new SetFlagsRule(DEVICE_DEFAULT);
|
||||
|
||||
private static final int ON = 1;
|
||||
private static final int OFF = 0;
|
||||
@@ -66,6 +74,7 @@ public class AirplaneModePreferenceControllerTest {
|
||||
|
||||
@Before
|
||||
public void setUp() {
|
||||
mSetFlagsRule.disableFlags(FLAG_CATALYST_NETWORK_PROVIDER_AND_INTERNET_SCREEN);
|
||||
if (Looper.myLooper() == null) {
|
||||
Looper.prepare();
|
||||
}
|
||||
|
||||
@@ -20,8 +20,14 @@ import android.content.ContextWrapper
|
||||
import android.content.pm.PackageManager
|
||||
import android.content.pm.PackageManager.FEATURE_LEANBACK
|
||||
import android.content.res.Resources
|
||||
import android.provider.Settings
|
||||
import android.telephony.TelephonyManager
|
||||
import androidx.annotation.DrawableRes
|
||||
import androidx.preference.SwitchPreferenceCompat
|
||||
import androidx.test.core.app.ApplicationProvider
|
||||
import androidx.test.ext.junit.runners.AndroidJUnit4
|
||||
import com.android.settingslib.datastore.SettingsGlobalStore
|
||||
import com.android.settingslib.preference.createAndBindWidget
|
||||
import com.google.common.truth.Truth.assertThat
|
||||
import org.junit.Test
|
||||
import org.junit.runner.RunWith
|
||||
@@ -31,19 +37,31 @@ import org.mockito.kotlin.mock
|
||||
import org.mockito.kotlin.stub
|
||||
|
||||
@RunWith(AndroidJUnit4::class)
|
||||
class AirplaneModePreferenceTest {
|
||||
open class AirplaneModePreferenceTest {
|
||||
|
||||
private val mockPackageManager = mock<PackageManager>()
|
||||
private val mockResources = mock<Resources>()
|
||||
private val mockPackageManager = mock<PackageManager>()
|
||||
private var mockTelephonyManager = mock<TelephonyManager>()
|
||||
|
||||
private val context =
|
||||
object : ContextWrapper(ApplicationProvider.getApplicationContext()) {
|
||||
override fun getResources(): Resources = mockResources
|
||||
|
||||
override fun getPackageManager(): PackageManager = mockPackageManager
|
||||
|
||||
override fun getResources(): Resources = mockResources
|
||||
override fun getSystemService(name: String): Any? =
|
||||
when (name) {
|
||||
getSystemServiceName(TelephonyManager::class.java) -> mockTelephonyManager
|
||||
else -> super.getSystemService(name)
|
||||
}
|
||||
}
|
||||
|
||||
private val airplaneModePreference = AirplaneModePreference()
|
||||
private var airplaneModePreference =
|
||||
object : AirplaneModePreference() {
|
||||
// TODO: Remove override
|
||||
override val icon: Int
|
||||
@DrawableRes get() = 0
|
||||
}
|
||||
|
||||
@Test
|
||||
fun isAvailable_hasConfigAndNoFeatureLeanback_shouldReturnTrue() {
|
||||
@@ -68,4 +86,49 @@ class AirplaneModePreferenceTest {
|
||||
|
||||
assertThat(airplaneModePreference.isAvailable(context)).isFalse()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun getValue_defaultOn_returnOn() {
|
||||
SettingsGlobalStore.get(context).setInt(Settings.Global.AIRPLANE_MODE_ON, 1)
|
||||
|
||||
val getValue =
|
||||
airplaneModePreference
|
||||
.storage(context)
|
||||
.getValue(AirplaneModePreference.KEY, Boolean::class.javaObjectType)
|
||||
|
||||
assertThat(getValue).isTrue()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun getValue_defaultOff_returnOff() {
|
||||
SettingsGlobalStore.get(context).setInt(Settings.Global.AIRPLANE_MODE_ON, 0)
|
||||
|
||||
val getValue =
|
||||
airplaneModePreference
|
||||
.storage(context)
|
||||
.getValue(AirplaneModePreference.KEY, Boolean::class.javaObjectType)
|
||||
|
||||
assertThat(getValue).isFalse()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun performClick_defaultOn_checkedIsFalse() {
|
||||
SettingsGlobalStore.get(context).setInt(Settings.Global.AIRPLANE_MODE_ON, 1)
|
||||
|
||||
val preference = getSwitchPreference().apply { performClick() }
|
||||
|
||||
assertThat(preference.isChecked).isFalse()
|
||||
}
|
||||
|
||||
@Test
|
||||
fun performClick_defaultOff_checkedIsTrue() {
|
||||
SettingsGlobalStore.get(context).setInt(Settings.Global.AIRPLANE_MODE_ON, 0)
|
||||
|
||||
val preference = getSwitchPreference().apply { performClick() }
|
||||
|
||||
assertThat(preference.isChecked).isTrue()
|
||||
}
|
||||
|
||||
private fun getSwitchPreference(): SwitchPreferenceCompat =
|
||||
airplaneModePreference.createAndBindWidget(context)
|
||||
}
|
||||
Reference in New Issue
Block a user