diff options
author | Junyu Lai <junyulai@google.com> | 2020-02-19 00:13:02 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2020-02-19 00:13:02 +0000 |
commit | 6d2690463977a5f508cbf79c01aed653de5bb88d (patch) | |
tree | 0f5ef4a0ee56852ebd8ef5d9e3cc7e4788ad21e4 | |
parent | 1f67bac38ec1d2dade03364a5fa8002f6506c515 (diff) | |
parent | 23a6a569d94b197d6ee57aec5035711f8cf9a0f9 (diff) |
Merge "[SP13.1] Add assert equals function for NetworkStats"
-rw-r--r-- | tests/lib/src/com/android/testutils/NetworkStatsUtils.kt | 29 |
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) +} |