mirror of
https://github.com/bitcoin-s/bitcoin-s.git
synced 2025-01-19 14:43:57 +01:00
794f6e073e
* Fix TLV parsing for non-standard strings * Create function * Fix oracle migrations * Forced all TLV strings to be normalized implicitly * Removed redundant normalization * Fix oracle * Bump migration test * Fix 2.12.12 compile * Use NetworkElement & StringFactory Co-authored-by: nkohen <nadavk25@gmail.com>
581 lines
15 KiB
Scala
581 lines
15 KiB
Scala
import com.typesafe.sbt.SbtGit.GitKeys._
|
|
|
|
import scala.util.Properties
|
|
|
|
cancelable in Global := true
|
|
|
|
//don't allow us to wipe all of our prod databases
|
|
flywayClean / aggregate := false
|
|
//allow us to wipe our test databases
|
|
Test / flywayClean / aggregate := true
|
|
|
|
lazy val Benchmark = config("bench") extend Test
|
|
|
|
lazy val benchSettings: Seq[Def.SettingsDefinition] = {
|
|
//for scalameter
|
|
//https://scalameter.github.io/home/download/
|
|
//you can add benchmarking to a project by adding these to lines
|
|
//to the projects build definition
|
|
// .settings(benchSettings: _*)
|
|
// .configs(Benchmark)
|
|
List(
|
|
unmanagedSourceDirectories in Test += baseDirectory.value / "src" / "bench" / "scala",
|
|
testFrameworks += new TestFramework("org.scalameter.ScalaMeterFramework"),
|
|
parallelExecution in Benchmark := false,
|
|
outputStrategy in Benchmark := Some(StdoutOutput),
|
|
fork in Benchmark := true,
|
|
connectInput in Benchmark := true,
|
|
inConfig(Benchmark)(Defaults.testSettings)
|
|
)
|
|
}
|
|
|
|
import Projects._
|
|
lazy val crypto = project in file("crypto")
|
|
lazy val core = project in file("core") dependsOn crypto
|
|
|
|
lazy val bitcoindRpc = project
|
|
.in(file("bitcoind-rpc"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(
|
|
appCommons
|
|
)
|
|
lazy val eclairRpc = project in file("eclair-rpc")
|
|
|
|
// quoting the val name this way makes it appear as
|
|
// 'bitcoin-s' in sbt/bloop instead of 'bitcoins'
|
|
lazy val `bitcoin-s` = project
|
|
.in(file("."))
|
|
.aggregate(
|
|
secp256k1jni,
|
|
chain,
|
|
chainTest,
|
|
cli,
|
|
cliTest,
|
|
core,
|
|
coreTest,
|
|
crypto,
|
|
cryptoTest,
|
|
dbCommons,
|
|
dbCommonsTest,
|
|
feeProvider,
|
|
feeProviderTest,
|
|
dlcOracle,
|
|
dlcOracleTest,
|
|
bitcoindRpc,
|
|
bitcoindRpcTest,
|
|
bench,
|
|
eclairRpc,
|
|
eclairRpcTest,
|
|
bundle,
|
|
gui,
|
|
keyManager,
|
|
keyManagerTest,
|
|
node,
|
|
nodeTest,
|
|
wallet,
|
|
walletTest,
|
|
appServer,
|
|
appServerTest,
|
|
appCommons,
|
|
appCommonsTest,
|
|
testkit,
|
|
zmq,
|
|
oracleServer
|
|
)
|
|
.settings(CommonSettings.settings: _*)
|
|
// crossScalaVersions must be set to Nil on the aggregating project
|
|
.settings(crossScalaVersions := Nil)
|
|
// unidoc aggregates Scaladocs for all subprojects into one big doc
|
|
.enablePlugins(ScalaUnidocPlugin)
|
|
.settings(
|
|
// we modify the unidoc task to move the generated Scaladocs into the
|
|
// website directory afterwards
|
|
Compile / unidoc := {
|
|
import java.nio.file._
|
|
import scala.collection.JavaConverters._
|
|
val logger = streams.value.log
|
|
|
|
def cleanPath(path: Path, isRoot: Boolean = true): Unit =
|
|
if (Files.isDirectory(path)) {
|
|
path.toFile.list().map { file =>
|
|
val toClean = path.resolve(file)
|
|
cleanPath(toClean, isRoot = false)
|
|
}
|
|
if (isRoot) ()
|
|
else Files.deleteIfExists(path)
|
|
} else if (isRoot) {
|
|
()
|
|
} else if (path.toString.endsWith(".gitkeep")) {
|
|
()
|
|
} else {
|
|
Files.deleteIfExists(path)
|
|
}
|
|
|
|
val websiteScaladocDir =
|
|
Paths.get("website", "static", "api").toAbsolutePath
|
|
|
|
logger.info(s"Cleaning website Scaladoc directory $websiteScaladocDir")
|
|
cleanPath(websiteScaladocDir)
|
|
|
|
// returned value is a list of files,
|
|
// list has one element
|
|
val generatedDir = (Compile / unidoc).value.head
|
|
|
|
logger.info(s"Moving files in $generatedDir to $websiteScaladocDir")
|
|
|
|
try {
|
|
Files
|
|
.walk(generatedDir.toPath)
|
|
.iterator()
|
|
.asScala
|
|
.drop(1) // skip the root directory
|
|
.foreach { child =>
|
|
val pathDiff = generatedDir.toPath.relativize(child)
|
|
Files.copy(
|
|
child,
|
|
websiteScaladocDir.resolve(pathDiff),
|
|
StandardCopyOption.REPLACE_EXISTING
|
|
)
|
|
}
|
|
} catch {
|
|
case e: Throwable =>
|
|
logger.err(
|
|
"Error when copying Scaladocs to website folder: ${e.toString}"
|
|
)
|
|
throw e
|
|
}
|
|
Seq(generatedDir)
|
|
}
|
|
)
|
|
.settings(
|
|
name := "bitcoin-s",
|
|
gitRemoteRepo := "git@github.com:bitcoin-s/bitcoin-s-core.git",
|
|
publish / skip := true
|
|
)
|
|
|
|
lazy val secp256k1jni = project
|
|
.in(file("secp256k1jni"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(
|
|
libraryDependencies ++= Deps.secp256k1jni,
|
|
// we place lib files in this directory
|
|
unmanagedResourceDirectories in Compile += baseDirectory.value / "natives",
|
|
//since this is not a scala module, we have no code coverage
|
|
//this also doesn't place nice with scoverage, see
|
|
//https://github.com/scoverage/sbt-scoverage/issues/275
|
|
coverageEnabled := false
|
|
)
|
|
|
|
/**
|
|
* If you want sbt projects to depend on each other in
|
|
* slighly nonstandard ways, the way to do it is through
|
|
* stringly typed syntax.
|
|
*
|
|
* Suppose you have a module A and a module B:
|
|
* {{{
|
|
* lazy val A = project.in(file("A"))
|
|
* lazy val B = project.in(file("B"))
|
|
* .dependsOn(A)
|
|
* // .dependsOn(A % "compile->compile")
|
|
* // the line above is equivalent to the one
|
|
* // above it
|
|
* }}}
|
|
*
|
|
* With this setup, main sources in B can access
|
|
* main sources in A
|
|
*
|
|
* To make test sources in A available to test
|
|
* sources in B, you'd write this:
|
|
* {{{
|
|
* lazy val A = project.in(file("A"))
|
|
* lazy val B = project.in(file("B"))
|
|
* .dependsOn(A % "test->test")
|
|
* }}}
|
|
*
|
|
* And finally, to make main sources able to access
|
|
* main sources as well as test sources able to
|
|
* access test sources:
|
|
* {{{
|
|
* lazy val A = project.in(file("A"))
|
|
* lazy val B = project.in(file("B"))
|
|
* .dependsOn(A % "compile->compile;test->test")
|
|
* }}}
|
|
*
|
|
* We use this to make logging configuration in core
|
|
* propagate to tests in the other modules, without
|
|
* being published in the generated JARs.
|
|
*/
|
|
val testAndCompile = "compile->compile;test->test"
|
|
|
|
lazy val cryptoTest = project
|
|
.in(file("crypto-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-crypto-test"
|
|
)
|
|
.dependsOn(
|
|
crypto % testAndCompile,
|
|
testkit
|
|
)
|
|
|
|
lazy val coreTest = project
|
|
.in(file("core-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-core-test"
|
|
)
|
|
.dependsOn(
|
|
core % testAndCompile,
|
|
testkit
|
|
)
|
|
|
|
lazy val appCommons = project
|
|
.in(file("app-commons"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(
|
|
core % testAndCompile
|
|
)
|
|
|
|
lazy val appCommonsTest = project
|
|
.in(file("app-commons-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.dependsOn(appCommons, testkit)
|
|
|
|
lazy val oracleServer = project
|
|
.in(file("app/oracle-server"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(
|
|
dlcOracle,
|
|
appServer
|
|
)
|
|
|
|
lazy val appServer = project
|
|
.in(file("app/server"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(
|
|
appCommons,
|
|
node,
|
|
chain,
|
|
wallet,
|
|
bitcoindRpc,
|
|
feeProvider,
|
|
zmq
|
|
)
|
|
|
|
lazy val appServerTest = project
|
|
.in(file("app/server-test"))
|
|
.settings(CommonSettings.testSettings)
|
|
.settings(libraryDependencies ++= Deps.walletServerTest)
|
|
.dependsOn(
|
|
appServer,
|
|
testkit
|
|
)
|
|
|
|
lazy val cli = project
|
|
.in(file("app/cli"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(
|
|
appCommons
|
|
)
|
|
|
|
lazy val cliTest = project
|
|
.in(file("app/cli-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.dependsOn(
|
|
cli,
|
|
testkit
|
|
)
|
|
|
|
lazy val bundle = project
|
|
.in(file("app/bundle"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(appServer, gui)
|
|
|
|
lazy val gui = project
|
|
.in(file("app/gui"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(
|
|
cli
|
|
)
|
|
|
|
lazy val chainDbSettings = dbFlywaySettings("chaindb")
|
|
|
|
lazy val chain = project
|
|
.in(file("chain"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(chainDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-chain",
|
|
libraryDependencies ++= Deps.chain
|
|
)
|
|
.dependsOn(core, dbCommons)
|
|
.enablePlugins(FlywayPlugin)
|
|
|
|
lazy val chainTest = project
|
|
.in(file("chain-test"))
|
|
.settings(CommonSettings.testWithDbSettings: _*)
|
|
.settings(chainDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-chain-test",
|
|
libraryDependencies ++= Deps.chainTest
|
|
)
|
|
.dependsOn(chain, core % testAndCompile, testkit, zmq)
|
|
.enablePlugins(FlywayPlugin)
|
|
|
|
lazy val dbCommons = project
|
|
.in(file("db-commons"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-db-commons",
|
|
libraryDependencies ++= Deps.dbCommons
|
|
)
|
|
.dependsOn(core, appCommons)
|
|
|
|
lazy val dbCommonsTest = project
|
|
.in(file("db-commons-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-db-commons-test"
|
|
)
|
|
.dependsOn(testkit)
|
|
|
|
lazy val feeProvider = project
|
|
.in(file("fee-provider"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-fee-provider",
|
|
libraryDependencies ++= Deps.feeProvider
|
|
)
|
|
.dependsOn(core, appCommons)
|
|
|
|
lazy val feeProviderTest = project
|
|
.in(file("fee-provider-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-fee-provider-test",
|
|
libraryDependencies ++= Deps.feeProviderTest
|
|
)
|
|
.dependsOn(core, core % testAndCompile, testkit)
|
|
|
|
lazy val zmq = project
|
|
.in(file("zmq"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(name := "bitcoin-s-zmq", libraryDependencies ++= Deps.bitcoindZmq)
|
|
.dependsOn(
|
|
core % testAndCompile
|
|
)
|
|
|
|
lazy val bitcoindRpcTest = project
|
|
.in(file("bitcoind-rpc-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.dependsOn(core % testAndCompile, testkit)
|
|
|
|
lazy val bench = project
|
|
.in(file("bench"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(
|
|
libraryDependencies ++= Deps.bench,
|
|
name := "bitcoin-s-bench",
|
|
skip in publish := true
|
|
)
|
|
.dependsOn(core % testAndCompile, testkit)
|
|
|
|
lazy val eclairRpcTest = project
|
|
.in(file("eclair-rpc-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(
|
|
libraryDependencies ++= Deps.eclairRpcTest,
|
|
name := "bitcoin-s-eclair-rpc-test"
|
|
)
|
|
.dependsOn(core % testAndCompile, testkit)
|
|
|
|
lazy val nodeDbSettings = dbFlywaySettings("nodedb")
|
|
|
|
lazy val node =
|
|
project
|
|
.in(file("node"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(nodeDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-node",
|
|
libraryDependencies ++= Deps.node
|
|
)
|
|
.dependsOn(
|
|
core,
|
|
chain,
|
|
dbCommons,
|
|
bitcoindRpc
|
|
)
|
|
.enablePlugins(FlywayPlugin)
|
|
|
|
lazy val nodeTest =
|
|
project
|
|
.in(file("node-test"))
|
|
.settings(CommonSettings.testWithDbSettings: _*)
|
|
.settings(nodeDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-node-test",
|
|
// There's a weird issue with forking
|
|
// in node tests, for example this CI
|
|
// error: https://travis-ci.org/bitcoin-s/bitcoin-s-core/jobs/525018199#L1252
|
|
// It seems to be related to this
|
|
// Scalatest issue:
|
|
// https://github.com/scalatest/scalatest/issues/556
|
|
Test / fork := false,
|
|
libraryDependencies ++= Deps.nodeTest
|
|
)
|
|
.dependsOn(
|
|
core % testAndCompile,
|
|
node,
|
|
testkit
|
|
)
|
|
.enablePlugins(FlywayPlugin)
|
|
|
|
lazy val testkit = project
|
|
.in(file("testkit"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-testkit"
|
|
)
|
|
.dependsOn(
|
|
core % testAndCompile,
|
|
appServer,
|
|
chain,
|
|
bitcoindRpc,
|
|
eclairRpc,
|
|
node,
|
|
wallet,
|
|
zmq,
|
|
dlcOracle
|
|
)
|
|
|
|
lazy val docs = project
|
|
.in(file("bitcoin-s-docs")) // important: it must not be docs/
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.dependsOn(
|
|
bitcoindRpc,
|
|
chain,
|
|
cli,
|
|
core,
|
|
eclairRpc,
|
|
keyManager,
|
|
secp256k1jni,
|
|
testkit,
|
|
wallet,
|
|
zmq
|
|
)
|
|
|
|
lazy val keyManager = project
|
|
.in(file("key-manager"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.dependsOn(core, dbCommons)
|
|
|
|
lazy val keyManagerTest = project
|
|
.in(file("key-manager-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(name := "bitcoin-s-keymanager-test",
|
|
libraryDependencies ++= Deps.keyManagerTest)
|
|
.dependsOn(keyManager, testkit)
|
|
|
|
lazy val walletDbSettings = dbFlywaySettings("walletdb")
|
|
|
|
lazy val wallet = project
|
|
.in(file("wallet"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(walletDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-wallet",
|
|
libraryDependencies ++= Deps.wallet(scalaVersion.value)
|
|
)
|
|
.dependsOn(core, appCommons, dbCommons, keyManager)
|
|
.enablePlugins(FlywayPlugin)
|
|
|
|
lazy val walletTest = project
|
|
.in(file("wallet-test"))
|
|
.settings(CommonSettings.testWithDbSettings: _*)
|
|
.settings(walletDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-wallet-test",
|
|
libraryDependencies ++= Deps.walletTest
|
|
)
|
|
.dependsOn(core % testAndCompile, testkit, wallet)
|
|
.enablePlugins(FlywayPlugin)
|
|
|
|
lazy val oracleDbSettings = dbFlywaySettings("oracle")
|
|
|
|
lazy val dlcOracle = project
|
|
.in(file("dlc-oracle"))
|
|
.settings(CommonSettings.prodSettings: _*)
|
|
.settings(oracleDbSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-dlc-oracle",
|
|
libraryDependencies ++= Deps.dlcOracle
|
|
)
|
|
.dependsOn(core, keyManager, dbCommons)
|
|
|
|
lazy val dlcOracleTest = project
|
|
.in(file("dlc-oracle-test"))
|
|
.settings(CommonSettings.testSettings: _*)
|
|
.settings(
|
|
name := "bitcoin-s-dlc-oracle-test",
|
|
libraryDependencies ++= Deps.dlcOracleTest
|
|
)
|
|
.dependsOn(core % testAndCompile, dlcOracle, testkit)
|
|
|
|
/** Given a database name, returns the appropriate
|
|
* Flyway settings we apply to a project (chain, node, wallet)
|
|
*/
|
|
def dbFlywaySettings(dbName: String): List[Setting[_]] = {
|
|
lazy val DB_HOST = "localhost"
|
|
lazy val DB_NAME = s"${dbName}.sqlite"
|
|
lazy val network = "unittest" //mainnet, testnet3, regtest, unittest
|
|
|
|
lazy val mainnetDir = s"${System.getenv("HOME")}/.bitcoin-s/mainnet/"
|
|
lazy val testnetDir = s"${System.getenv("HOME")}/.bitcoin-s/testnet3/"
|
|
lazy val regtestDir = s"${System.getenv("HOME")}/.bitcoin-s/regtest/"
|
|
lazy val signetDir = s"${System.getenv("HOME")}/.bitcoin-s/signet/"
|
|
lazy val unittestDir = s"${System.getenv("HOME")}/.bitcoin-s/unittest/"
|
|
|
|
lazy val dirs =
|
|
List(mainnetDir, testnetDir, regtestDir, signetDir, unittestDir)
|
|
|
|
//create directies if they DNE
|
|
dirs.foreach { d =>
|
|
val file = new File(d)
|
|
file.mkdirs()
|
|
val db = new File(d + DB_NAME)
|
|
db.createNewFile()
|
|
}
|
|
|
|
def makeNetworkSettings(directoryPath: String): List[Setting[_]] =
|
|
List(
|
|
Test / flywayUrl := s"jdbc:sqlite:$directoryPath$DB_NAME",
|
|
Test / flywayLocations := List("nodedb/migration"),
|
|
Test / flywayUser := "nodedb",
|
|
Test / flywayPassword := "",
|
|
flywayUrl := s"jdbc:sqlite:$directoryPath$DB_NAME",
|
|
flywayUser := "nodedb",
|
|
flywayPassword := ""
|
|
)
|
|
|
|
lazy val mainnet = makeNetworkSettings(mainnetDir)
|
|
|
|
lazy val testnet3 = makeNetworkSettings(testnetDir)
|
|
|
|
lazy val regtest = makeNetworkSettings(regtestDir)
|
|
|
|
lazy val signet = makeNetworkSettings(signetDir)
|
|
|
|
lazy val unittest = makeNetworkSettings(unittestDir)
|
|
|
|
network match {
|
|
case "mainnet" => mainnet
|
|
case "testnet3" => testnet3
|
|
case "regtest" => regtest
|
|
case "signet" => signet
|
|
case "unittest" => unittest
|
|
case unknown: String =>
|
|
throw new IllegalArgumentException(s"Unknown network=${unknown}")
|
|
}
|
|
}
|