Build: Enforce name is set for all plugins

The plugin name currently defaults to the gradle project name. But the
gradle project name for standalone repo (like an external plugin would
be) defaults to the directory name of the repo. This is trappy, since it
depends on how the repo was checked out.

This change enforces the plugin name is always set.

closes #14603
This commit is contained in:
Ryan Ernst 2015-11-07 16:34:26 -08:00
parent d0f5950c80
commit 8d78f970b0
2 changed files with 17 additions and 13 deletions

View File

@ -42,29 +42,28 @@ class PluginPropertiesTask extends Copy {
} }
dependsOn(copyPluginPropertiesTemplate) dependsOn(copyPluginPropertiesTemplate)
extension = project.extensions.create('esplugin', PluginPropertiesExtension, project) extension = project.extensions.create('esplugin', PluginPropertiesExtension, project)
project.clean { project.clean.delete(generatedResourcesDir)
delete generatedResourcesDir
}
project.afterEvaluate { project.afterEvaluate {
// check require properties are set // check require properties are set
if (extension.name == null) {
throw new InvalidUserDataException('name is a required setting for esplugin')
}
if (extension.description == null) { if (extension.description == null) {
throw new InvalidUserDataException('description is a required setting for esplugin') throw new InvalidUserDataException('description is a required setting for esplugin')
} }
if (extension.jvm && extension.classname == null) { if (extension.jvm && extension.classname == null) {
throw new InvalidUserDataException('classname is a required setting for esplugin with jvm=true') throw new InvalidUserDataException('classname is a required setting for esplugin with jvm=true')
} }
configure { doFirst {
doFirst { if (extension.jvm && extension.isolated == false) {
if (extension.jvm && extension.isolated == false) { String warning = "WARNING: Disabling plugin isolation in ${project.path} is deprecated and will be removed in the future"
String warning = "WARNING: Disabling plugin isolation in ${project.name} is deprecated and will be removed in the future" logger.warn("${'=' * warning.length()}\n${warning}\n${'=' * warning.length()}")
logger.warn("${'=' * warning.length()}\n${warning}\n${'=' * warning.length()}")
}
} }
// configure property substitution
from templateFile
into generatedResourcesDir
expand(generateSubstitutions())
} }
// configure property substitution
from(templateFile)
into(generatedResourcesDir)
expand(generateSubstitutions())
} }
} }

View File

@ -25,6 +25,11 @@ subprojects {
apply plugin: 'elasticsearch.esplugin' apply plugin: 'elasticsearch.esplugin'
apply plugin: 'com.bmuschko.nexus' apply plugin: 'com.bmuschko.nexus'
esplugin {
// for local ES plugins, the name of the plugin is the same as the directory
name project.name
}
Task dependencyLicensesTask = DependencyLicensesTask.configure(project) { Task dependencyLicensesTask = DependencyLicensesTask.configure(project) {
dependencies = project.configurations.runtime - project.configurations.provided dependencies = project.configurations.runtime - project.configurations.provided
} }