From fde7e858d40f02c050c6487373f478ba7c7f285b Mon Sep 17 00:00:00 2001 From: Lars Grefer Date: Wed, 2 Mar 2022 02:42:13 +0100 Subject: [PATCH 1/2] Support up-to-date checking of Format task See gh-323 --- .../javaformat/gradle/tasks/Format.java | 16 ++++++++++++++++ .../javaformat/gradle/FormatTaskTests.java | 19 +++++++++++++++++++ 2 files changed, 35 insertions(+) diff --git a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java index 591377c5..0c9b8b85 100644 --- a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java +++ b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java @@ -19,6 +19,11 @@ import java.io.IOException; import org.gradle.api.GradleException; +import org.gradle.api.file.FileTree; +import org.gradle.api.tasks.InputFiles; +import org.gradle.api.tasks.OutputFiles; +import org.gradle.api.tasks.PathSensitive; +import org.gradle.api.tasks.PathSensitivity; import org.gradle.api.tasks.TaskAction; import io.spring.javaformat.formatter.FileEdit; @@ -51,4 +56,15 @@ public void format() throws IOException, InterruptedException { } } + @Override + @InputFiles + @PathSensitive(PathSensitivity.RELATIVE) + public FileTree getSource() { + return super.getSource(); + } + + @OutputFiles + public FileTree getOutputFiles() { + return super.getSource(); + } } diff --git a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java index 071cf75c..b8cb2197 100644 --- a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java +++ b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java @@ -21,6 +21,7 @@ import java.nio.file.Files; import org.gradle.testkit.runner.BuildResult; +import org.gradle.testkit.runner.GradleRunner; import org.gradle.testkit.runner.TaskOutcome; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; @@ -50,6 +51,24 @@ public void checkOk() throws IOException { assertThat(formattedContent).contains("class Simple {").contains(" public static void main"); } + @Test + public void checkUpTpDate() throws IOException { + GradleRunner runner = this.gradleBuild.source("src/test/resources/format").prepareRunner("format"); + + // 1) Actually format the sources. + BuildResult result1 = runner.build(); + assertThat(result1.task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + + // 2) No-op reformat the sources + // Not up-to-date yet because 1) changed the sources. + BuildResult result2 = runner.build(); + assertThat(result2.task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + + // 3) Now we should be up-to-date since 2) was effectively a no-op + BuildResult result3 = runner.build(); + assertThat(result3.task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.UP_TO_DATE); + } + @Test public void checkSpacesOk() throws IOException { BuildResult result = this.gradleBuild.source("src/test/resources/format-spaces").build("format"); From ae64820d0de0813a7f1df00cecf8fd0e1db9d8cb Mon Sep 17 00:00:00 2001 From: Andy Wilkinson Date: Tue, 24 May 2022 11:55:44 +0100 Subject: [PATCH 2/2] Polish "Support up-to-date checking of Format task" See gh-323 --- .../javaformat/gradle/tasks/CheckFormat.java | 11 +---- .../javaformat/gradle/tasks/Format.java | 13 +----- .../gradle/tasks/FormatterTask.java | 11 +++++ .../javaformat/gradle/FormatTaskTests.java | 46 ++++++++++++++----- 4 files changed, 48 insertions(+), 33 deletions(-) diff --git a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/CheckFormat.java b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/CheckFormat.java index 42bb7057..6487ff6d 100644 --- a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/CheckFormat.java +++ b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/CheckFormat.java @@ -1,5 +1,5 @@ /* - * Copyright 2017-2021 the original author or authors. + * Copyright 2017-2022 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -25,11 +25,8 @@ import java.util.stream.Collectors; import org.gradle.api.GradleException; -import org.gradle.api.file.FileTree; import org.gradle.api.tasks.CacheableTask; import org.gradle.api.tasks.OutputFile; -import org.gradle.api.tasks.PathSensitive; -import org.gradle.api.tasks.PathSensitivity; import org.gradle.api.tasks.TaskAction; import io.spring.javaformat.formatter.FileEdit; @@ -72,12 +69,6 @@ public void checkFormatting() throws IOException, InterruptedException { } } - @Override - @PathSensitive(PathSensitivity.RELATIVE) - public FileTree getSource() { - return super.getSource(); - } - @OutputFile public File getReportLocation() { return this.reportLocation; diff --git a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java index 0c9b8b85..d89abe61 100644 --- a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java +++ b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/Format.java @@ -1,5 +1,5 @@ /* - * Copyright 2017-2021 the original author or authors. + * Copyright 2017-2022 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -20,10 +20,7 @@ import org.gradle.api.GradleException; import org.gradle.api.file.FileTree; -import org.gradle.api.tasks.InputFiles; import org.gradle.api.tasks.OutputFiles; -import org.gradle.api.tasks.PathSensitive; -import org.gradle.api.tasks.PathSensitivity; import org.gradle.api.tasks.TaskAction; import io.spring.javaformat.formatter.FileEdit; @@ -56,15 +53,9 @@ public void format() throws IOException, InterruptedException { } } - @Override - @InputFiles - @PathSensitive(PathSensitivity.RELATIVE) - public FileTree getSource() { - return super.getSource(); - } - @OutputFiles public FileTree getOutputFiles() { return super.getSource(); } + } diff --git a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/FormatterTask.java b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/FormatterTask.java index 88089e3a..ed55a945 100644 --- a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/FormatterTask.java +++ b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/main/java/io/spring/javaformat/gradle/tasks/FormatterTask.java @@ -19,9 +19,13 @@ import java.nio.charset.Charset; import java.util.stream.Stream; +import org.gradle.api.file.FileTree; import org.gradle.api.provider.Property; import org.gradle.api.tasks.Input; +import org.gradle.api.tasks.InputFiles; import org.gradle.api.tasks.Optional; +import org.gradle.api.tasks.PathSensitive; +import org.gradle.api.tasks.PathSensitivity; import org.gradle.api.tasks.SourceTask; import io.spring.javaformat.config.IndentationStyle; @@ -84,6 +88,13 @@ public Property getJavaBaseline() { return this.javaBaseline; } + @Override + @InputFiles + @PathSensitive(PathSensitivity.RELATIVE) + public FileTree getSource() { + return super.getSource(); + } + /** * Format the source files and provide a {@link Stream} of {@link FileEdit} instances. * @return the file edits diff --git a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java index b8cb2197..023b4d0d 100644 --- a/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java +++ b/spring-javaformat-gradle/spring-javaformat-gradle-plugin/src/test/java/io/spring/javaformat/gradle/FormatTaskTests.java @@ -19,6 +19,7 @@ import java.io.File; import java.io.IOException; import java.nio.file.Files; +import java.util.Arrays; import org.gradle.testkit.runner.BuildResult; import org.gradle.testkit.runner.GradleRunner; @@ -52,21 +53,42 @@ public void checkOk() throws IOException { } @Test - public void checkUpTpDate() throws IOException { + public void checkUpToDate() throws IOException { GradleRunner runner = this.gradleBuild.source("src/test/resources/format").prepareRunner("format"); + // Format that changes files + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + // Format of already formatted files + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + // Up-to-date + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.UP_TO_DATE); + } - // 1) Actually format the sources. - BuildResult result1 = runner.build(); - assertThat(result1.task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); - - // 2) No-op reformat the sources - // Not up-to-date yet because 1) changed the sources. - BuildResult result2 = runner.build(); - assertThat(result2.task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + @Test + public void notUpToDateWhenJavaBaselineChanges() throws IOException { + GradleRunner runner = this.gradleBuild.source("src/test/resources/format").prepareRunner("format"); + // Format that changes files + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + // Format of already formatted files + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + // Up-to-date + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.UP_TO_DATE); + Files.write(new File(this.gradleBuild.getProjectDir(), ".springjavaformatconfig").toPath(), + Arrays.asList("java-baseline=8")); + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + } - // 3) Now we should be up-to-date since 2) was effectively a no-op - BuildResult result3 = runner.build(); - assertThat(result3.task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.UP_TO_DATE); + @Test + public void notUpToDateWhenIndentationStyleChanges() throws IOException { + GradleRunner runner = this.gradleBuild.source("src/test/resources/format").prepareRunner("format"); + // Format that changes files + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + // Format of already formatted files + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); + // Up-to-date + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.UP_TO_DATE); + Files.write(new File(this.gradleBuild.getProjectDir(), ".springjavaformatconfig").toPath(), + Arrays.asList("indentation-style=spaces")); + assertThat(runner.build().task(":formatMain").getOutcome()).isEqualTo(TaskOutcome.SUCCESS); } @Test