【发布时间】:2015-09-25 18:56:01
【问题描述】:
我有一个 Java 项目。
PS:在我的项目中,src/test/java中没有任何java程序/源代码。
- 此文件夹仅包含一个空白.txt 文件。
我有两个不同的 Gradle 版本:
Gradle 1.6 与 Java 7(因为 Java 8 不兼容 Gradle 1.6 或任何版本
另一个版本是:Gradle 2.3 with Java 8。
同时使用上述 Gradle 1.6 + Java7 或 Gradle 2.3 + Java 8 版本我的项目构建成功。
不过,我注意到一件事:在运行构建时,它会自动调用“测试”任务(根据 Gradle 设计,测试任务是免费运行的);我在 Gradle 1.6 + Java7 运行期间发现 --- 我看到以下输出。
:jar
:assemble
:compileTestJava UP-TO-DATE
:processTestResources
:testClasses
:test
:check
你会注意到,它说我没有任何测试源代码(即 src/test/java 不包含任何源代码或 Gradle 没有什么新东西可以编译 这一次可能自上次 gradle 运行构建以来没有任何变化),这就是为什么 compileTestJava 任务在其前面显示 UP-TO-DATE 的原因。
但是,:test 任务显示它运行成功。我在 test { .. } 任务中使用了 jacoco(代码覆盖率)部分,然后它实际上运行了该部分(因为 test 任务前面没有 UP-TO-DATE)。 Jacoco 部分未在我的项目的 build.gradle 中定义,但实际上它来自顶级 / GRADLE_HOME/init.d/some-common-top-level.gradle 文件(其中 test { ... has jacoco { ... } .. } 部分)。
如上所述,test 任务没有说 UP-TO-DATE,因此,在 Gradle 构建过程完成后,我可以看到它在 中创建了以下文件夹/文件结构>build/tmp/expandedArchives/org.jacoco.... 文件夹:
$ ls -ltr build/tmp/expandedArchives/
total 4
drwxr-xr-x+ 1 e020001 Domain Users 0 Jul 7 20:45 org.jacoco.agent-0.7.2.201409121644.jar_778m6tp3jrtvcetasufl59dmau
$ ls -ltr build/tmp/expandedArchives/org.jacoco.agent-0.7.2.201409121644.jar_778m6tp3jrtvcetasufl59dmau/
total 272
drwxr-xr-x+ 1 e020001 Domain Users 0 Jul 7 20:58 META-INF
-rwxr-xr-x 1 e020001 Domain Users 2652 Jul 7 20:58 about.html
-rwxr-xr-x 1 e020001 Domain Users 272311 Jul 7 20:58 jacocoagent.jar
drwxr-xr-x+ 1 e020001 Domain Users 0 Jul 7 20:58 org
在我运行 Gradle 2.3 和 Java8 时不会发生同样的情况。
构建成功,但我没有得到包含 jacocoagent.jar 文件的 build/tmp/expandedArchives/org.jacoco.... 文件夹。
任何想法,为什么 Gradle 2.3 没有创建这个 jacoco 特定的 .jar 文件。
使用 Gradle 2.3+Java8,以下输出在 :compileTestJava 和 :test 任务前面显示 UP-TO-DATE(Gradle 不是这种情况1.6 用于 test 任务)。
我运行了“gradle clean build”。
:compileTestJava UP-TO-DATE
:compileTestGroovy UP-TO-DATE
:processTestResources
:testClasses
:test UP-TO-DATE
:check
我需要 Gradle 2.3 在 build/tmp/expandedArchives/org.jacoco..... 文件夹下生成这个 jacocoagent.jar,这样我就可以在下游 Jenkins 作业(运行非单元测试)中使用它项目确实有一些集成测试,我正在下游作业中从父主构建作业(运行 gradle clean build 包括测试任务)中获取 jacocoagent.jar,以便我可以将其传递给 TOMCAT JVM在启动 Tomcat 时(这样我就可以获得 IT 测试的 jacocoIT.exec 代码覆盖率)。但是,在我切换到 Gradle 2.3 后,我没有 src/test/java 的所有项目......现在 jacocoagent.jar 没有被创建,并且 copy artifact plugin 在尝试复制时失败来自父作业的 .jar 文件。
还有一点:
使用 Gradle 1.6 + Java7,如果我运行 gradle clean build,它会在 build/tmp/expandedArchives/org.jacoco..... 文件夹中成功创建 jacocoagent.jar,但它只能以这种方式工作当我运行 gradle clean build 或“gradle clean; gradle test”时。
如果我运行 gradle clean build,然后删除 build/tmp 文件夹,现在只需运行:gradle test,它会在两个 :compileTestJava 前面显示 UP-TO-DATE 和 :test 任务并且不会创建包含 jacocoagent.jar 文件的 build/tmp/expandedArchives/org.jacoco.... 文件夹。
有关更多信息,我在为 Gradle 1.6 + java 7 运行 gradle test 任务时附加配置文件运行(即使用 --profile 选项)。 p>
我看到,在配置文件 html 文件中,当 test 任务运行时,它首先按照 Gradle 流程逻辑调用 compileJava,然后测试任务,它也在调用depedencies --- :jacocoAgent(根据依赖项解析选项卡):
但是,
使用 Gradle 2.3 + Java8,依赖关系解析/顺序和任务执行步骤是不同的(或与 Gradle 1.6 相比的顺序),用于生成或显示对 jacocoAgent 依赖项的任何引用,因为它甚至没有调用它。
使用 -i(或 --info)选项运行 Gradle1.6 +Java7 测试任务说明了原因即使我没有测试源代码,它也会运行测试任务,看看原因:
Note: Recompile with -Xlint:unchecked for details.
:processResources
Skipping task ':processResources' as it has no source files.
:processResources UP-TO-DATE
:classes
Skipping task ':classes' as it has no actions.
:compileTestJava
Skipping task ':compileTestJava' as it has no source files.
:compileTestJava UP-TO-DATE
:processTestResources
Executing task ':processTestResources' due to:
No history is available.
:testClasses
Skipping task ':testClasses' as it has no actions.
:test
file or directory '/my/workspace/project/build/classes/test', not found
Executing task ':test' due to:
No history is available.
file or directory '/my/workspace/project/build/classes/test', not found
Finished generating test XML results (0.001 secs)
Generating HTML test report...
Finished generating test html results (0.012 secs)
BUILD SUCCESSFUL
【问题讨论】:
-
您能否在启用“-i”标志的情况下运行 Gradle 1.6 + Java7。这告诉你为什么 gradle 运行这个任务并且确实认为测试任务不是最新的。我想有一些变化
-
我运行“rm -fr .gradle”(删除任何本地 gradle 缓存),运行“gradle clean”。现在,我运行了 gradle test -i(用于显示 --info)。它显示: :compileTestJava 跳过任务 ':compileTestJava' 因为它没有源文件。:compileTestJava UP-TO-DATE。然后, :processTestResources 执行任务 ':processTestResources' 由于: 没有可用的历史记录。然后, :testClasses 跳过任务 ':testClasses' 因为它没有任何动作。然后,:test文件或目录'/production/home/c400093/giga/OCMPayerOnline/build/classes/test',找不到
-
执行任务 ':test' 由于:没有可用的历史记录。文件或目录“/my/workspace/project/build/classes/test”,未找到符合预期的文件或目录。
-
啊,我明白了。如果您将其添加到您的构建中是否有帮助:
test {doFirst { file("build/classes/test").mkdirs()}} -
是的,我同意你为什么 compileTestJava 说 UP-TO-DATE (这是预期的,因为我没有任何测试代码)但测试任务仍然运行(没有显示 UP-TO-DATE ) 使用 Gradle1.6+Java7。我用 -i output 粘贴了上面的原因
标签: unit-testing gradle jacoco gradle-2