Merge "[Catalyst] Migrate Airplane Mode preference" into main

This commit is contained in:
Treehugger Robot
2024-12-05 10:47:21 +00:00
committed by Android (Google) Code Review
6 changed files with 268 additions and 22 deletions

View File

@@ -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();
}

View File

@@ -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)
}