Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marc0der/gradle-spawn-plugin
Gradle plugin for spawning and killing command line processes.
https://github.com/marc0der/gradle-spawn-plugin
Last synced: 3 months ago
JSON representation
Gradle plugin for spawning and killing command line processes.
- Host: GitHub
- URL: https://github.com/marc0der/gradle-spawn-plugin
- Owner: marc0der
- License: apache-2.0
- Created: 2014-03-24T17:31:54.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2019-07-04T16:04:38.000Z (over 5 years ago)
- Last Synced: 2024-04-14T15:09:18.144Z (9 months ago)
- Language: Groovy
- Size: 115 KB
- Stars: 62
- Watchers: 7
- Forks: 29
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
## Gradle Spawn Plugin
This plugin is used for starting and stopping UNIX command line processes from within your build.
A typical application of this plugin is for stopping and starting an embedded web server when running functional tests from within your build.
### Setup
Add the following to your `build.gradle`:
import com.wiredforcode.gradle.spawn.*
buildscript {
repositories {
...
maven { url 'http://dl.bintray.com/vermeulen-mp/gradle-plugins' }
}
dependencies {
classpath 'com.wiredforcode:gradle-spawn-plugin:0.8.0'
}
}apply plugin: 'com.wiredforcode.spawn'
task startServer(type: SpawnProcessTask, dependsOn: 'assemble') {
command "java -jar ${projectDir}/build/libs/zim-service.jar"
ready 'Started Application'
}task stopServer(type: KillProcessTask)
The `startServer` task is used for starting the process.
The command line passed into the `command` method is typically a blocking process. The String passed into the `ready` method is the trigger used for continuing the build once the server process is up and running. If this String is discovered in the stdout stream of the server, the process will be placed into the background and the Gradle build will continue.
Once the build draws to a close, the `stopServer` task is then used to gracefully shut down the server process.
### PID File
The `SpawnProcessTask` will automatically deposit a `.pid.lock` file in the working directory. This contains the PID of the running process.
The `KillProcessTask` will read this lock file, kill the process gracefully, and remove the file.It is also possible to set the name of the pid file allowing more than one process to be opened.
task startServer(type: SpawnProcessTask, dependsOn: 'assemble') {
command "java -jar ${projectDir}/build/libs/zim-service.jar"
ready 'Started Application'
pidLockFileName '.other.pid.lock'
}