diff options
author | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2020-02-19 00:54:03 +0000 |
---|---|---|
committer | Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com> | 2020-02-19 00:54:03 +0000 |
commit | 754f2a779fb6de99e731ad30d6d45b17996d852f (patch) | |
tree | 0f5ef4a0ee56852ebd8ef5d9e3cc7e4788ad21e4 | |
parent | 7107c4de2e6b5f45382ab4bff45197c496e6e4ac (diff) | |
parent | 70e87d787d9b5f97aaa642a511348e8f939d4e83 (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.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) +} |