Catch IllegalStateException when get carrier config
Fix: 319149441 Test: manual - on System Update page Test: unit test Change-Id: I484a036b2ce086531b20e1a5ca7e541934bc4c07
This commit is contained in:
@@ -0,0 +1,39 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2024 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.telephony
|
||||||
|
|
||||||
|
import android.os.PersistableBundle
|
||||||
|
import android.telephony.CarrierConfigManager
|
||||||
|
import android.telephony.SubscriptionManager
|
||||||
|
import androidx.core.os.persistableBundleOf
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the configuration values of the specified config keys applied.
|
||||||
|
*/
|
||||||
|
fun CarrierConfigManager.safeGetConfig(
|
||||||
|
keys: List<String>,
|
||||||
|
subId: Int = SubscriptionManager.getDefaultSubscriptionId(),
|
||||||
|
): PersistableBundle = try {
|
||||||
|
getConfigForSubId(subId, *keys.toTypedArray())
|
||||||
|
} catch (e: IllegalStateException) {
|
||||||
|
// The CarrierConfigLoader (the service implemented the CarrierConfigManager) hasn't been
|
||||||
|
// initialized yet. This may occurs during very early phase of phone booting up or when Phone
|
||||||
|
// process has been restarted.
|
||||||
|
// Settings should not assume Carrier config loader (and any other system services as well) are
|
||||||
|
// always available. If not available, use default value instead.
|
||||||
|
persistableBundleOf()
|
||||||
|
}
|
@@ -20,6 +20,7 @@ import android.content.Context
|
|||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.telephony.CarrierConfigManager
|
import android.telephony.CarrierConfigManager
|
||||||
import android.util.Log
|
import android.util.Log
|
||||||
|
import com.android.settings.network.telephony.safeGetConfig
|
||||||
|
|
||||||
class ClientInitiatedActionRepository(private val context: Context) {
|
class ClientInitiatedActionRepository(private val context: Context) {
|
||||||
private val configManager = context.getSystemService(CarrierConfigManager::class.java)!!
|
private val configManager = context.getSystemService(CarrierConfigManager::class.java)!!
|
||||||
@@ -29,11 +30,13 @@ class ClientInitiatedActionRepository(private val context: Context) {
|
|||||||
*/
|
*/
|
||||||
fun onSystemUpdate() {
|
fun onSystemUpdate() {
|
||||||
val bundle =
|
val bundle =
|
||||||
configManager.getConfig(
|
configManager.safeGetConfig(
|
||||||
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_BOOL,
|
keys = listOf(
|
||||||
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING,
|
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_BOOL,
|
||||||
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_STRING,
|
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING,
|
||||||
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_VAL_STRING,
|
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_STRING,
|
||||||
|
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_EXTRA_VAL_STRING,
|
||||||
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
if (!bundle.getBoolean(CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_BOOL)) return
|
if (!bundle.getBoolean(CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_BOOL)) return
|
||||||
|
@@ -0,0 +1,70 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2024 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.telephony
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.telephony.CarrierConfigManager
|
||||||
|
import androidx.core.os.persistableBundleOf
|
||||||
|
import androidx.test.ext.junit.runners.AndroidJUnit4
|
||||||
|
import com.google.common.truth.Truth.assertThat
|
||||||
|
import org.junit.Test
|
||||||
|
import org.junit.runner.RunWith
|
||||||
|
import org.mockito.kotlin.any
|
||||||
|
import org.mockito.kotlin.doReturn
|
||||||
|
import org.mockito.kotlin.doThrow
|
||||||
|
import org.mockito.kotlin.eq
|
||||||
|
import org.mockito.kotlin.mock
|
||||||
|
import org.mockito.kotlin.stub
|
||||||
|
|
||||||
|
@RunWith(AndroidJUnit4::class)
|
||||||
|
class CarrierConfigManagerExtTest {
|
||||||
|
|
||||||
|
private val mockCarrierConfigManager = mock<CarrierConfigManager>()
|
||||||
|
|
||||||
|
private val context = mock<Context> {
|
||||||
|
on { getSystemService(CarrierConfigManager::class.java) } doReturn mockCarrierConfigManager
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun safeGetConfig_managerReturnKeyValue_returnNonEmptyBundle() {
|
||||||
|
mockCarrierConfigManager.stub {
|
||||||
|
on { getConfigForSubId(any(), eq(KEY)) } doReturn persistableBundleOf(KEY to VALUE)
|
||||||
|
}
|
||||||
|
val carrierConfigManager = context.getSystemService(CarrierConfigManager::class.java)!!
|
||||||
|
|
||||||
|
val bundle = carrierConfigManager.safeGetConfig(listOf(KEY))
|
||||||
|
|
||||||
|
assertThat(bundle.getString(KEY)).isEqualTo(VALUE)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
fun safeGetConfig_managerThrowIllegalStateException_returnEmptyBundle() {
|
||||||
|
mockCarrierConfigManager.stub {
|
||||||
|
on { getConfigForSubId(any(), eq(KEY)) } doThrow IllegalStateException()
|
||||||
|
}
|
||||||
|
val carrierConfigManager = context.getSystemService(CarrierConfigManager::class.java)!!
|
||||||
|
|
||||||
|
val bundle = carrierConfigManager.safeGetConfig(listOf(KEY))
|
||||||
|
|
||||||
|
assertThat(bundle.containsKey(KEY)).isFalse()
|
||||||
|
}
|
||||||
|
|
||||||
|
private companion object {
|
||||||
|
const val KEY = "key"
|
||||||
|
const val VALUE = "value"
|
||||||
|
}
|
||||||
|
}
|
@@ -25,7 +25,6 @@ import com.google.common.truth.Truth.assertThat
|
|||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import org.junit.runner.RunWith
|
import org.junit.runner.RunWith
|
||||||
import org.mockito.kotlin.any
|
import org.mockito.kotlin.any
|
||||||
import org.mockito.kotlin.anyVararg
|
|
||||||
import org.mockito.kotlin.argumentCaptor
|
import org.mockito.kotlin.argumentCaptor
|
||||||
import org.mockito.kotlin.doReturn
|
import org.mockito.kotlin.doReturn
|
||||||
import org.mockito.kotlin.mock
|
import org.mockito.kotlin.mock
|
||||||
@@ -47,7 +46,7 @@ class ClientInitiatedActionRepositoryTest {
|
|||||||
@Test
|
@Test
|
||||||
fun onSystemUpdate_notEnabled() {
|
fun onSystemUpdate_notEnabled() {
|
||||||
mockCarrierConfigManager.stub {
|
mockCarrierConfigManager.stub {
|
||||||
on { getConfig(anyVararg()) } doReturn persistableBundleOf()
|
on { getConfigForSubId(any(), any()) } doReturn persistableBundleOf()
|
||||||
}
|
}
|
||||||
|
|
||||||
repository.onSystemUpdate()
|
repository.onSystemUpdate()
|
||||||
@@ -58,7 +57,7 @@ class ClientInitiatedActionRepositoryTest {
|
|||||||
@Test
|
@Test
|
||||||
fun onSystemUpdate_enabled() {
|
fun onSystemUpdate_enabled() {
|
||||||
mockCarrierConfigManager.stub {
|
mockCarrierConfigManager.stub {
|
||||||
on { getConfig(anyVararg()) } doReturn persistableBundleOf(
|
on { getConfigForSubId(any(), any()) } doReturn persistableBundleOf(
|
||||||
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_BOOL to true,
|
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_BOOL to true,
|
||||||
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING to ACTION,
|
CarrierConfigManager.KEY_CI_ACTION_ON_SYS_UPDATE_INTENT_STRING to ACTION,
|
||||||
)
|
)
|
||||||
|
Reference in New Issue
Block a user