Fix AppDataUsageCycleController.setInitialCycles

This is actually called after displayPreference(), so should update
cycleAdapter in setInitialCycles() instead of displayPreference().

Also update test.

Bug: 240931350
Test: manual - on AppDataUsage
Test: unit test
Change-Id: I00287c21e307199b26c336f15b9a623737a5d130
This commit is contained in:
Chaohui Wang
2023-11-05 21:10:45 +08:00
parent 6584f32b6a
commit fead9257b3
3 changed files with 25 additions and 32 deletions

View File

@@ -25,7 +25,6 @@ import androidx.lifecycle.lifecycleScope
import androidx.lifecycle.repeatOnLifecycle import androidx.lifecycle.repeatOnLifecycle
import androidx.preference.PreferenceScreen import androidx.preference.PreferenceScreen
import com.android.settings.core.BasePreferenceController import com.android.settings.core.BasePreferenceController
import com.android.settings.datausage.lib.AppDataUsageDetailsRepository
import com.android.settings.datausage.lib.IAppDataUsageDetailsRepository import com.android.settings.datausage.lib.IAppDataUsageDetailsRepository
import com.android.settings.datausage.lib.NetworkUsageDetailsData import com.android.settings.datausage.lib.NetworkUsageDetailsData
import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.Dispatchers
@@ -40,11 +39,18 @@ class AppDataUsageCycleController(context: Context, preferenceKey: String) :
private lateinit var preference: SpinnerPreference private lateinit var preference: SpinnerPreference
private var cycleAdapter: CycleAdapter? = null private var cycleAdapter: CycleAdapter? = null
private var initialCycles: List<Long> = emptyList()
private var initialSelectedEndTime: Long = -1
private var usageDetailsDataList: List<NetworkUsageDetailsData> = emptyList() private var usageDetailsDataList: List<NetworkUsageDetailsData> = emptyList()
override fun getAvailabilityStatus() = AVAILABLE
override fun displayPreference(screen: PreferenceScreen) {
super.displayPreference(screen)
preference = screen.findPreference(preferenceKey)!!
if (cycleAdapter == null) {
cycleAdapter = CycleAdapter(mContext, preference)
}
}
fun init( fun init(
repository: IAppDataUsageDetailsRepository, repository: IAppDataUsageDetailsRepository,
onUsageDataUpdated: (NetworkUsageDetailsData) -> Unit, onUsageDataUpdated: (NetworkUsageDetailsData) -> Unit,
@@ -60,22 +66,9 @@ class AppDataUsageCycleController(context: Context, preferenceKey: String) :
* before loading to reduce flicker. * before loading to reduce flicker.
*/ */
fun setInitialCycles(initialCycles: List<Long>, initialSelectedEndTime: Long) { fun setInitialCycles(initialCycles: List<Long>, initialSelectedEndTime: Long) {
this.initialCycles = initialCycles if (initialCycles.isNotEmpty()) {
this.initialSelectedEndTime = initialSelectedEndTime cycleAdapter?.setInitialCycleList(initialCycles, initialSelectedEndTime)
} preference.setHasCycles(true)
override fun getAvailabilityStatus() = AVAILABLE
override fun displayPreference(screen: PreferenceScreen) {
super.displayPreference(screen)
preference = screen.findPreference(preferenceKey)!!
if (cycleAdapter == null) {
cycleAdapter = CycleAdapter(mContext, preference).apply {
if (initialCycles.isNotEmpty()) {
setInitialCycleList(initialCycles, initialSelectedEndTime)
preference.setHasCycles(true)
}
}
} }
} }

View File

@@ -39,6 +39,8 @@ open class ChartDataUsagePreferenceController(context: Context, preferenceKey: S
private lateinit var repository: INetworkCycleDataRepository private lateinit var repository: INetworkCycleDataRepository
private lateinit var preference: ChartDataUsagePreference private lateinit var preference: ChartDataUsagePreference
private lateinit var lifecycleScope: LifecycleCoroutineScope private lateinit var lifecycleScope: LifecycleCoroutineScope
private var lastStartTime: Long? = null
private var lastEndTime: Long? = null
open fun init(template: NetworkTemplate) { open fun init(template: NetworkTemplate) {
this.repository = NetworkCycleDataRepository(mContext, template) this.repository = NetworkCycleDataRepository(mContext, template)
@@ -72,6 +74,10 @@ open class ChartDataUsagePreferenceController(context: Context, preferenceKey: S
} }
fun update(startTime: Long, endTime: Long) { fun update(startTime: Long, endTime: Long) {
if (lastStartTime == startTime && lastEndTime == endTime) return
lastStartTime = startTime
lastEndTime = endTime
preference.setTime(startTime, endTime) preference.setTime(startTime, endTime)
preference.setNetworkCycleData(NetworkCycleChartData.AllZero) preference.setNetworkCycleData(NetworkCycleChartData.AllZero)
lifecycleScope.launch { lifecycleScope.launch {

View File

@@ -22,7 +22,6 @@ import androidx.lifecycle.testing.TestLifecycleOwner
import androidx.preference.PreferenceManager import androidx.preference.PreferenceManager
import androidx.test.core.app.ApplicationProvider import androidx.test.core.app.ApplicationProvider
import androidx.test.ext.junit.runners.AndroidJUnit4 import androidx.test.ext.junit.runners.AndroidJUnit4
import com.android.settings.datausage.lib.AppDataUsageDetailsRepository
import com.android.settings.datausage.lib.IAppDataUsageDetailsRepository import com.android.settings.datausage.lib.IAppDataUsageDetailsRepository
import com.android.settings.datausage.lib.NetworkUsageDetailsData import com.android.settings.datausage.lib.NetworkUsageDetailsData
import com.google.common.truth.Truth.assertThat import com.google.common.truth.Truth.assertThat
@@ -31,23 +30,18 @@ import kotlinx.coroutines.runBlocking
import org.junit.Before import org.junit.Before
import org.junit.Test import org.junit.Test
import org.junit.runner.RunWith import org.junit.runner.RunWith
import org.mockito.kotlin.doReturn
import org.mockito.kotlin.mock
import org.mockito.kotlin.spy import org.mockito.kotlin.spy
import org.mockito.kotlin.stub
import org.mockito.kotlin.verify import org.mockito.kotlin.verify
@RunWith(AndroidJUnit4::class) @RunWith(AndroidJUnit4::class)
class AppDataUsageCycleControllerTest { class AppDataUsageCycleControllerTest {
private val context: Context = ApplicationProvider.getApplicationContext() private val context: Context = ApplicationProvider.getApplicationContext()
private val controller = AppDataUsageCycleController(context, KEY)
private val preference = spy(SpinnerPreference(context, null).apply { key = KEY }) private val preference = spy(SpinnerPreference(context, null).apply { key = KEY })
private val preferenceScreen = PreferenceManager(context).createPreferenceScreen(context) private val preferenceScreen = PreferenceManager(context).createPreferenceScreen(context)
private val onUsageDataUpdated: (NetworkUsageDetailsData) -> Unit = {} private val controller = AppDataUsageCycleController(context, KEY)
@Before @Before
fun setUp() { fun setUp() {
@@ -59,8 +53,8 @@ class AppDataUsageCycleControllerTest {
val repository = object : IAppDataUsageDetailsRepository { val repository = object : IAppDataUsageDetailsRepository {
override suspend fun queryDetailsForCycles() = emptyList<NetworkUsageDetailsData>() override suspend fun queryDetailsForCycles() = emptyList<NetworkUsageDetailsData>()
} }
controller.init(repository, onUsageDataUpdated)
controller.displayPreference(preferenceScreen) controller.displayPreference(preferenceScreen)
controller.init(repository) {}
controller.onViewCreated(TestLifecycleOwner()) controller.onViewCreated(TestLifecycleOwner())
delay(100) delay(100)
@@ -79,8 +73,8 @@ class AppDataUsageCycleControllerTest {
val repository = object : IAppDataUsageDetailsRepository { val repository = object : IAppDataUsageDetailsRepository {
override suspend fun queryDetailsForCycles() = listOf(detailsData) override suspend fun queryDetailsForCycles() = listOf(detailsData)
} }
controller.init(repository, onUsageDataUpdated)
controller.displayPreference(preferenceScreen) controller.displayPreference(preferenceScreen)
controller.init(repository) {}
controller.onViewCreated(TestLifecycleOwner()) controller.onViewCreated(TestLifecycleOwner())
delay(100) delay(100)
@@ -93,14 +87,14 @@ class AppDataUsageCycleControllerTest {
val repository = object : IAppDataUsageDetailsRepository { val repository = object : IAppDataUsageDetailsRepository {
override suspend fun queryDetailsForCycles() = emptyList<NetworkUsageDetailsData>() override suspend fun queryDetailsForCycles() = emptyList<NetworkUsageDetailsData>()
} }
controller.init(repository, onUsageDataUpdated) controller.displayPreference(preferenceScreen)
controller.init(repository) {}
controller.setInitialCycles( controller.setInitialCycles(
initialCycles = listOf(CYCLE2_END_TIME, CYCLE1_END_TIME, CYCLE1_START_TIME), initialCycles = listOf(CYCLE2_END_TIME, CYCLE1_END_TIME, CYCLE1_START_TIME),
initialSelectedEndTime = CYCLE1_END_TIME, initialSelectedEndTime = CYCLE1_END_TIME,
) )
controller.displayPreference(preferenceScreen)
verify(preference).setSelection(1) verify(preference).setSelection(1)
} }