我对 JVM 世界很陌生,不知道如何解决以下问题:
我有一个 gradle 项目,它创建一个测试 uber jar(使用shadowJar插件构建),并将 JUnit 测试作为其输出。我可以使用这样的东西在同一个项目中运行这个 uber jar:
task runFatJar(type: Test) {
dependsOn shadowJar
classpath = project.files( "$buildDir/libs/fatjar.jar", configurations.runtime )
outputs.upToDateWhen { false }
}
然而,我想要的是创建一个非常小的gradle.build
文件来运行与预先构建的 jar 相同的作业。详细说明一下:我有一个创建这个胖 jar 的项目 A,我想要一个只有runFatJar
任务而没有源的项目 B。
我试着用我的项目 B 做这样的事情:
apply plugin: 'java'
buildscript {
repositories {
jcenter()
}
}
repositories {
jcenter()
}
dependencies {
testRuntime("org.junit.vintage:junit-vintage-engine:5.4.1")
}
tasks.withType(Test) {
systemProperties = System.getProperties()
systemProperties.remove("java.endorsed.dirs")
}
configurations {
itestCompile.extendsFrom testCompile
itestRuntime.extendsFrom testRuntime
}
task runFatJar(type: Test) {
classpath = project.files( "$buildDir/fatjar.jar", configurations.runtime )
outputs.upToDateWhen { false }
}
我的文件夹结构如下所示:
├───build
└───src
└───test
└───resources
└───features
在我运行后gradle runFatJar
它变成了这样:
├───.gradle
│ ├───5.2.1
│ │ ├───executionHistory
│ │ ├───fileChanges
│ │ ├───fileContent
│ │ ├───fileHashes
│ │ └───vcsMetadata-1
│ ├───buildOutputCleanup
│ └───vcs-1
├───build
│ └───resources
│ └───test
│ └───features
└───src
└───test
└───resources
└───features
但是 gradle 输出并没有真正做任何事情:
> gradle runFatJar --info
Initialized native services in: C:\Users\derwasp\.gradle\native
The client will now receive all logging from the daemon (pid: 6960). The daemon log file: C:\Users\derwasp\.gradle\daemon\5.2.1\daemon-6960.out.log
Starting 3rd build in daemon [uptime: 49.78 secs, performance: 97%, no major garbage collections]
Using 8 worker leases.
Starting Build
Settings evaluated using settings file 'D:\Temp\!deleteme\settings.gradle'.
Projects loaded. Root project using build file 'D:\Temp\!deleteme\build.gradle'.
Included projects: [root project '!deleteme']
> Configure project :
Evaluating root project '!deleteme' using build file 'D:\Temp\!deleteme\build.gradle'.
All projects evaluated.
Selected primary task 'runFatJar' from project :
Tasks to be executed: [task ':compileJava', task ':processResources', task ':classes', task ':compileTestJava', task ':processTestResources', task ':testClasses', task ':runFatJar']
:compileJava (Thread[Execution worker for ':',5,main]) started.
> Task :compileJava NO-SOURCE
file or directory 'D:\Temp\!deleteme\src\main\java', not found
Skipping task ':compileJava' as it has no source files and no previous output files.
:compileJava (Thread[Execution worker for ':',5,main]) completed. Took 0.007 secs.
:processResources (Thread[Execution worker for ':',5,main]) started.
> Task :processResources NO-SOURCE
file or directory 'D:\Temp\!deleteme\src\main\resources', not found
Skipping task ':processResources' as it has no source files and no previous output files.
:processResources (Thread[Execution worker for ':',5,main]) completed. Took 0.001 secs.
:classes (Thread[Execution worker for ':',5,main]) started.
> Task :classes UP-TO-DATE
Skipping task ':classes' as it has no actions.
:classes (Thread[Execution worker for ':',5,main]) completed. Took 0.0 secs.
:compileTestJava (Thread[Execution worker for ':',5,main]) started.
> Task :compileTestJava NO-SOURCE
file or directory 'D:\Temp\!deleteme\src\test\java', not found
Skipping task ':compileTestJava' as it has no source files and no previous output files.
:compileTestJava (Thread[Execution worker for ':',5,main]) completed. Took 0.001 secs.
:processTestResources (Thread[Execution worker for ':',5,main]) started.
> Task :processTestResources UP-TO-DATE
Skipping task ':processTestResources' as it is up-to-date.
:processTestResources (Thread[Execution worker for ':',5,main]) completed. Took 0.011 secs.
:testClasses (Thread[Execution worker for ':',5,main]) started.
> Task :testClasses UP-TO-DATE
Skipping task ':testClasses' as it has no actions.
:testClasses (Thread[Execution worker for ':',5,main]) completed. Took 0.0 secs.
:runFatJar (Thread[Execution worker for ':',5,main]) started.
> Task :runFatJar NO-SOURCE
Skipping task ':runFatJar' as it has no source files and no previous output files.
:runFatJar (Thread[Execution worker for ':',5,main]) completed. Took 0.001 secs.
我什至不知道现在为什么要选择它。有没有办法在没有实际源代码文件的情况下强制开始这项工作?