-
Introduction =============== This project contains a set of useful gradle plugins
-
Usage ======== In order to use the plugins you need to add this to your build script:
buildscript { repositories { mavenCentral() } dependencies { classpath 'org.linkedin:org.linkedin.gradle-plugins:1.5.0' } }
-
Plugins ==========
org.linkedin.userConfig
is a plugin which attempts to load user configuration (for the gradle
build) in the following files (values read last overrides previous values) and make it available
to all gradle build files as a userConfig
object (instance of groovy.util.ConfigObject
).
Check groovy.util.ConfigSlurper for details on the syntax.
./userConfig.properties
./userConfig-${project.name}.properties
${user.home}/.org.linkedin/userConfig.properties
${user.home}/.org.linkedin/userConfig-${project.name}.properties
${user.home}/.gradle/userConfig.properties
${user.home}/.gradle/userConfig-${project.name}.properties
${user.home}/.userConfig.properties
${user.home}/.userConfig-${project.name}.properties
You can provide your own location by using -PuserConfig.properties=...
(this will override the
entire list).
This plugin should be used only in the root project when doing a multi project build.
org.linkedin.spec
is a plugin which reads a file called project-spec.groovy
(or
project-spec.json
) and makes it available in all build files as a spec
object (instance of
java.util.Map
). This plugin automatically handles spec.version
in this fashion: always force
snapshot mode (meaning version ends with -SNAPSHOT
) unless -Prelease=true
is provided when
running the build. See an example of
this file and how it is being used in this project itself!
org.linkedin.repository
is a plugin which allows you to externalize repository configuration
and override it with your own defaults (for example if you do not want to use maven central). In a
similar fashion to the org.linkedin.userConfig
plugin, it reads an optional set of files (values
read last overrides previous values) and makes it available to all build files as a
allRepositories
object (instance of org.linkedin.gradle.core.RepositoryHandlerContainer).
./repositories.gradle
./repositories-${project.name}.gradle
${user.home}/.org.linkedin/repositories.gradle
${user.home}/.org.linkedin/repositories-${project.name}.gradle
${user.home}/.gradle/repositories.gradle
${user.home}/.gradle/repositories-${project.name}.gradle
${user.home}/.repositories.gradle
${user.home}/.repositories-${project.name}.gradle
You can provide your own location by using -Prepositories.gradle=...
(this will override the
entire list).
This plugin should be used only in the root project when doing a multi project build.
org.linkedin.release
is a plugin which adds release
and publish
tasks. release
is supposed
to build and release in a local repository. publish
is supposed to build and publish in a remote
repository. None of this is enforced and you can still use whichever convention you want. If it is a
java or groovy project, it also releases/publishes sources, javadoc and groovydoc. The plugin also
knows about snapshots (where the version ends with -SNAPSHOT
). The repositories are configured
using the org.linkedin.repository
plugin with the following values:
allRepositories.release -> for release
allRepositories.snapshotRelease -> for release of snapshots
allRepositories.publish -> for publish
allRepositories.snapshotPublish -> for publish of snapshots
See repositories.gradle for an example of configuration.
This plugin is used in every project that needs to be released.
org.linkedin.cmdline
is a plugin which adds the following tasks:
package-assemble
: Assembles the package (exploded)package
: Create the packagepackage-install
: Install the package (locally)package-clean-install
: Cleans the (previously) installed package
and a lib
configuration on which you add your dependencies.
By convention (configurable), the result of the package
task is a tgz which contains a directory
structure like this:
lib/*.jar (all dependencies)
+ whatever directory structure was under 'src/cmdline/resources' (also configurable)
If there is a src/cmdline/resources/bin
folder, then all files in this folder will be tarred up
as executables.
All files under src/cmdline/resources
are also processed through a replacement token plugin if
you provide replacement tokens.
This plugin is highly configurable through the CmdLinePluginConvention
available in the build file
as cmdline
:
example:
dependencies {
lib project(':project1')
lib 'org.json:json:20090211'
}
cmdline {
replacementTokens = [__version__: project.version]
resources << fileTree(dir: rootDir, includes: ['*.txt', '*.md'])
}
- Compilation ============== In order to compile the code you need
- java 1.6+
At the top simply run
./gradlew test
which should compile and run all the tests.
- Directory structure ======================
-
buildSrc
- Contains the code of the plugins
-
org.linkedin.gradle-plugins
- Simple wrapper which uses the plugin themselves to recompile them and make them available for release/publish
-
Build configuration ====================== The project uses the
org.linkedin.userConfig
plugin and as such can be configured the way described in the pluginExample: ~/.userConfig.properties top.build.dir="/Volumes/Disk2/deployment/${userConfig.project.name}" top.install.dir="/export/content/${userConfig.project.name}" top.release.dir="/export/content/repositories/release" top.publish.dir="/export/content/repositories/publish"