Skip to content

Commit

Permalink
chore: upgrade Ktor to 3.0.0
Browse files Browse the repository at this point in the history
  • Loading branch information
ianbotsf committed Oct 22, 2024
1 parent b5f5e91 commit b1b24b2
Show file tree
Hide file tree
Showing 8 changed files with 22 additions and 25 deletions.
2 changes: 1 addition & 1 deletion gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ kotlin-compile-testing-version = "1.6.0"
kotlinx-benchmark-version = "0.4.12"
kotlinx-serialization-version = "1.7.3"
docker-java-version = "3.4.0"
ktor-version = "2.3.12"
ktor-version = "3.0.0"
kaml-version = "0.55.0"
jsoup-version = "1.18.1"

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ import aws.smithy.kotlin.runtime.httptest.TestWithLocalServer
import aws.smithy.kotlin.runtime.net.Host
import aws.smithy.kotlin.runtime.net.Scheme
import aws.smithy.kotlin.runtime.testing.IgnoreWindows
import io.ktor.server.application.*
import io.ktor.server.cio.*
import io.ktor.server.engine.*
import io.ktor.server.response.*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,43 +19,34 @@ import java.io.ByteArrayOutputStream
import java.util.zip.GZIPOutputStream
import kotlin.random.Random

internal const val DOWNLOAD_SIZE = 16L * 1024 * 1024 // 16MB

internal fun Application.downloadTests() {
routing {
route("/download") {
get("/integrity") {
// writer is setup to write random lengths and delay to cause the reader to enter a suspend loop
val data = ByteArray(16 * 1024 * 1024) { it.toByte() }
val data = ByteArray(DOWNLOAD_SIZE.toInt()) { it.toByte() }
val writeSha = data.sha256().encodeToHex()
call.response.header("expected-sha256", writeSha)
val chunked = call.request.queryParameters["chunked-response"]?.toBoolean() ?: false

val ch = ByteChannel(autoFlush = true)
val content = object : OutgoingContent.ReadChannelContent() {
override val contentLength: Long? = if (chunked) null else data.size.toLong()
override fun readFrom(): ByteReadChannel = ch
override val contentType: ContentType = ContentType.Application.OctetStream
}

launch {
call.respondBytesWriter(contentLength = DOWNLOAD_SIZE.takeUnless { chunked }) {
var wcRemaining = data.size
var offset = 0
while (wcRemaining > 0) {
// random write sizes
val wc = minOf(wcRemaining, Random.nextInt(256, 8 * 1024))
val slice = data.sliceArray(offset until offset + wc)
ch.writeFully(slice)
writeFully(slice)
offset += wc
wcRemaining -= wc

if (wcRemaining % 256 == 0) {
delay(Random.nextLong(0, 10))
}
}
}.invokeOnCompletion { cause ->
ch.close(cause)
}

call.respond(content)
}

get("/empty") {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ import io.ktor.http.*
import io.ktor.server.application.*
import io.ktor.server.response.*
import io.ktor.server.routing.*
import io.ktor.utils.io.availableForRead
import io.ktor.utils.io.readAvailable

private const val CHUNK_SIZE = 1024 * 8

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -88,10 +88,13 @@ internal fun startServers(sslConfigPath: String): Closeable {
return servers
}

private fun tlsServer(instance: TestServer, sslConfig: SslConfig): ApplicationEngine {
private fun tlsServer(instance: TestServer, sslConfig: SslConfig): EmbeddedServer<*, *> {
val description = "${instance.type.name} server on port ${instance.port}"
println("Starting $description...")
val environment = applicationEngineEnvironment {
val rootConfig = serverConfig {
module(instance.initializer)
}
val engineConfig: ApplicationEngine.Configuration.() -> Unit = {
when (instance.type) {
ConnectorType.HTTP -> connector { port = instance.port }

Expand All @@ -106,11 +109,10 @@ private fun tlsServer(instance: TestServer, sslConfig: SslConfig): ApplicationEn
enabledProtocols = instance.protocolName?.let(::listOf)
}
}

modules.add(instance.initializer)
}

return try {
embeddedServer(Jetty, environment).start()
embeddedServer(Jetty, rootConfig, engineConfig).start()
} catch (e: Exception) {
println("$description failed to start with exception $e")
throw e
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import aws.smithy.kotlin.runtime.hashing.sha256
import aws.smithy.kotlin.runtime.http.*
import aws.smithy.kotlin.runtime.http.complete
import aws.smithy.kotlin.runtime.http.request.HttpRequest
import aws.smithy.kotlin.runtime.http.test.suite.DOWNLOAD_SIZE
import aws.smithy.kotlin.runtime.http.test.util.AbstractEngineTest
import aws.smithy.kotlin.runtime.http.test.util.test
import aws.smithy.kotlin.runtime.http.test.util.testSetup
Expand Down Expand Up @@ -62,16 +63,17 @@ class FileUploadDownloadTest : AbstractEngineTest() {

val expectedSha256 = call.response.headers["expected-sha256"] ?: fail("missing expected-sha256 header")
val contentLength = call.response.body.contentLength ?: fail("expected Content-Length")
check(contentLength < Int.MAX_VALUE)
assertEquals(DOWNLOAD_SIZE, contentLength)

val body = call.response.body
val stream = checkNotNull(body.toByteStream())

val file = RandomTempFile(0)
stream.writeToFile(file)
assertEquals(DOWNLOAD_SIZE, file.length())

val readSha256 = file.readBytes().sha256().encodeToHex()
assertEquals(expectedSha256, readSha256)
assertEquals(contentLength, file.length())
} finally {
call.complete()
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ public abstract class TestWithLocalServer {
protected val serverPort: Int = ServerSocket(0).use { it.localPort }
protected val testHost: String = "localhost"

public abstract val server: ApplicationEngine
public abstract val server: EmbeddedServer<*, *>

@BeforeTest
public fun startServer(): Unit = runBlocking {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,11 +19,12 @@ import aws.smithy.kotlin.runtime.io.SdkSource
import aws.smithy.kotlin.runtime.io.source
import aws.smithy.kotlin.runtime.net.Host
import aws.smithy.kotlin.runtime.net.Scheme
import io.ktor.server.application.*
import io.ktor.server.engine.*
import io.ktor.server.netty.*
import io.ktor.server.response.*
import io.ktor.server.routing.*
import io.ktor.utils.io.core.remaining
import io.ktor.utils.io.readRemaining
import kotlinx.benchmark.Blackhole
import kotlinx.coroutines.launch
import kotlinx.coroutines.runBlocking
Expand Down

0 comments on commit b1b24b2

Please sign in to comment.