summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2020-02-19 00:54:03 +0000
committerAutomerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>2020-02-19 00:54:03 +0000
commit754f2a779fb6de99e731ad30d6d45b17996d852f (patch)
tree0f5ef4a0ee56852ebd8ef5d9e3cc7e4788ad21e4
parent7107c4de2e6b5f45382ab4bff45197c496e6e4ac (diff)
parent70e87d787d9b5f97aaa642a511348e8f939d4e83 (diff)
Merge "[SP13.1] Add assert equals function for NetworkStats" am: 6d26904639 am: 70e87d787d
Change-Id: Ice48ca18a49d9ffd2c5af46b19a5a46afa6e853d
-rw-r--r--tests/lib/src/com/android/testutils/NetworkStatsUtils.kt29
1 files changed, 26 insertions, 3 deletions
diff --git a/tests/lib/src/com/android/testutils/NetworkStatsUtils.kt b/tests/lib/src/com/android/testutils/NetworkStatsUtils.kt
index c82011c..51e9e4d 100644
--- a/tests/lib/src/com/android/testutils/NetworkStatsUtils.kt
+++ b/tests/lib/src/com/android/testutils/NetworkStatsUtils.kt
@@ -17,14 +17,19 @@
package com.android.testutils
import android.net.NetworkStats
+import kotlin.test.assertTrue
+@JvmOverloads
fun orderInsensitiveEquals(
leftStats: NetworkStats,
- rightStats: NetworkStats
+ rightStats: NetworkStats,
+ compareTime: Boolean = false
): Boolean {
if (leftStats == rightStats) return true
- if (leftStats.getElapsedRealtime() != rightStats.getElapsedRealtime() ||
- leftStats.size() != rightStats.size()) return false
+ if (compareTime && leftStats.getElapsedRealtime() != rightStats.getElapsedRealtime()) {
+ return false
+ }
+ if (leftStats.size() != rightStats.size()) return false
val left = NetworkStats.Entry()
val right = NetworkStats.Entry()
// Order insensitive compare.
@@ -32,8 +37,26 @@ fun orderInsensitiveEquals(
leftStats.getValues(i, left)
val j: Int = rightStats.findIndexHinted(left.iface, left.uid, left.set, left.tag,
left.metered, left.roaming, left.defaultNetwork, i)
+ if (j == -1) return false
rightStats.getValues(j, right)
if (left != right) return false
}
return true
}
+
+/**
+ * Assert that two {@link NetworkStats} are equals, assuming the order of the records are not
+ * necessarily the same.
+ *
+ * @note {@code elapsedRealtime} is not compared by default, given that in test cases that is not
+ * usually used.
+ */
+@JvmOverloads
+fun assertNetworkStatsEquals(
+ expected: NetworkStats,
+ actual: NetworkStats,
+ compareTime: Boolean = false
+) {
+ assertTrue(orderInsensitiveEquals(expected, actual, compareTime),
+ "expected: " + expected + "but was: " + actual)
+}