-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathbuild.sbt
64 lines (54 loc) · 2.33 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
//
// Copyright 2022- IBM Inc. All rights reserved
// SPDX-License-Identifier: Apache2.0
//
scalaVersion := sys.env.getOrElse("SCALA_VERSION", "2.12.15")
organization := "com.ibm"
name := "spark-s3-shuffle"
val sparkVersion = sys.env.getOrElse("SPARK_VERSION", "3.3.1")
enablePlugins(GitVersioning, BuildInfoPlugin)
// Git
git.useGitDescribe := true
git.uncommittedSignifier := Some("DIRTY")
// Build info
buildInfoObject := "SparkS3ShuffleBuild"
buildInfoPackage := "com.ibm"
buildInfoKeys ++= Seq[BuildInfoKey](
BuildInfoKey.action("buildTime") {
System.currentTimeMillis
},
BuildInfoKey.action("sparkVersion") {
sparkVersion
}
)
libraryDependencies ++= Seq(
"org.apache.spark" %% "spark-core" % sparkVersion % "provided",
"org.apache.spark" %% "spark-sql" % sparkVersion % "provided",
"org.apache.spark" %% "spark-hadoop-cloud" % sparkVersion % "compile"
)
libraryDependencies ++= (if (scalaBinaryVersion.value == "2.12")
Seq(
"junit" % "junit" % "4.13.2" % Test,
"org.scalatest" %% "scalatest" % "3.2.2" % Test,
"ch.cern.sparkmeasure" %% "spark-measure" % "0.18" % Test,
"org.scalacheck" %% "scalacheck" % "1.15.2" % Test,
"org.mockito" % "mockito-core" % "3.4.6" % Test,
"org.scalatestplus" %% "mockito-3-4" % "3.2.9.0" % Test,
"com.github.sbt" % "junit-interface" % "0.13.3" % Test
)
else Seq())
javacOptions ++= Seq("-source", "1.8", "-target", "1.8")
javaOptions ++= Seq("-Xms512M", "-Xmx2048M", "-XX:MaxPermSize=2048M", "-XX:+CMSClassUnloadingEnabled")
scalacOptions ++= Seq("-deprecation", "-unchecked")
artifactName := { (sv: ScalaVersion, module: ModuleID, artifact: Artifact) =>
artifact.name + "_" + sv.binary + "-" + sparkVersion + "_" + module.revision + "." + artifact.extension
}
assemblyMergeStrategy := {
case PathList("META-INF", xs @ _*) => MergeStrategy.discard
case x => MergeStrategy.first
}
assembly / assemblyJarName := s"${name.value}_${scalaBinaryVersion.value}-${sparkVersion}_${version}-with-dependencies.jar"
assembly / assemblyOption ~= {
_.withIncludeScala(false)
}
lazy val lib = (project in file("."))