Merge "Add TestableNetworkOfferCallback" into sc-dev
This commit is contained in:
@@ -0,0 +1,75 @@
|
||||
/*
|
||||
* Copyright (C) 2021 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.NetworkCapabilities
|
||||
import android.net.NetworkProvider
|
||||
import android.net.NetworkRequest
|
||||
import android.util.Log
|
||||
import com.android.net.module.util.ArrayTrackRecord
|
||||
import kotlin.test.fail
|
||||
|
||||
class TestableNetworkOfferCallback(val timeoutMs: Long, private val noCallbackTimeoutMs: Long)
|
||||
: NetworkProvider.NetworkOfferCallback {
|
||||
private val TAG = this::class.simpleName
|
||||
val history = ArrayTrackRecord<CallbackEntry>().newReadHead()
|
||||
|
||||
sealed class CallbackEntry {
|
||||
data class OnNetworkNeeded(val request: NetworkRequest) : CallbackEntry()
|
||||
data class OnNetworkUnneeded(val request: NetworkRequest) : CallbackEntry()
|
||||
}
|
||||
|
||||
/**
|
||||
* Called by the system when a network for this offer is needed to satisfy some
|
||||
* networking request.
|
||||
*/
|
||||
override fun onNetworkNeeded(request: NetworkRequest) {
|
||||
Log.d(TAG, "onNetworkNeeded $request")
|
||||
history.add(CallbackEntry.OnNetworkNeeded(request))
|
||||
}
|
||||
|
||||
/**
|
||||
* Called by the system when this offer is no longer valuable for this request.
|
||||
*/
|
||||
override fun onNetworkUnneeded(request: NetworkRequest) {
|
||||
Log.d(TAG, "onNetworkUnneeded $request")
|
||||
history.add(CallbackEntry.OnNetworkUnneeded(request))
|
||||
}
|
||||
|
||||
inline fun <reified T : CallbackEntry> expectCallbackThat(
|
||||
crossinline predicate: (T) -> Boolean
|
||||
) {
|
||||
val event = history.poll(timeoutMs)
|
||||
?: fail("Did not receive callback after ${timeoutMs}ms")
|
||||
if (event !is T || !predicate(event)) fail("Received unexpected callback $event")
|
||||
}
|
||||
|
||||
fun expectOnNetworkNeeded(capabilities: NetworkCapabilities) =
|
||||
expectCallbackThat<CallbackEntry.OnNetworkNeeded> {
|
||||
it.request.canBeSatisfiedBy(capabilities)
|
||||
}
|
||||
|
||||
fun expectOnNetworkUnneeded(capabilities: NetworkCapabilities) =
|
||||
expectCallbackThat<CallbackEntry.OnNetworkUnneeded> {
|
||||
it.request.canBeSatisfiedBy(capabilities)
|
||||
}
|
||||
|
||||
fun assertNoCallback() {
|
||||
val cb = history.poll(noCallbackTimeoutMs)
|
||||
if (null != cb) fail("Expected no callback but got $cb")
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user