Судя по предоставленному вами комментарию в сборке Gradle, я предполагаю, что вы установили Gradle на свой локальный компьютер и использовали gradle init
для создания того, что у вас есть. За исключением того, что вы сгенерировали java-library
тип сборки , когда вы должны были сгенерировать тип сборки плагина Gradle.
Поскольку у вас применен плагин groovy
, я предполагаю, что вы хотите использовать Groovy Подключаемый модуль Gradle, поэтому просто снова запустите gradle init
, но выберите groovy-gradle-plugin
тип подключаемого модуля . Например, используя Gradle 6.2.2 на моей локальной машине, мой вывод терминала для генерации проекта плагина Gradle с использованием Groovy показывает:
➜ gradle init
Select type of project to generate:
1: basic
2: application
3: library
4: Gradle plugin
Enter selection (default: basic) [1..4] 4
Select implementation language:
1: Groovy
2: Java
3: Kotlin
Enter selection (default: Java) [1..3] 1
Select build script DSL:
1: Groovy
2: Kotlin
Enter selection (default: Groovy) [1..2] 1
Project name (default: example-groovy):
Source package (default: example.groovy):
> Task :init
Get more help with your project: https://guides.gradle.org?q=Plugin%20Development
BUILD SUCCESSFUL in 17s
2 actionable tasks: 2 executed
Так что теперь у меня есть следующая структура каталогов и файлов:
├── build.gradle
├── gradle
│ └── wrapper
│ ├── gradle-wrapper.jar
│ └── gradle-wrapper.properties
├── gradlew
├── gradlew.bat
├── settings.gradle
└── src
├── functionalTest
│ └── groovy
│ └── example
│ └── groovy
│ └── ExampleGroovyPluginFunctionalTest.groovy
├── main
│ ├── groovy
│ │ └── example
│ │ └── groovy
│ │ └── ExampleGroovyPlugin.groovy
│ └── resources
└── test
├── groovy
│ └── example
│ └── groovy
│ └── ExampleGroovyPluginTest.groovy
└── resources
И сгенерированное содержимое файла сборки Gradle:
/*
* This file was generated by the Gradle 'init' task.
*
* This generated file contains a sample Gradle plugin project to get you started.
* For more details take a look at the Writing Custom Plugins chapter in the Gradle
* User Manual available at https://docs.gradle.org/6.2.2/userguide/custom_plugins.html
*/
plugins {
// Apply the Java Gradle plugin development plugin to add support for developing Gradle plugins
id 'java-gradle-plugin'
// Apply the Groovy plugin to add support for Groovy
id 'groovy'
}
repositories {
// Use jcenter for resolving dependencies.
// You can declare any Maven/Ivy/file repository here.
jcenter()
}
dependencies {
// Use the awesome Spock testing and specification framework
testImplementation 'org.spockframework:spock-core:1.3-groovy-2.5'
}
gradlePlugin {
// Define the plugin
plugins {
greeting {
id = 'example.groovy.greeting'
implementationClass = 'example.groovy.ExampleGroovyPlugin'
}
}
}
// Add a source set for the functional test suite
sourceSets {
functionalTest {
}
}
gradlePlugin.testSourceSets(sourceSets.functionalTest)
configurations.functionalTestImplementation.extendsFrom(configurations.testImplementation)
// Add a task to run the functional tests
task functionalTest(type: Test) {
testClassesDirs = sourceSets.functionalTest.output.classesDirs
classpath = sourceSets.functionalTest.runtimeClasspath
}
check {
// Run the functional tests as part of `check`
dependsOn(tasks.functionalTest)
}