package com.kmlabz.k8s import io.ktor.application.* import io.ktor.util.* import kotlinx.coroutines.* import java.time.Duration import java.time.Instant import java.util.* import kotlin.collections.LinkedHashMap fun main(args: Array): Unit = io.ktor.server.tomcat.EngineMain.main(args) @KtorExperimentalAPI @Suppress("unused") @kotlin.jvm.JvmOverloads fun Application.module(testing: Boolean = false) { runBlocking { var startTime: Instant var elapsed = Duration.ZERO val targetTime = Duration.ofSeconds(System.getenv("WAITTIME").toLong()) var currIter = 0 val timestamps = LinkedHashMap() val uploaders = LinkedList() val processResults = ProcessResults() environment.monitor.subscribe(ApplicationStarted) { GlobalScope.launch { println("Starting benchmark") startTime = Instant.now() while (elapsed < targetTime) { currIter += 1 uploaders.add(Uploader(currIter)) } for (uploader in uploaders) { uploader.sendRequest() } for (uploader in uploaders){ timestamps[uploader.currIteration] = uploader.respInstant } println("Benchmark ended") processResults.mapToProcess = timestamps processResults.process() } } } }