From 9e2b63a7b51a0c4a57566e15b8b0a3f8655b538f Mon Sep 17 00:00:00 2001 From: slinkydeveloper Date: Wed, 14 Aug 2024 15:28:04 +0200 Subject: [PATCH] Started working on the socat container, to replace toxiproxy --- .../sdktesting/infra/SocatContainer.kt | 43 +++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 src/main/kotlin/dev/restate/sdktesting/infra/SocatContainer.kt diff --git a/src/main/kotlin/dev/restate/sdktesting/infra/SocatContainer.kt b/src/main/kotlin/dev/restate/sdktesting/infra/SocatContainer.kt new file mode 100644 index 0000000..82c0c3f --- /dev/null +++ b/src/main/kotlin/dev/restate/sdktesting/infra/SocatContainer.kt @@ -0,0 +1,43 @@ +// Copyright (c) 2023 - Restate Software, Inc., Restate GmbH +// +// This file is part of the Restate SDK Test suite tool, +// which is released under the MIT license. +// +// You can find a copy of the license in file LICENSE in the root +// directory of this repository or package, or at +// https://github.com/restatedev/sdk-test-suite/blob/main/LICENSE +package dev.restate.sdktesting.infra + +import org.apache.logging.log4j.LogManager +import org.testcontainers.containers.GenericContainer +import org.testcontainers.containers.Network +import org.testcontainers.utility.DockerImageName + +class SocatContainer(listenPort: Int, targetHost: String, targetPort: Int, exposeOnHost: Boolean) : + GenericContainer(DockerImageName.parse("docker.io/alpine/socat")) { + + companion object { + private val LOG = LogManager.getLogger(SocatContainer::class.java) + } + + init { + val networkAlias = "socat-$targetHost-$targetPort" + + this.network = network + this.networkAliases = arrayListOf(networkAlias) + withStartupAttempts(3) + + if (exposeOnHost) { + LOG.info("Going to expose {}:{} on localhost:{}", networkAlias, listenPort, listenPort) + super.addFixedExposedPort(listenPort, listenPort) + } + + withCommand("tcp-listen:$listenPort,fork,reuseaddr tcp-connect:$targetHost:$targetPort") + } + + internal fun start(network: Network, testReportDir: String) { + this.withNetwork(network) + .withLogConsumer(ContainerLogger(testReportDir, this.networkAliases[0]!!)) + .start() + } +}