/** * Copyright (C) 2016-2018 Lightbend Inc. */ package akka import sbt._ import Keys._ object Dependencies { import DependencyHelpers._ lazy val scalaTestVersion = settingKey[String]("The version of ScalaTest to use.") lazy val scalaStmVersion = settingKey[String]("The version of ScalaSTM to use.") lazy val scalaCheckVersion = settingKey[String]("The version of ScalaCheck to use.") lazy val java8CompatVersion = settingKey[String]("The version of scala-java8-compat to use.") val junitVersion = "4.12" val sslConfigVersion = "0.3.6" val slf4jVersion = "1.7.25" val scalaXmlVersion = "1.0.6" val aeronVersion = "1.12.0" val Versions = Seq( crossScalaVersions := Seq("2.12.7", "2.11.12"), scalaVersion := System.getProperty("akka.build.scalaVersion", crossScalaVersions.value.head), scalaStmVersion := sys.props.get("akka.build.scalaStmVersion").getOrElse("0.8"), scalaCheckVersion := sys.props.get("akka.build.scalaCheckVersion").getOrElse( CrossVersion.partialVersion(scalaVersion.value) match { case Some((2, n)) if n >= 12 ⇒ "1.14.0" // does not work for 2.11 case _ ⇒ "1.13.2" }), scalaTestVersion := "3.0.5", java8CompatVersion := { CrossVersion.partialVersion(scalaVersion.value) match { case Some((2, n)) if n >= 13 ⇒ "0.9.0" case Some((2, n)) if n == 12 ⇒ "0.8.0" case _ ⇒ "0.7.0" } }) object Compile { // Compile val camelCore = "org.apache.camel" % "camel-core" % "2.17.7" exclude ("org.slf4j", "slf4j-api") // ApacheV2 // when updating config version, update links ActorSystem ScalaDoc to link to the updated version val config = "com.typesafe" % "config" % "1.3.3" // ApacheV2 val netty = "io.netty" % "netty" % "3.10.6.Final" // ApacheV2 val scalaStm = Def.setting { "org.scala-stm" %% "scala-stm" % scalaStmVersion.value } // Modified BSD (Scala) val scalaXml = "org.scala-lang.modules" %% "scala-xml" % scalaXmlVersion // Scala License val scalaReflect = ScalaVersionDependentModuleID.versioned("org.scala-lang" % "scala-reflect" % _) // Scala License val slf4jApi = "org.slf4j" % "slf4j-api" % slf4jVersion // MIT // mirrored in OSGi sample https://github.com/akka/akka-samples/tree/master/akka-sample-osgi-dining-hakkers val osgiCore = "org.osgi" % "org.osgi.core" % "4.3.1" // ApacheV2 val osgiCompendium = "org.osgi" % "org.osgi.compendium" % "4.3.1" // ApacheV2 val sigar = "org.fusesource" % "sigar" % "1.6.4" // ApacheV2 val jctools = "org.jctools" % "jctools-core" % "2.1.2" // ApacheV2 // reactive streams val reactiveStreams = "org.reactivestreams" % "reactive-streams" % "1.0.2" // CC0 // ssl-config val sslConfigCore = "com.typesafe" %% "ssl-config-core" % sslConfigVersion // ApacheV2 val lmdb = "org.lmdbjava" % "lmdbjava" % "0.6.1" // ApacheV2, OpenLDAP Public License val junit = "junit" % "junit" % junitVersion // Common Public License 1.0 // For Java 8 Conversions val java8Compat = Def.setting { "org.scala-lang.modules" %% "scala-java8-compat" % java8CompatVersion.value } // Scala License val aeronDriver = "io.aeron" % "aeron-driver" % aeronVersion // ApacheV2 val aeronClient = "io.aeron" % "aeron-client" % aeronVersion // ApacheV2 object Docs { val sprayJson = "io.spray" %% "spray-json" % "1.3.4" % "test" val gson = "com.google.code.gson" % "gson" % "2.8.5" % "test" } object Test { val commonsMath = "org.apache.commons" % "commons-math" % "2.2" % "test" // ApacheV2 val commonsIo = "commons-io" % "commons-io" % "2.6" % "test" // ApacheV2 val commonsCodec = "commons-codec" % "commons-codec" % "1.11" % "test" // ApacheV2 val junit = "junit" % "junit" % junitVersion % "test" // Common Public License 1.0 val logback = "ch.qos.logback" % "logback-classic" % "1.2.3" % "test" // EPL 1.0 / LGPL 2.1 val mockito = "org.mockito" % "mockito-core" % "2.19.1" % "test" // MIT // changing the scalatest dependency must be reflected in akka-docs/rst/dev/multi-jvm-testing.rst val scalatest = Def.setting { "org.scalatest" %% "scalatest" % scalaTestVersion.value % "test" } // ApacheV2 val scalacheck = Def.setting { "org.scalacheck" %% "scalacheck" % scalaCheckVersion.value % "test" } // New BSD val pojosr = "com.googlecode.pojosr" % "de.kalpatec.pojosr.framework" % "0.2.1" % "test" // ApacheV2 val tinybundles = "org.ops4j.pax.tinybundles" % "tinybundles" % "1.0.0" % "test" // ApacheV2 val log4j = "log4j" % "log4j" % "1.2.17" % "test" // ApacheV2 val scalaXml = "org.scala-lang.modules" %% "scala-xml" % scalaXmlVersion % "test" // in-memory filesystem for file related tests val jimfs = "com.google.jimfs" % "jimfs" % "1.1" % "test" // ApacheV2 // docker utils val dockerClient = "com.spotify" % "docker-client" % "8.13.1" % "test" // ApacheV2 // metrics, measurements, perf testing val metrics = "io.dropwizard.metrics" % "metrics-core" % "3.2.5" % "test" // ApacheV2 val metricsJvm = "io.dropwizard.metrics" % "metrics-jvm" % "3.2.5" % "test" // ApacheV2 val latencyUtils = "org.latencyutils" % "LatencyUtils" % "1.0.5" % "test" // Free BSD val hdrHistogram = "org.hdrhistogram" % "HdrHistogram" % "2.1.10" % "test" // CC0 val metricsAll = Seq(metrics, metricsJvm, latencyUtils, hdrHistogram) // sigar logging val slf4jJul = "org.slf4j" % "jul-to-slf4j" % slf4jVersion % "test" // MIT val slf4jLog4j = "org.slf4j" % "log4j-over-slf4j" % slf4jVersion % "test" // MIT // reactive streams tck val reactiveStreamsTck = "org.reactivestreams" % "reactive-streams-tck" % "1.0.2" % "test" // CC0 } object Provided { // TODO remove from "test" config // If changed, update akka-docs/build.sbt as well val sigarLoader = "io.kamon" % "sigar-loader" % "1.6.6-rev002" % "optional;provided;test" // ApacheV2 // Non-default module in Java9, removed in Java11. For Camel. val jaxb = "javax.xml.bind" % "jaxb-api" % "2.3.0" % "provided;test" val activation = "com.sun.activation" % "javax.activation" % "1.2.0" % "provided;test" val levelDB = "org.iq80.leveldb" % "leveldb" % "0.10" % "optional;provided" // ApacheV2 val levelDBmultiJVM = "org.iq80.leveldb" % "leveldb" % "0.10" % "optional;provided;multi-jvm" // ApacheV2 val levelDBNative = "org.fusesource.leveldbjni" % "leveldbjni-all" % "1.8" % "optional;provided" // New BSD val junit = Compile.junit % "optional;provided;test" val scalatest = Def.setting { "org.scalatest" %% "scalatest" % scalaTestVersion.value % "optional;provided;test" } // ApacheV2 } } import Compile._ // TODO check if `l ++=` everywhere expensive? val l = libraryDependencies val actor = l ++= Seq(config, java8Compat.value) val testkit = l ++= Seq(Test.junit, Test.scalatest.value) ++ Test.metricsAll val actorTests = l ++= Seq( Test.junit, Test.scalatest.value, Test.commonsCodec, Test.commonsMath, Test.mockito, Test.scalacheck.value, Test.jimfs, Test.dockerClient ) val actorTestkitTyped = l ++= Seq(Provided.junit, Provided.scalatest.value) val remote = l ++= Seq(netty, aeronDriver, aeronClient, Test.junit, Test.scalatest.value, Test.jimfs) val remoteTests = l ++= Seq(Test.junit, Test.scalatest.value, Test.scalaXml) val cluster = l ++= Seq(Test.junit, Test.scalatest.value) val clusterTools = l ++= Seq(Test.junit, Test.scalatest.value) val clusterSharding = l ++= Seq(Provided.levelDBmultiJVM, Provided.levelDBNative, Test.junit, Test.scalatest.value, Test.commonsIo) val clusterMetrics = l ++= Seq(Provided.sigarLoader, Test.slf4jJul, Test.slf4jLog4j, Test.logback, Test.mockito) val distributedData = l ++= Seq(lmdb, Test.junit, Test.scalatest.value) val slf4j = l ++= Seq(slf4jApi, Test.logback) val agent = l ++= Seq(scalaStm.value, Test.scalatest.value, Test.junit) val persistence = l ++= Seq(Provided.levelDB, Provided.levelDBNative, Test.scalatest.value, Test.junit, Test.commonsIo, Test.commonsCodec, Test.scalaXml) val persistenceQuery = l ++= Seq(Test.scalatest.value, Test.junit, Test.commonsIo, Provided.levelDB, Provided.levelDBNative) val persistenceTck = l ++= Seq(Test.scalatest.value.withConfigurations(Some("compile")), Test.junit.withConfigurations(Some("compile")), Provided.levelDB, Provided.levelDBNative) val persistenceShared = l ++= Seq(Provided.levelDB, Provided.levelDBNative) val camel = l ++= Seq(camelCore, Provided.jaxb, Provided.activation, Test.scalatest.value, Test.junit, Test.mockito, Test.logback, Test.commonsIo) val osgi = l ++= Seq(osgiCore, osgiCompendium, Test.logback, Test.commonsIo, Test.pojosr, Test.tinybundles, Test.scalatest.value, Test.junit) val docs = l ++= Seq(Test.scalatest.value, Test.junit, Docs.sprayJson, Docs.gson, Provided.levelDB) val contrib = l ++= Seq(Test.commonsIo) val benchJmh = l ++= Seq(Provided.levelDB, Provided.levelDBNative, Compile.jctools) // akka stream lazy val stream = l ++= Seq[sbt.ModuleID]( reactiveStreams, sslConfigCore, Test.scalatest.value) lazy val streamTestkit = l ++= Seq(Test.scalatest.value, Test.scalacheck.value, Test.junit) lazy val streamTests = l ++= Seq(Test.scalatest.value, Test.scalacheck.value, Test.junit, Test.commonsIo, Test.jimfs) lazy val streamTestsTck = l ++= Seq(Test.scalatest.value, Test.scalacheck.value, Test.junit, Test.reactiveStreamsTck) } object DependencyHelpers { case class ScalaVersionDependentModuleID(modules: String ⇒ Seq[ModuleID]) { def %(config: String): ScalaVersionDependentModuleID = ScalaVersionDependentModuleID(version ⇒ modules(version).map(_ % config)) } object ScalaVersionDependentModuleID { implicit def liftConstantModule(mod: ModuleID): ScalaVersionDependentModuleID = versioned(_ ⇒ mod) def versioned(f: String ⇒ ModuleID): ScalaVersionDependentModuleID = ScalaVersionDependentModuleID(v ⇒ Seq(f(v))) def fromPF(f: PartialFunction[String, ModuleID]): ScalaVersionDependentModuleID = ScalaVersionDependentModuleID(version ⇒ if (f.isDefinedAt(version)) Seq(f(version)) else Nil) } /** * Use this as a dependency setting if the dependencies contain both static and Scala-version * dependent entries. */ def versionDependentDeps(modules: ScalaVersionDependentModuleID*): Def.Setting[Seq[ModuleID]] = libraryDependencies ++= modules.flatMap(m ⇒ m.modules(scalaVersion.value)) val ScalaVersion = """\d\.\d+\.\d+(?:-(?:M|RC)\d+)?""".r val nominalScalaVersion: String ⇒ String = { // matches: // 2.12.0-M1 // 2.12.0-RC1 // 2.12.0 case version @ ScalaVersion() ⇒ version // transforms 2.12.0-custom-version to 2.12.0 case version ⇒ version.takeWhile(_ != '-') } }