forked from filodb/FiloDB
-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.sbt
304 lines (266 loc) · 13.7 KB
/
build.sbt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
import com.typesafe.sbt.SbtMultiJvm
import com.typesafe.sbt.SbtMultiJvm.MultiJvmKeys.MultiJvm
val mySettings = Seq(organization := "org.velvia",
scalaVersion := "2.11.8",
parallelExecution in Test := false,
fork in Test := true,
resolvers ++= extraRepos,
ivyScala := ivyScala.value map { _.copy(overrideScalaVersion = true) }) ++ universalSettings
publishTo := Some(Resolver.file("Unused repo", file("target/unusedrepo")))
lazy val core = (project in file("core"))
.settings(mySettings:_*)
.settings(name := "filodb-core")
.settings(scalacOptions += "-language:postfixOps")
.settings(libraryDependencies ++= coreDeps)
lazy val coordinator = (project in file("coordinator"))
.configs(MultiJvm)
.settings(mySettings:_*)
.settings(multiJvmSettings:_*)
.settings(name := "filodb-coordinator")
.settings(libraryDependencies ++= coordDeps)
.dependsOn(core % "compile->compile; test->test")
lazy val cassandra = (project in file("cassandra"))
.settings(mySettings:_*)
.settings(name := "filodb-cassandra")
.settings(libraryDependencies ++= cassDeps)
.dependsOn(core % "compile->compile; test->test")
lazy val cli = (project in file("cli"))
.settings(mySettings:_*)
.settings(name := "filodb-cli")
.settings(libraryDependencies ++= cliDeps)
.settings(cliAssemblySettings:_*)
.dependsOn(core, coordinator, cassandra)
lazy val spark = (project in file("spark"))
.settings(name := "filodb-spark")
.configs( IntegrationTest )
.settings(itSettings : _*)
.settings(fork in IntegrationTest := true)
.settings(mySettings:_*)
.settings(libraryDependencies ++= sparkDeps)
.settings(jvmPerTestSettings:_*)
.settings(assemblySettings:_*)
.settings(assemblyOption in assembly := (assemblyOption in assembly).value.copy(includeScala = false))
.dependsOn(core % "compile->compile; test->test; it->test",
coordinator % "compile->compile; test->test",
cassandra % "compile->compile; test->test; it->test")
lazy val jmh = (project in file("jmh"))
.settings(mySettings:_*)
.settings(name := "filodb-jmh")
.settings(libraryDependencies ++= jmhDeps)
.settings(publish := {})
.enablePlugins(JmhPlugin)
.dependsOn(core % "compile->compile; compile->test", spark)
lazy val stress = (project in file("stress"))
.settings(mySettings:_*)
.settings(name := "filodb-stress")
.settings(libraryDependencies ++= stressDeps)
.settings(assemblySettings:_*)
.settings(assemblyOption in assembly := (assemblyOption in assembly).value.copy(includeScala = false))
.dependsOn(spark)
val cassDriverVersion = "3.0.2"
val akkaVersion = "2.3.15"
val sparkVersion = "2.0.0"
lazy val extraRepos = Seq(
"Velvia Bintray" at "https://dl.bintray.com/velvia/maven",
"spray repo" at "http://repo.spray.io"
)
val excludeShapeless = ExclusionRule(organization = "com.chuusai")
// Zookeeper pulls in slf4j-log4j12 which we DON'T want
val excludeZK = ExclusionRule(organization = "org.apache.zookeeper")
// This one is brought by Spark by default
val excludeSlf4jLog4j = ExclusionRule(organization = "org.slf4j", name = "slf4j-log4j12")
val excludeJersey = ExclusionRule(organization = "com.sun.jersey")
lazy val commonDeps = Seq(
"io.kamon" %% "kamon-core" % "0.6.0",
"ch.qos.logback" % "logback-classic" % "1.0.7" % "test", // to get good test logs
"org.scalatest" %% "scalatest" % "2.2.4" % "test"
)
lazy val coreDeps = commonDeps ++ Seq(
"com.typesafe.scala-logging" %% "scala-logging-slf4j" % "2.1.2",
"org.slf4j" % "slf4j-api" % "1.7.10",
"com.beachape" %% "enumeratum" % "1.2.1",
"org.velvia.filo" %% "filo-scala" % "0.2.6",
"io.monix" %% "monix" % "2.1.1",
"joda-time" % "joda-time" % "2.2",
"org.joda" % "joda-convert" % "1.2",
"com.googlecode.concurrentlinkedhashmap" % "concurrentlinkedhashmap-lru" % "1.4",
"net.ceedubs" %% "ficus" % "1.1.2",
"org.scodec" %% "scodec-bits" % "1.0.10",
"io.fastjson" % "boon" % "0.33",
"com.github.alexandrnikitin" %% "bloom-filter" % "0.7.0",
"com.github.rholder.fauxflake" % "fauxflake-core" % "1.1.0",
"org.scalactic" %% "scalactic" % "2.2.6",
"com.markatta" %% "futiles" % "1.1.3",
"com.nativelibs4java" %% "scalaxy-loops" % "0.3.3" % "provided",
"com.github.scala-incubator.io" %% "scala-io-file" % "0.4.3-1" % "test"
)
lazy val cassDeps = commonDeps ++ Seq(
// other dependencies separated by commas
"net.jpountz.lz4" % "lz4" % "1.3.0",
"com.datastax.cassandra" % "cassandra-driver-core" % cassDriverVersion,
"ch.qos.logback" % "logback-classic" % "1.0.7" % "test"
)
lazy val coordDeps = commonDeps ++ Seq(
"com.typesafe.akka" %% "akka-slf4j" % akkaVersion,
"com.typesafe.akka" %% "akka-cluster" % akkaVersion,
"com.typesafe.akka" %% "akka-contrib" % akkaVersion,
// Take out the below line if you really don't want statsd metrics enabled
"io.kamon" %% "kamon-statsd" % "0.6.0",
"com.opencsv" % "opencsv" % "3.3",
"com.typesafe.akka" %% "akka-testkit" % akkaVersion % "test",
"com.typesafe.akka" %% "akka-multi-node-testkit" % akkaVersion % "test"
)
lazy val cliDeps = Seq(
"ch.qos.logback" % "logback-classic" % "1.0.7",
"com.quantifind" %% "sumac" % "0.3.0"
)
lazy val sparkDeps = Seq(
// We don't want LOG4J. We want Logback! The excludeZK is to help with a conflict re Coursier plugin.
"org.apache.spark" %% "spark-hive" % sparkVersion % "provided" excludeAll(excludeSlf4jLog4j, excludeZK),
"org.apache.spark" %% "spark-hive-thriftserver" % sparkVersion % "provided" excludeAll(excludeSlf4jLog4j, excludeZK),
"org.apache.spark" %% "spark-streaming" % sparkVersion % "provided",
"org.scalatest" %% "scalatest" % "2.2.4" % "it"
)
lazy val jmhDeps = Seq(
"com.nativelibs4java" %% "scalaxy-loops" % "0.3.3" % "provided",
"org.apache.spark" %% "spark-sql" % sparkVersion excludeAll(
excludeSlf4jLog4j, excludeZK, excludeJersey)
)
lazy val stressDeps = Seq(
"com.databricks" %% "spark-csv" % "1.3.0",
"org.apache.spark" %% "spark-sql" % sparkVersion % "provided" excludeAll(excludeZK),
"org.apache.spark" %% "spark-streaming" % sparkVersion % "provided" excludeAll(excludeZK)
)
//////////////////////////
///
lazy val coreSettings = Seq(
scalacOptions ++= Seq("-Xlint", "-deprecation", "-Xfatal-warnings", "-feature")
)
lazy val testSettings = Seq(
parallelExecution in Test := false,
// Needed to avoid cryptic EOFException crashes in forked tests
// in Travis with `sudo: false`.
// See https://github.com/sbt/sbt/issues/653
// and https://github.com/travis-ci/travis-ci/issues/3775
javaOptions += "-Xmx1250M",
concurrentRestrictions in Global := Seq(
// Tags.limit(Tags.CPU, java.lang.Runtime.getRuntime().availableProcessors()),
Tags.limit(Tags.CPU, 1),
// limit to 1 concurrent test task, even across sub-projects
Tags.limit(Tags.Test, 1),
// Note: some components of tests seem to have the "Untagged" tag rather than "Test" tag.
// So, we limit the sum of "Test", "Untagged" tags to 1 concurrent
Tags.limitSum(1, Tags.Test, Tags.Untagged))
)
// Fork a separate JVM for each test, instead of one for all tests in a module.
// This is necessary for Spark tests due to initialization, for example
lazy val jvmPerTestSettings = {
import Tests._
def jvmPerTest(tests: Seq[TestDefinition]) =
tests map { test =>
new Group(test.name, Seq(test), SubProcess(Nil))
} toSeq
Seq(testGrouping in Test <<= (definedTests in Test) map jvmPerTest)
}
lazy val multiJvmSettings = SbtMultiJvm.multiJvmSettings ++ Seq(
compile in MultiJvm <<= (compile in MultiJvm) triggeredBy (compile in Test),
// make sure that MultiJvm tests are executed by the default test target,
// and combine the results from ordinary test and multi-jvm tests
executeTests in Test <<= (executeTests in Test, executeTests in MultiJvm) map {
case (testResults, multiNodeResults) =>
val overall =
if (testResults.overall.id < multiNodeResults.overall.id)
multiNodeResults.overall
else
testResults.overall
Tests.Output(overall,
testResults.events ++ multiNodeResults.events,
testResults.summaries ++ multiNodeResults.summaries)
}
)
lazy val itSettings = Defaults.itSettings ++ Seq(
fork in IntegrationTest := true
)
lazy val universalSettings = coreSettings ++ styleSettings ++ testSettings ++ publishSettings
// Create a default Scala style task to run with tests
lazy val testScalastyle = taskKey[Unit]("testScalastyle")
lazy val compileScalastyle = taskKey[Unit]("compileScalastyle")
lazy val styleSettings = Seq(
testScalastyle := org.scalastyle.sbt.ScalastylePlugin.scalastyle.in(Test).toTask("").value,
// (scalastyleConfig in Test) := "scalastyle-test-config.xml",
// This is disabled for now, cannot get ScalaStyle to recognize the file above for some reason :/
// (test in Test) <<= (test in Test) dependsOn testScalastyle,
scalastyleFailOnError := true,
compileScalastyle := org.scalastyle.sbt.ScalastylePlugin.scalastyle.in(Compile).toTask("").value,
// Is running this on compile too much?
(compile in Test) <<= (compile in Test) dependsOn compileScalastyle
)
lazy val shellScript = """#!/bin/bash
while [ "${1:0:2}" = "-D" ]
do
allprops="$allprops $1"
shift
done
if [ ! -z "$FILO_CONFIG_FILE" ]; then
config="-Dconfig.file=$FILO_CONFIG_FILE"
fi
: ${FILO_LOG_DIR:="."}
exec java -Xmx4g -Xms4g -DLOG_DIR=$FILO_LOG_DIR $config $allprops -jar "$0" "$@"
""".split("\n")
// Builds cli as a standalone executable to make it easier to launch commands
lazy val cliAssemblySettings = assemblySettings ++ Seq(
assemblyOption in assembly := (assemblyOption in assembly).value.copy(
prependShellScript = Some(shellScript)),
assemblyJarName in assembly := s"filo-cli-${version.value}"
)
// Create a new MergeStrategy for aop.xml files
// Needed for Kamon.io async / Akka tracing / AspectJ weaving
val aopMerge = new sbtassembly.MergeStrategy {
val name = "aopMerge"
import scala.xml._
import scala.xml.dtd._
def apply(tempDir: File, path: String, files: Seq[File]): Either[String, Seq[(File, String)]] = {
val dt = DocType("aspectj", PublicID("-//AspectJ//DTD//EN", "http://www.eclipse.org/aspectj/dtd/aspectj.dtd"), Nil)
val file = MergeStrategy.createMergeTarget(tempDir, path)
val xmls: Seq[Elem] = files.map(XML.loadFile)
val aspectsChildren: Seq[Node] = xmls.flatMap(_ \\ "aspectj" \ "aspects" \ "_")
val weaverChildren: Seq[Node] = xmls.flatMap(_ \\ "aspectj" \ "weaver" \ "_")
val options: String = xmls.map(x => (x \\ "aspectj" \ "weaver" \ "@options").text).mkString(" ").trim
val weaverAttr = if (options.isEmpty) Null else new UnprefixedAttribute("options", options, Null)
val aspects = new Elem(null, "aspects", Null, TopScope, false, aspectsChildren: _*)
val weaver = new Elem(null, "weaver", weaverAttr, TopScope, false, weaverChildren: _*)
val aspectj = new Elem(null, "aspectj", Null, TopScope, false, aspects, weaver)
XML.save(file.toString, aspectj, "UTF-8", xmlDecl = false, dt)
IO.append(file, IO.Newline.getBytes(IO.defaultCharset))
Right(Seq(file -> path))
}
}
lazy val assemblySettings = Seq(
assemblyMergeStrategy in assembly := {
case m if m.toLowerCase.endsWith("manifest.mf") => MergeStrategy.discard
case m if m.toLowerCase.matches("meta-inf.*\\.sf$") => MergeStrategy.discard
case m if m.toLowerCase.matches("meta-inf.*\\.properties") => MergeStrategy.discard
case PathList("META-INF", "aop.xml") => aopMerge
case PathList(ps @ _*) if ps.last endsWith ".txt.1" => MergeStrategy.first
case "reference.conf" => MergeStrategy.concat
case "application.conf" => MergeStrategy.concat
case x =>
val oldStrategy = (assemblyMergeStrategy in assembly).value
oldStrategy(x)
},
assemblyShadeRules in assembly := Seq(
ShadeRule.rename("com.datastax.driver.**" -> "filodb.datastax.driver.@1").inAll,
ShadeRule.rename("com.google.common.**" -> "filodb.com.google.common.@1").inAll,
ShadeRule.rename("org.apache.http.**" -> "filodb.org.apache.http.@1").inAll,
ShadeRule.rename("com.google.guava.**" -> "filodb.com.google.guava.@1").inAll
),
test in assembly := {} //noisy for end-user since the jar is not available and user needs to build the project locally
)
lazy val publishSettings = Seq(
organizationName := "FiloDB",
publishMavenStyle := true,
publishArtifact in Test := false,
publishArtifact in IntegrationTest := false,
licenses += ("Apache-2.0", url("http://choosealicense.com/licenses/apache/")),
pomIncludeRepository := { x => false }
)