我在专用的测试文件夹下有一个带有测试类的小型实用程序scala构建。编译然后publish-local
在我的本地存储库中创建包。
正如预期的那样,测试文件夹会自动从实用程序包的本地jar中排除。
但是,生成的POM仍然包含sbt中定义的相关依赖项。 SBT依赖项:
libraryDependencies ++= Seq(
"org.scalactic" %% "scalactic" % "3.0.0" % Test,
"org.scalatest" %% "scalatest" % "3.0.0" % Test
)
POM的一部分:
<dependency>
<groupId>org.scalactic</groupId>
<artifactId>scalactic_2.11</artifactId>
<version>3.0.0</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.scalatest</groupId>
<artifactId>scalatest_2.11</artifactId>
<version>3.0.0</version>
<scope>test</scope>
</dependency>
显然需要对范围进行测试,以防止使用此库的另一个项目(主要)中出现问题。特别是,主项目的测试否则包括这些测试库,这会导致版本冲突等。
由于这些依赖项仅适用于未包含的测试包,因此将它们列在POM中似乎很愚蠢。如何告诉SBT不要将这些测试范围依赖项包含在最终的POM中?
答案 0 :(得分:4)
这里有一个类似的问题:sbt - exclude certain dependency only during publish。
在lyomi提供的the answer上,这是如何排除包含子<dependency>
元素(包括<scope>
和test
)的所有provided
元素的方法。
import scala.xml.{Node => XmlNode, NodeSeq => XmlNodeSeq, _}
import scala.xml.transform.{RewriteRule, RuleTransformer}
// skip dependency elements with a scope
pomPostProcess := { (node: XmlNode) =>
new RuleTransformer(new RewriteRule {
override def transform(node: XmlNode): XmlNodeSeq = node match {
case e: Elem if e.label == "dependency"
&& e.child.exists(child => child.label == "scope") =>
def txt(label: String): String = "\"" + e.child.filter(_.label == label).flatMap(_.text).mkString + "\""
Comment(s""" scoped dependency ${txt("groupId")} % ${txt("artifactId")} % ${txt("version")} % ${txt("scope")} has been omitted """)
case _ => node
}
}).transform(node).head
}
这将生成一个如下所示的POM:
<dependencies>
<dependency>
<groupId>org.scala-lang</groupId>
<artifactId>scala-library</artifactId>
<version>2.12.5</version>
</dependency>
<!-- scoped dependency "org.scalatest" % "scalatest_2.12" % "3.0.5" % "test" has been omitted -->
</dependencies>