Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vmj/gradle-download-worker
A parallel download task type for Gradle
https://github.com/vmj/gradle-download-worker
download get gradle gradle-plugin groovy groovy-language http parallel worker
Last synced: 2 months ago
JSON representation
A parallel download task type for Gradle
- Host: GitHub
- URL: https://github.com/vmj/gradle-download-worker
- Owner: vmj
- License: gpl-3.0
- Created: 2017-08-16T00:56:23.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-05-26T17:59:32.000Z (8 months ago)
- Last Synced: 2024-11-15T09:49:40.401Z (2 months ago)
- Topics: download, get, gradle, gradle-plugin, groovy, groovy-language, http, parallel, worker
- Language: Groovy
- Size: 178 KB
- Stars: 2
- Watchers: 3
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.adoc
- License: LICENSE
Awesome Lists containing this project
README
= A parallel download task type for Gradle
image:https://travis-ci.org/vmj/gradle-download-worker.svg?branch=master["Build Status", link="https://travis-ci.org/vmj/gradle-download-worker"]
This Gradle plugin implements a parallel download task type.
The releases are available via
https://search.maven.org/artifact/fi.linuxbox.gradle/gradle-download/0.6/jar[Maven Central],
https://bintray.com/bintray/jcenter/fi.linuxbox.gradle%3Agradle-download[Bintray], and
https://plugins.gradle.org/plugin/fi.linuxbox.download[Gradle Plugin Portal].Plugin version 0.7 requires *Gradle 5.6 or newer* (tested up to 8.7).
Version 0.6 supports Gradle versions 5.0 - 7.6.
If you need to use older Gradle (down to 4.3), use version 0.5 of the plugin.== Usage
Basic usage is as follows:
[source,groovy]
----
plugins {
id 'fi.linuxbox.download' version '0.7'
}import fi.linuxbox.gradle.download.Download
task("my-download", type: Download) {
from 'https://www.google.com/robots.txt'
to "$buildDir/robots.txt"
}
----A more interesting example:
[source,groovy]
----
plugins {
id 'fi.linuxbox.download' version '0.7'
}import fi.linuxbox.gradle.download.Download
final downloadAll = tasks.register('downloadAll') {
group 'My tasks'
description 'Download all ChangeLogs'
}ext {
mirror = 'http://ftp.osuosl.org/pub/slackware'
distroNames = ['slackware', 'slackware64']
distroVersions = ['13.0', '13.1', '13.37', '14.0', '14.1', '14.2']
}distroNames.each { final distroName ->
distroVersions.each { final distroVersion ->
final distro = "$distroName-$distroVersion"
final path = "$distroName/$distroVersion"// Define a parallel download task for this distro version
final download = tasks.register("download-$distro-changelog", Download) {
from "$mirror/$distro/ChangeLog.txt"
to "$buildDir/changelogs/$path/ChangeLog.txt"
}// Just to demo the UP-TO-DATE functionality:
// even though the download task does some work (conditional GET)
// it doesn't necessarily touch the artifact.
// That allows Gradle to skip the copy task.
final copy = tasks.register("copy-$distro-changelog", Copy) {
from download
into "$buildDir/copies/$path/"
}downloadAll.configure {
dependsOn copy
}
}
}
----With above build script, the first run of `gradle downloadAll` would download
the ChangeLog files in parallel. Then it would copy each ChangeLog as
soon as it was downloaded, i.e. in parallel.The second invocation of `gradle downloadAll` would finish pretty quickly,
as the download task will make a conditional HTTP GET and,
since the ChangeLogs will not be updated,
copy tasks will report UP-TO-DATE.== Task Configuration
This download task can be configured with the following properties:
.Configuration properties
[cols="2,2,6"]
|===
|Property | Default | Description|`from` | -
| The HTTP or HTTPS URL from which to download. This is mandatory|`to` | -
| Destination file. This is mandatory, and can be anything that is understood by the
https://docs.gradle.org/current/dsl/org.gradle.api.Project.html#org.gradle.api.Project:file(java.lang.Object)[Project.file(path)]
method.|`connectTimeout` | 30000 (30 seconds)
|Milliseconds before timing out the connection attempt. Set to zero to disable the timeout (infinite timeout).|`readTimeout` | 30000 (30 seconds)
|Milliseconds before timing out the socket reading. Set to zero to disable the timeout (infinite timeout).|===
== Programmatic usage (rarely needed)
In case you are using this project as a library dependency (perhaps as part of another Gradle plugin),
in Gradle that would look like:[source,groovy]
----
dependencies {
compile 'fi.linuxbox.gradle:gradle-download:0.7'
}
----And a Maven equivalent is:
[source,xml]
----fi.linuxbox.gradle
gradle-download
0.7----
This is relevant if you are applying the plugin via
https://docs.gradle.org/current/javadoc/org/gradle/api/plugins/PluginContainer.html#apply-java.lang.Class-[PluginContainer.apply(Class)]
method.