2021-04-29 10:25:25 +02:00
|
|
|
package dorkboxTest.network
|
|
|
|
|
2021-07-08 14:33:24 +02:00
|
|
|
import ch.qos.logback.classic.Level
|
2021-07-07 16:19:00 +02:00
|
|
|
import dorkbox.network.Client
|
|
|
|
import dorkbox.network.Server
|
|
|
|
import dorkbox.network.connection.Connection
|
|
|
|
import kotlinx.atomicfu.atomic
|
|
|
|
import org.junit.Assert
|
2021-04-29 10:25:25 +02:00
|
|
|
import org.junit.Test
|
|
|
|
|
|
|
|
class PingTest : BaseTest() {
|
2022-06-11 23:54:23 +02:00
|
|
|
val counter = atomic(0)
|
2021-04-29 10:25:25 +02:00
|
|
|
@Test
|
2021-07-07 16:19:00 +02:00
|
|
|
fun RmiPing() {
|
2021-07-08 14:33:24 +02:00
|
|
|
setLogLevel(Level.TRACE)
|
|
|
|
|
2021-07-07 16:19:00 +02:00
|
|
|
val clientSuccess = atomic(false)
|
|
|
|
|
|
|
|
run {
|
|
|
|
val configuration = serverConfig()
|
|
|
|
|
|
|
|
val server: Server<Connection> = Server(configuration)
|
|
|
|
addEndPoint(server)
|
|
|
|
server.bind()
|
|
|
|
}
|
|
|
|
|
|
|
|
run {
|
|
|
|
val config = clientConfig()
|
|
|
|
|
|
|
|
val client: Client<Connection> = Client(config)
|
|
|
|
addEndPoint(client)
|
|
|
|
|
|
|
|
client.onConnect {
|
2021-07-08 14:33:24 +02:00
|
|
|
repeat(100) {
|
|
|
|
ping {
|
2022-04-04 23:21:44 +02:00
|
|
|
// a ping object is returned, once the round-trip is complete
|
2022-06-11 23:54:23 +02:00
|
|
|
val count = counter.getAndIncrement()
|
|
|
|
println(count)
|
2021-07-08 14:33:24 +02:00
|
|
|
|
2022-06-11 23:54:23 +02:00
|
|
|
if (count == 99) {
|
2021-07-08 14:33:24 +02:00
|
|
|
clientSuccess.value = true
|
2021-07-07 16:19:00 +02:00
|
|
|
|
2021-07-08 14:33:24 +02:00
|
|
|
logger.error("out-bound: $outbound")
|
|
|
|
logger.error("in-bound: $inbound")
|
|
|
|
logger.error("round-trip: $roundtrip")
|
2021-07-07 16:19:00 +02:00
|
|
|
|
2021-07-08 14:33:24 +02:00
|
|
|
stopEndPoints()
|
|
|
|
}
|
|
|
|
}
|
2021-07-07 16:19:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-03-15 12:44:52 +01:00
|
|
|
client.connect(LOCALHOST)
|
2021-07-07 16:19:00 +02:00
|
|
|
}
|
|
|
|
|
2022-06-11 23:54:23 +02:00
|
|
|
waitForThreads(500)
|
2021-07-07 16:19:00 +02:00
|
|
|
|
|
|
|
Assert.assertTrue(clientSuccess.value)
|
|
|
|
}
|
2021-04-29 10:25:25 +02:00
|
|
|
}
|