【发布时间】:2021-10-25 02:18:01
【问题描述】:
我正在尝试与 testcontainers 一起检查流式管道作为集成测试,但我不知道如何获取 bootstrapServers,至少在最后一个 testcontainers 版本中并在那里创建特定主题。如何使用 'containerDef' 提取引导服务器并添加主题?
import com.dimafeng.testcontainers.{ContainerDef, KafkaContainer}
import com.dimafeng.testcontainers.scalatest.TestContainerForAll
import munit.FunSuite
import org.apache.spark.sql.SparkSession
class Mykafkatest extends FunSuite with TestContainerForAll {
//val kafkaContainer: KafkaContainer = KafkaContainer("confluentinc/cp-kafka:5.4.3")
override val containerDef: ContainerDef = KafkaContainer.Def()
test("do something")(withContainers { container =>
val sparkSession: SparkSession = SparkSession
.builder()
.master("local[*]")
.appName("Unit testing")
.getOrCreate()
// How add a topic in that container?
// This is not posible:
val servers=container.bootstrapServers
val df = sparkSession.readStream
.format("kafka")
.option("kafka.bootstrap.servers", servers)
.option("subscribe", "topic1")
.load()
df.show(false)
})
}
我的 sbt 配置:
lazy val root = project
.in(file("./pipeline"))
.settings(
organization := "org.example",
name := "spark-stream",
version := "0.1",
scalaVersion := "2.12.10",
libraryDependencies := Seq(
"org.apache.spark" %% "spark-sql-kafka-0-10" % "3.0.3" % Compile,
"org.apache.spark" %% "spark-sql" % "3.0.3" % Compile,
"com.dimafeng" %% "testcontainers-scala-munit" % "0.39.5" % Test,
"org.dimafeng" %% "testcontainers-scala-kafka" % "0.39.5" % Test,
"org.scalameta" %% "munit" % "0.7.28" % Test
),
testFrameworks += new TestFramework("munit.Framework"),
Test / fork := true
)
【问题讨论】:
-
这个问题是否与 MuleSoft 的应用程序测试框架 MUnit (docs.mulesoft.com/munit/latest) 相关,用于为您的 Mule 应用程序构建自动化测试?
-
container.getBootstrapServers()不起作用? -
不是,不是
-
如果没有这个测试用例,理想情况下你会如何“在那个容器中添加一个主题?”就像流程的工作原理一样,contianer 对象上有哪些可用的方法?
标签: scala testcontainers