0

我无法摆脱 gradle 4.2 版本中的警告:

Gradle now uses separate output directories for each JVM language, but this build assumes a single directory for all classes from a source set. This behaviour has been deprecated and is scheduled to be removed in Gradle 5.0
    at build_d02ctf5wwx94ec3duxv44z2cn$_run_closure3$_closure6.doCall(...\build.gradle:56)

这些项目构建 EJB jar,因此 beans.xml 文件必须在类输出文件夹中结束。我发现的推荐修复方法是替换警告中提到的行:

sourceSets {
  main {
    output.resourcesDir = java.outputDir
  }
  test {
    output.resourcesDir = java.outputDir
  }
}

至:

sourceSets {
  main {
    output.resourcesDir = new File(buildDir, "classes/java/main")
  }
  test {
    output.resourcesDir = new File(buildDir, "classes/java/main")
  }
}

这解决了警告并且 beans.xml 是它需要的地方。我无法弄清楚的问题是构建中有另一个项目依赖于 ejb 项目并运行测试。使用第二种方法,它似乎无法识别 beans.xml 文件(测试中的焊接注入不起作用)

项目结构:

build.gradle
/ejb-project (builds ejb's and copies beans.xml)
/it-test-project (uses Services from ejb)
/st-test-project
/war-project
/ear-project

it-test-project包含一个 project() 依赖项和这个 sourceSets :

dependencies {    
  testCompile project(':ejb-project')
  testRuntime project(':ejb-project')
}

sourceSets {
  test {
    // output.resourcesDir = new File(buildDir, "classes/java/main")
    output.resourcesDir = output.classesDir
  }
}

我不明白测试中的注入在上面的变体中是如何工作的,但是一旦我切换到注释过的那个就不行了。我认为它与文件引用和依赖关系有关,但我不明白这里的正确选项是什么。

任何建议都会很棒:)

4

1 回答 1

0

所以。经过一番挖掘,我可以通过做两件事来摆脱警告信息:

  1. 打开我的眼睛:测试失败是因为缺少 beans.xml 文件,该文件不在 java/main 中,而是在测试文件夹中。因此上面的注释行不起作用,beans.xml 不存在。因此,请确保您引用正确的文件夹实际上是我的解决方案。

  2. 将 resourcesDir 添加/更改到测试文件夹。

此代码段不会导致警告:

sourceSets {
    test {
         output.resourcesDir = new File(buildDir, "classes/java/test")
    }
}

不确定这是否是最好的方法,因为这意味着 java 源集文件夹。以某种方式正确引用它们会很好 - 但因为我知道它的'java' - 我可以接受这个解决方案。

于 2017-11-23T16:11:30.943 回答