diff options
author | Thibault Gagnaux <tgagnaux@gmail.com> | 2021-07-01 19:09:02 +0200 |
---|---|---|
committer | Thibault Gagnaux <tgagnaux@gmail.com> | 2021-07-01 19:09:02 +0200 |
commit | 5ad88075e8e67ece6673999ffd06260c2b5d298d (patch) | |
tree | a332a0515cf1fe80e8c2b38f785f3bd0aad45461 /src/main/java/ch/fhnw | |
parent | b87c1babf4a1d0b9cdf417b8aaf8da8edc473766 (diff) | |
download | frege-gradle-plugin-5ad88075e8e67ece6673999ffd06260c2b5d298d.tar.gz frege-gradle-plugin-5ad88075e8e67ece6673999ffd06260c2b5d298d.tar.bz2 frege-gradle-plugin-5ad88075e8e67ece6673999ffd06260c2b5d298d.zip |
Refactors `SetupFregeCompilerTask` tests
Diffstat (limited to 'src/main/java/ch/fhnw')
3 files changed, 40 insertions, 27 deletions
diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java b/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java index 5e8834d..8a6d175 100644 --- a/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java +++ b/src/main/java/ch/fhnw/thga/gradleplugins/FregeExtension.java @@ -2,32 +2,25 @@ package ch.fhnw.thga.gradleplugins; import javax.inject.Inject; +import org.gradle.api.file.DirectoryProperty; import org.gradle.api.file.ProjectLayout; -import org.gradle.api.file.RegularFileProperty; import org.gradle.api.provider.Property; -import org.gradle.api.provider.Provider; -import groovy.transform.Internal; public abstract class FregeExtension { public static final String DEFAULT_FREGE_EXTENSION_NAMESPACE = "frege"; public static final String FREGE_VERSION_BUILD_FILE_KEY = "fregeVersion"; public static final String FREGE_RELEASE_BUILD_FILE_KEY = "fregeRelease"; - public static final String FREGE_COMPILER_BUILD_FILE_KEY = "fregeCompilerPath"; + public static final String FREGE_COMPILER_OUTPUT_DIRECTORY_KEY = "fregeCompilerOutputDirectory"; public abstract Property<String> getFregeVersion(); public abstract Property<String> getFregeRelease(); - public abstract RegularFileProperty getFregeCompilerPath(); - - @Internal - public Provider<String> getDefaultJarName() { - return getFregeVersion().map(version -> version + ".jar"); - } + public abstract DirectoryProperty getFregeCompilerOutputDirectory(); @Inject public FregeExtension(ProjectLayout projectLayout) { - getFregeCompilerPath().set(projectLayout.getProjectDirectory().file("lib/frege" + getDefaultJarName())); + getFregeCompilerOutputDirectory().convention(projectLayout.getProjectDirectory().dir("lib")); } } diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java b/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java index ffa788f..709552c 100644 --- a/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java +++ b/src/main/java/ch/fhnw/thga/gradleplugins/FregePlugin.java @@ -2,8 +2,6 @@ package ch.fhnw.thga.gradleplugins; import org.gradle.api.Plugin; import org.gradle.api.Project; -import org.gradle.api.file.RegularFile; -import org.gradle.api.provider.Property; public class FregePlugin implements Plugin<Project> { public static final String SETUP_FREGE_COMPILER_TASK_NAME = "setupFregeCompiler"; @@ -16,7 +14,7 @@ public class FregePlugin implements Plugin<Project> { project.getTasks().register(SETUP_FREGE_COMPILER_TASK_NAME, SetupFregeCompilerTask.class, task -> { task.getFregeVersion().set(extension.getFregeVersion()); task.getFregeRelease().set(extension.getFregeRelease()); - task.getFregeCompilerPath().set(extension.getFregeCompilerPath()); + task.getFregeCompilerOutputDirectory().set(extension.getFregeCompilerOutputDirectory()); }); //Configuration fregeCompiler = project.getConfigurations().create("fregeCompiler", c -> { // c.setVisible(false); diff --git a/src/main/java/ch/fhnw/thga/gradleplugins/SetupFregeCompilerTask.java b/src/main/java/ch/fhnw/thga/gradleplugins/SetupFregeCompilerTask.java index a7f48ba..b3d08a1 100644 --- a/src/main/java/ch/fhnw/thga/gradleplugins/SetupFregeCompilerTask.java +++ b/src/main/java/ch/fhnw/thga/gradleplugins/SetupFregeCompilerTask.java @@ -9,13 +9,21 @@ import java.nio.channels.ReadableByteChannel; import org.gradle.api.DefaultTask; import org.gradle.api.GradleException; -import org.gradle.api.file.RegularFileProperty; +import org.gradle.api.file.DirectoryProperty; +import org.gradle.api.file.RegularFile; +import org.gradle.api.logging.Logger; +import org.gradle.api.logging.Logging; import org.gradle.api.provider.Property; +import org.gradle.api.provider.Provider; import org.gradle.api.tasks.Input; +import org.gradle.api.tasks.Internal; import org.gradle.api.tasks.OutputFile; import org.gradle.api.tasks.TaskAction; public abstract class SetupFregeCompilerTask extends DefaultTask { + public static final Logger LOGGER = Logging.getLogger(SetupFregeCompilerTask.class); + + private static final String FREGE_GITHUB_URL_PREFIX = "https://github.com/Frege/frege/releases/download"; @Input public abstract Property<String> getFregeVersion(); @@ -23,21 +31,35 @@ public abstract class SetupFregeCompilerTask extends DefaultTask { @Input public abstract Property<String> getFregeRelease(); + @Internal + public abstract DirectoryProperty getFregeCompilerOutputDirectory(); + + @Internal + public Provider<String> getFregeVersionJarName() { + return getFregeVersion().map(version -> "frege" + version + ".jar"); + } + + @Internal + public Provider<String> getDownloadUrl() { + return getFregeVersionJarName() + .map(name -> String.join("/", FREGE_GITHUB_URL_PREFIX, getFregeRelease().get(), name)); + } + @OutputFile - public abstract RegularFileProperty getFregeCompilerPath(); + public Provider<RegularFile> getFregeCompilerOutputPath() { + return getFregeCompilerOutputDirectory().file(getFregeVersionJarName()); + } @TaskAction public void downloadFregeCompiler() { - try { - ReadableByteChannel readChannel = Channels.newChannel( - new URL("https://github.com/Frege/frege/releases/download/" + - getFregeRelease().get() + "/frege" + getFregeVersion().get() + ".jar").openStream()); - FileOutputStream fregeCompilerDestinationPath = new FileOutputStream(getFregeCompilerPath().get().getAsFile().getAbsolutePath()); - FileChannel writeChannel = fregeCompilerDestinationPath.getChannel(); - writeChannel.transferFrom(readChannel, 0, Long.MAX_VALUE); - System.out.println("Successfully downloaded compiler to" + getFregeCompilerPath().get()); - } catch (IOException e) { - throw new GradleException(e.getMessage()); - } + String fregeCompilerOutputPath = getFregeCompilerOutputPath().get().getAsFile().getAbsolutePath(); + try (ReadableByteChannel readChannel = Channels.newChannel(new URL(getDownloadUrl().get()).openStream()); + FileOutputStream fregeCompilerOutputStream = new FileOutputStream(fregeCompilerOutputPath);) { + FileChannel writeChannel = fregeCompilerOutputStream.getChannel(); + writeChannel.transferFrom(readChannel, 0, Long.MAX_VALUE); + LOGGER.lifecycle(String.format("Successfully downloaded %s to: %s", getFregeVersionJarName().get(), fregeCompilerOutputPath)); + } catch (IOException e) { + throw new GradleException(e.getMessage()); + } } } |