summaryrefslogtreecommitdiff
path: root/common/testutils/devicetests/com/android/testutils/NetworkStatsUtils.kt
blob: 8324b25ee3933bef1ee0f3099eb3626ec84fbe74 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
/*
 * Copyright (C) 2020 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package com.android.testutils

import android.net.NetworkStats
import kotlin.test.assertTrue

@JvmOverloads
fun orderInsensitiveEquals(
    leftStats: NetworkStats,
    rightStats: NetworkStats,
    compareTime: Boolean = false
): Boolean {
    if (leftStats == rightStats) return true
    if (compareTime && leftStats.getElapsedRealtime() != rightStats.getElapsedRealtime()) {
        return false
    }

    // While operations such as add/subtract will preserve empty entries. This will make
    // the result be hard to verify during test. Remove them before comparing since they
    // are not really affect correctness.
    // TODO (b/152827872): Remove empty entries after addition/subtraction.
    val leftTrimmedEmpty = leftStats.removeEmptyEntries()
    val rightTrimmedEmpty = rightStats.removeEmptyEntries()

    if (leftTrimmedEmpty.size() != rightTrimmedEmpty.size()) return false
    val left = NetworkStats.Entry()
    val right = NetworkStats.Entry()
    // Order insensitive compare.
    for (i in 0 until leftTrimmedEmpty.size()) {
        leftTrimmedEmpty.getValues(i, left)
        val j: Int = rightTrimmedEmpty.findIndexHinted(left.iface, left.uid, left.set, left.tag,
                left.metered, left.roaming, left.defaultNetwork, i)
        if (j == -1) return false
        rightTrimmedEmpty.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)
}

/**
 * Assert that after being parceled then unparceled, {@link NetworkStats} is equal to the original
 * object.
 */
fun assertParcelingIsLossless(stats: NetworkStats) {
    assertParcelingIsLossless(stats, { a, b -> orderInsensitiveEquals(a, b) })
}