Я очень новичок в мире 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 уже,Чтобы уточнить это: у меня есть проект А, который создает этот толстый фляга, и я хочу иметь проект Б, который имеет только задачу runFatJar
и не имеет источников.
Я пытался сделать что-то подобноес моим проектом 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.
Я даже не знаю, зачем ему это делать.Есть ли способ заставить эту работу начать без фактических файлов исходного кода?