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:
@@ -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)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -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 {
|
||||||
|
@@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user