Merge "Address comments at aosp/2658225" into main

This commit is contained in:
Treehugger Robot
2023-08-01 09:19:12 +00:00
committed by Gerrit Code Review

View File

@@ -28,7 +28,6 @@ import com.android.server.net.NetworkStatsRecorder
import java.io.BufferedInputStream import java.io.BufferedInputStream
import java.io.DataInputStream import java.io.DataInputStream
import java.io.File import java.io.File
import java.io.FileInputStream
import java.io.FileOutputStream import java.io.FileOutputStream
import java.nio.file.Files import java.nio.file.Files
import java.util.concurrent.TimeUnit import java.util.concurrent.TimeUnit
@@ -44,6 +43,8 @@ import org.mockito.Mockito.mock
class NetworkStatsTest { class NetworkStatsTest {
companion object { companion object {
private val DEFAULT_BUFFER_SIZE = 8192 private val DEFAULT_BUFFER_SIZE = 8192
private val FILE_CACHE_WARM_UP_REPEAT_COUNT = 10
private val TEST_REPEAT_COUNT = 10
private val UID_COLLECTION_BUCKET_DURATION_MS = TimeUnit.HOURS.toMillis(2) private val UID_COLLECTION_BUCKET_DURATION_MS = TimeUnit.HOURS.toMillis(2)
private val UID_RECORDER_ROTATE_AGE_MS = TimeUnit.DAYS.toMillis(15) private val UID_RECORDER_ROTATE_AGE_MS = TimeUnit.DAYS.toMillis(15)
private val UID_RECORDER_DELETE_AGE_MS = TimeUnit.DAYS.toMillis(90) private val UID_RECORDER_DELETE_AGE_MS = TimeUnit.DAYS.toMillis(90)
@@ -63,14 +64,14 @@ class NetworkStatsTest {
} }
// Test results shows the test cases who read the file first will take longer time to // Test results shows the test cases who read the file first will take longer time to
// execute, and reading time getting shorter each time. Read files several times prior to // execute, and reading time getting shorter each time due to file caching mechanism.
// tests to minimize the impact. This cannot live in setUp() since the time // Read files several times prior to tests to minimize the impact.
// spent on the file reading will be attributed to the time spent on the individual // This cannot live in setUp() since the time spent on the file reading will be
// test case. // attributed to the time spent on the individual test case.
@JvmStatic @JvmStatic
@BeforeClass @BeforeClass
fun setUpOnce() { fun setUpOnce() {
for (i in 1..10) { repeat(FILE_CACHE_WARM_UP_REPEAT_COUNT) {
val collection = NetworkStatsCollection(UID_COLLECTION_BUCKET_DURATION_MS) val collection = NetworkStatsCollection(UID_COLLECTION_BUCKET_DURATION_MS)
for (file in uidTestFiles) { for (file in uidTestFiles) {
readFile(file, collection) readFile(file, collection)
@@ -78,20 +79,19 @@ class NetworkStatsTest {
} }
} }
private fun getInputStreamForResource(resourceId: Int): DataInputStream { private fun getInputStreamForResource(resourceId: Int): DataInputStream =
return DataInputStream( DataInputStream(
InstrumentationRegistry.getContext() InstrumentationRegistry.getContext()
.getResources().openRawResource(resourceId) .getResources().openRawResource(resourceId)
) )
}
private fun unzipToTempDir(zis: ZipInputStream): File { private fun unzipToTempDir(zis: ZipInputStream): File {
val statsDir = val statsDir =
Files.createTempDirectory(NetworkStatsTest::class.simpleName).toFile() Files.createTempDirectory(NetworkStatsTest::class.simpleName).toFile()
while (true) { generateSequence { zis.nextEntry }.forEach { entry ->
val entryName = zis.nextEntry?.name ?: break FileOutputStream(File(statsDir, entry.name)).use {
val file = File(statsDir, entryName) zis.copyTo(it, DEFAULT_BUFFER_SIZE)
FileOutputStream(file).use { zis.copyTo(it, DEFAULT_BUFFER_SIZE) } }
} }
return statsDir return statsDir
} }
@@ -99,20 +99,23 @@ class NetworkStatsTest {
// List [xt|uid|uid_tag].<start>-<end> files under the given directory. // List [xt|uid|uid_tag].<start>-<end> files under the given directory.
private fun getSortedListForPrefix(statsDir: File, prefix: String): List<File> { private fun getSortedListForPrefix(statsDir: File, prefix: String): List<File> {
assertTrue(statsDir.exists()) assertTrue(statsDir.exists())
return (statsDir.list() ?: arrayOf()).mapNotNull { return statsDir.list() { dir, name -> name.startsWith("$prefix.") }
if (it.startsWith("$prefix.")) File(statsDir, it) else null .orEmpty()
}.sorted() .map { it -> File(statsDir, it) }
.sorted()
} }
private fun readFile(file: File, reader: Reader) = private fun readFile(file: File, reader: Reader) =
BufferedInputStream(FileInputStream(file)).use { BufferedInputStream(file.inputStream()).use {
reader.read(it) reader.read(it)
} }
} }
@Test @Test
fun testReadCollection_manyUids() { fun testReadCollection_manyUids() {
for (i in 1..10) { // The file cache is warmed up by the @BeforeClass method, so now the test can repeat
// this a number of time to have a stable number.
repeat(TEST_REPEAT_COUNT) {
val collection = NetworkStatsCollection(UID_COLLECTION_BUCKET_DURATION_MS) val collection = NetworkStatsCollection(UID_COLLECTION_BUCKET_DURATION_MS)
for (file in uidTestFiles) { for (file in uidTestFiles) {
readFile(file, collection) readFile(file, collection)
@@ -122,13 +125,15 @@ class NetworkStatsTest {
@Test @Test
fun testReadFromRecorder_manyUids() { fun testReadFromRecorder_manyUids() {
for (i in 1..10) { val mockObserver = mock<NonMonotonicObserver<String>>()
val mockDropBox = mock<DropBoxManager>()
repeat(TEST_REPEAT_COUNT) {
val recorder = NetworkStatsRecorder( val recorder = NetworkStatsRecorder(
FileRotator( FileRotator(
testFilesDir, PREFIX_UID, UID_RECORDER_ROTATE_AGE_MS, UID_RECORDER_DELETE_AGE_MS testFilesDir, PREFIX_UID, UID_RECORDER_ROTATE_AGE_MS, UID_RECORDER_DELETE_AGE_MS
), ),
mock<NonMonotonicObserver<String>>(), mockObserver,
mock(DropBoxManager::class.java), mockDropBox,
PREFIX_UID, PREFIX_UID,
UID_COLLECTION_BUCKET_DURATION_MS, UID_COLLECTION_BUCKET_DURATION_MS,
false /* includeTags */, false /* includeTags */,
@@ -138,5 +143,5 @@ class NetworkStatsTest {
} }
} }
inline fun <reified T : Any> mock(): T = mock(T::class.java) inline fun <reified T> mock(): T = mock(T::class.java)
} }