aboutsummaryrefslogtreecommitdiff
path: root/docker/gradle
diff options
context:
space:
mode:
authorRoel Spilker <r.spilker@gmail.com>2017-10-30 23:25:25 +0100
committerRoel Spilker <r.spilker@gmail.com>2017-10-30 23:25:25 +0100
commit975880abdbba376e75f06a5bd6bf0bb7f0a2a885 (patch)
tree6e71a61eb9302b40705940aa47e6ae30722c8a2f /docker/gradle
parentc714a3bbca015ddd639b242323e20928980724e3 (diff)
downloadlombok-975880abdbba376e75f06a5bd6bf0bb7f0a2a885.tar.gz
lombok-975880abdbba376e75f06a5bd6bf0bb7f0a2a885.tar.bz2
lombok-975880abdbba376e75f06a5bd6bf0bb7f0a2a885.zip
use provisioning in docker to enable composition of versions
Diffstat (limited to 'docker/gradle')
-rw-r--r--docker/gradle/Dockerfile22
-rw-r--r--docker/gradle/readme.md33
2 files changed, 45 insertions, 10 deletions
diff --git a/docker/gradle/Dockerfile b/docker/gradle/Dockerfile
index 73d5fa1b..6c5cba15 100644
--- a/docker/gradle/Dockerfile
+++ b/docker/gradle/Dockerfile
@@ -1,19 +1,19 @@
FROM ubuntu:16.04 as downloader
-RUN apt-get update && apt-get install wget -y
-RUN wget --header "Cookie: oraclelicense=accept-securebackup-cookie" http://download.oracle.com/otn-pub/java/jdk/9.0.1+11/jdk-9.0.1_linux-x64_bin.tar.gz -O jdk9_linux-x64_bin.tar.gz
-RUN tar -xzf jdk9_linux-x64_bin.tar.gz -C /opt/
+ARG jdk=1.9
+ADD provision/jdk/java-${jdk}.sh provision/jdk/java-${jdk}.sh
+RUN provision/jdk/java-${jdk}.sh
-RUN wget https://services.gradle.org/distributions/gradle-4.2.1-bin.zip -O gradle.zip
-RUN apt-get update && apt-get install unzip -y
-RUN mkdir /opt/gradle && unzip -d /opt/gradle gradle.zip
+ARG gradle=4.2.1
+ADD provision/gradle/gradle-${gradle}.sh provision/gradle/gradle-${gradle}.sh
+RUN provision/gradle/gradle-${gradle}.sh
FROM ubuntu:16.04
COPY --from=downloader /opt/gradle/ /opt/gradle/
-COPY --from=downloader /opt/jdk-9.0.1/ /opt/jdk-9.0.1/
+COPY --from=downloader /opt/jdk/ /opt/jdk/
-RUN update-alternatives --install /usr/bin/java java /opt/jdk-9.0.1/bin/java 1000 && update-alternatives --install /usr/bin/javac javac /opt/jdk-9.0.1/bin/javac 1000 && update-alternatives --install /usr/bin/javadoc javadoc /opt/jdk-9.0.1/bin/javadoc 1000 && update-alternatives --install /usr/bin/javap javap /opt/jdk-9.0.1/bin/javap 1000
+RUN update-alternatives --install /usr/bin/java java /opt/jdk/bin/java 1000 && update-alternatives --install /usr/bin/javac javac /opt/jdk/bin/javac 1000 && update-alternatives --install /usr/bin/javadoc javadoc /opt/jdk/bin/javadoc 1000 && update-alternatives --install /usr/bin/javap javap /opt/jdk/bin/javap 1000
WORKDIR workspace
@@ -22,8 +22,10 @@ ADD gradle/files/ ./
ARG lombokjar=lombok.jar
ADD https://projectlombok.org/downloads/${lombokjar} lombok.jar
-ENV JAVA_HOME=/opt/jdk-9.0.1
-ENV GRADLE_HOME=/opt/gradle/gradle-4.2.1
+ARG jdk
+ENV JDK_VERSION=${jdk}
+ENV JAVA_HOME=/opt/jdk
+ENV GRADLE_HOME=/opt/gradle/gradle
ENV PATH="${JAVA_HOME}/bin:${GRADLE_HOME}/bin:${PATH}"
ENTRYPOINT bash
diff --git a/docker/gradle/readme.md b/docker/gradle/readme.md
new file mode 100644
index 00000000..efe4f237
--- /dev/null
+++ b/docker/gradle/readme.md
@@ -0,0 +1,33 @@
+## Configuration
+
+[_(general configuration and options)_](../readme.md)
+
+### `ARG gradle=4.2.1`
+
+The gradle version to be used. Supported values:
+
+- `4.2.1` (default)
+
+## Example build commands:
+
+(To be executed from the `<lombokhome>/docker` directory)
+
+```
+docker build -t lombok-gradle-jdk9 -f gradle/Dockerfile .
+
+docker build -t lombok-gradle-jdk9 --build-arg lombokjar=lombok-1.16.18.jar -f gradle/Dockerfile .
+```
+
+## Example run commands:
+
+```
+docker run -it lombok-gradle-jdk9
+
+docker run --rm -it -v /<lombokhome>/dist/lombok.jar:/workspace/lombok.jar lombok-gradle-jdk9
+```
+
+## Example container commands:
+
+```
+gradle assemble
+```