mirror of
https://github.com/gitbucket/gitbucket.git
synced 2025-11-07 22:15:51 +01:00
Use Scala wrapper for testcontainers-java
This commit is contained in:
@@ -67,6 +67,8 @@ libraryDependencies ++= Seq(
|
|||||||
"org.scalatra" %% "scalatra-scalatest" % ScalatraVersion % "test",
|
"org.scalatra" %% "scalatra-scalatest" % ScalatraVersion % "test",
|
||||||
"org.mockito" % "mockito-core" % "2.23.4" % "test",
|
"org.mockito" % "mockito-core" % "2.23.4" % "test",
|
||||||
"com.dimafeng" %% "testcontainers-scala" % "0.22.0" % "test",
|
"com.dimafeng" %% "testcontainers-scala" % "0.22.0" % "test",
|
||||||
|
"org.testcontainers" % "mysql" % "1.10.3" % "test",
|
||||||
|
"org.testcontainers" % "postgresql" % "1.10.3" % "test",
|
||||||
"net.i2p.crypto" % "eddsa" % "0.3.0",
|
"net.i2p.crypto" % "eddsa" % "0.3.0",
|
||||||
"is.tagomor.woothee" % "woothee-java" % "1.8.0",
|
"is.tagomor.woothee" % "woothee-java" % "1.8.0",
|
||||||
"org.ec4j.core" % "ec4j-core" % "0.0.3"
|
"org.ec4j.core" % "ec4j-core" % "0.0.3"
|
||||||
|
|||||||
@@ -1,17 +1,13 @@
|
|||||||
package gitbucket.core
|
package gitbucket.core
|
||||||
|
|
||||||
import java.sql.DriverManager
|
import java.sql.DriverManager
|
||||||
import java.time.Duration
|
|
||||||
import java.time.temporal.ChronoUnit.SECONDS
|
|
||||||
|
|
||||||
import com.dimafeng.testcontainers.GenericContainer
|
import com.dimafeng.testcontainers.{MySQLContainer, PostgreSQLContainer}
|
||||||
import io.github.gitbucket.solidbase.Solidbase
|
import io.github.gitbucket.solidbase.Solidbase
|
||||||
import io.github.gitbucket.solidbase.model.Module
|
import io.github.gitbucket.solidbase.model.Module
|
||||||
import liquibase.database.core.{H2Database, MySQLDatabase, PostgresDatabase}
|
import liquibase.database.core.{H2Database, MySQLDatabase, PostgresDatabase}
|
||||||
import org.junit.runner.Description
|
import org.junit.runner.Description
|
||||||
import org.scalatest.{FunSuite, Tag}
|
import org.scalatest.{FunSuite, Tag}
|
||||||
import org.testcontainers.containers.ContainerLaunchException
|
|
||||||
import org.testcontainers.containers.wait.strategy.{HostPortWaitStrategy, Wait}
|
|
||||||
|
|
||||||
object ExternalDBTest extends Tag("ExternalDBTest")
|
object ExternalDBTest extends Tag("ExternalDBTest")
|
||||||
|
|
||||||
@@ -28,46 +24,19 @@ class GitBucketCoreModuleSpec extends FunSuite {
|
|||||||
|
|
||||||
implicit private val suiteDescription = Description.createSuiteDescription(getClass)
|
implicit private val suiteDescription = Description.createSuiteDescription(getClass)
|
||||||
|
|
||||||
test("Migration MySQL 5.7", ExternalDBTest) {
|
Seq("8.0", "5.7").foreach { tag =>
|
||||||
val container = GenericContainer(
|
test(s"Migration MySQL $tag", ExternalDBTest) {
|
||||||
"mysql:5.7",
|
val container = new MySQLContainer() {
|
||||||
env = Map("MYSQL_ROOT_PASSWORD" -> "my-secret-pw", "MYSQL_DATABASE" -> "gitbucket"),
|
override val container = new org.testcontainers.containers.MySQLContainer(s"mysql:$tag") {
|
||||||
waitStrategy = new HostPortWaitStrategy {
|
override def getDriverClassName = "org.mariadb.jdbc.Driver"
|
||||||
override def waitUntilReady(): Unit = {
|
|
||||||
super.waitUntilReady()
|
|
||||||
|
|
||||||
def readyForConnections(retry: Int = 0): Boolean = {
|
|
||||||
var con: java.sql.Connection = null
|
|
||||||
try {
|
|
||||||
con = DriverManager.getConnection(
|
|
||||||
s"jdbc:mysql://${waitStrategyTarget.getContainerIpAddress}:${waitStrategyTarget.getMappedPort(3306)}/gitbucket?useSSL=false",
|
|
||||||
"root",
|
|
||||||
"my-secret-pw"
|
|
||||||
)
|
|
||||||
con.createStatement().execute("SELECT 1")
|
|
||||||
} catch {
|
|
||||||
case _: Exception if retry < 3 =>
|
|
||||||
Thread.sleep(10000)
|
|
||||||
readyForConnections(retry + 1)
|
|
||||||
case _: Exception => false
|
|
||||||
} finally {
|
|
||||||
Option(con).foreach(_.close())
|
|
||||||
}
|
}
|
||||||
|
// TODO https://github.com/testcontainers/testcontainers-java/issues/736
|
||||||
|
container.withCommand("mysqld --default-authentication-plugin=mysql_native_password")
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!readyForConnections()) throw new ContainerLaunchException("Timed out")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
container.starting()
|
container.starting()
|
||||||
try {
|
try {
|
||||||
new Solidbase().migrate(
|
new Solidbase().migrate(
|
||||||
DriverManager.getConnection(
|
DriverManager.getConnection(s"${container.jdbcUrl}?useSSL=false", container.username, container.password),
|
||||||
s"jdbc:mysql://${container.containerIpAddress}:${container.mappedPort(3306)}/gitbucket?useSSL=false",
|
|
||||||
"root",
|
|
||||||
"my-secret-pw"
|
|
||||||
),
|
|
||||||
Thread.currentThread().getContextClassLoader(),
|
Thread.currentThread().getContextClassLoader(),
|
||||||
new MySQLDatabase(),
|
new MySQLDatabase(),
|
||||||
new Module(GitBucketCoreModule.getModuleId, GitBucketCoreModule.getVersions)
|
new Module(GitBucketCoreModule.getModuleId, GitBucketCoreModule.getVersions)
|
||||||
@@ -76,24 +45,16 @@ class GitBucketCoreModuleSpec extends FunSuite {
|
|||||||
container.finished()
|
container.finished()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
test("Migration PostgreSQL 11", ExternalDBTest) {
|
Seq("11", "10").foreach { tag =>
|
||||||
val container = GenericContainer(
|
test(s"Migration PostgreSQL $tag", ExternalDBTest) {
|
||||||
"postgres:11",
|
val container = PostgreSQLContainer(s"postgres:$tag")
|
||||||
env = Map("POSTGRES_PASSWORD" -> "mysecretpassword", "POSTGRES_DB" -> "gitbucket"),
|
|
||||||
waitStrategy = Wait
|
|
||||||
.forLogMessage(".*database system is ready to accept connections.*\\s", 2)
|
|
||||||
.withStartupTimeout(Duration.of(60, SECONDS))
|
|
||||||
)
|
|
||||||
|
|
||||||
container.starting()
|
container.starting()
|
||||||
try {
|
try {
|
||||||
new Solidbase().migrate(
|
new Solidbase().migrate(
|
||||||
DriverManager.getConnection(
|
DriverManager.getConnection(container.jdbcUrl, container.username, container.password),
|
||||||
s"jdbc:postgresql://${container.containerIpAddress}:${container.mappedPort(5432)}/gitbucket",
|
|
||||||
"postgres",
|
|
||||||
"mysecretpassword"
|
|
||||||
),
|
|
||||||
Thread.currentThread().getContextClassLoader(),
|
Thread.currentThread().getContextClassLoader(),
|
||||||
new PostgresDatabase(),
|
new PostgresDatabase(),
|
||||||
new Module(GitBucketCoreModule.getModuleId, GitBucketCoreModule.getVersions)
|
new Module(GitBucketCoreModule.getModuleId, GitBucketCoreModule.getVersions)
|
||||||
@@ -102,31 +63,6 @@ class GitBucketCoreModuleSpec extends FunSuite {
|
|||||||
container.finished()
|
container.finished()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
test("Migration PostgreSQL 10", ExternalDBTest) {
|
|
||||||
val container = GenericContainer(
|
|
||||||
"postgres:10",
|
|
||||||
env = Map("POSTGRES_PASSWORD" -> "mysecretpassword", "POSTGRES_DB" -> "gitbucket"),
|
|
||||||
waitStrategy = Wait
|
|
||||||
.forLogMessage(".*database system is ready to accept connections.*\\s", 2)
|
|
||||||
.withStartupTimeout(Duration.of(60, SECONDS))
|
|
||||||
)
|
|
||||||
|
|
||||||
container.starting()
|
|
||||||
try {
|
|
||||||
new Solidbase().migrate(
|
|
||||||
DriverManager.getConnection(
|
|
||||||
s"jdbc:postgresql://${container.containerIpAddress}:${container.mappedPort(5432)}/gitbucket",
|
|
||||||
"postgres",
|
|
||||||
"mysecretpassword"
|
|
||||||
),
|
|
||||||
Thread.currentThread().getContextClassLoader(),
|
|
||||||
new PostgresDatabase(),
|
|
||||||
new Module(GitBucketCoreModule.getModuleId, GitBucketCoreModule.getVersions)
|
|
||||||
)
|
|
||||||
} finally {
|
|
||||||
container.finished()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user