From 41da9b3a7115f7a656eff2e5510c40cef87b4319 Mon Sep 17 00:00:00 2001 From: TheSnoozer Date: Sat, 2 Mar 2024 15:43:01 +0100 Subject: [PATCH 1/5] remove unused argument 'reactorProjects' from GitDirLocator --- src/main/java/pl/project13/maven/git/GitCommitIdMojo.java | 2 +- src/main/java/pl/project13/maven/git/GitDirLocator.java | 6 +----- src/test/java/pl/project13/maven/git/GitDirLocatorTest.java | 6 ++---- 3 files changed, 4 insertions(+), 10 deletions(-) diff --git a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java index 51972739..e74b0267 100644 --- a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java +++ b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java @@ -1510,7 +1510,7 @@ private void appendPropertiesToReactorProjects(LogInterface log, Properties prop * @return the File representation of the .git directory */ private File lookupGitDirectory() throws GitCommitIdExecutionException { - return new GitDirLocator(project, reactorProjects).lookupGitDirectory(dotGitDirectory); + return new GitDirLocator(project).lookupGitDirectory(dotGitDirectory); } private void logProperties(LogInterface log, Properties propertiesToPublish) { diff --git a/src/main/java/pl/project13/maven/git/GitDirLocator.java b/src/main/java/pl/project13/maven/git/GitDirLocator.java index 789aa1c1..89952d4a 100644 --- a/src/main/java/pl/project13/maven/git/GitDirLocator.java +++ b/src/main/java/pl/project13/maven/git/GitDirLocator.java @@ -35,18 +35,14 @@ */ public class GitDirLocator { final MavenProject mavenProject; - final List reactorProjects; /** * Constructor to encapsulates all references required to locate a valid .git directory * * @param mavenProject The currently used (maven) project. - * @param reactorProjects The list of reactor projects (sub-projects) of the current (maven) - * project. */ - public GitDirLocator(MavenProject mavenProject, List reactorProjects) { + public GitDirLocator(MavenProject mavenProject) { this.mavenProject = mavenProject; - this.reactorProjects = reactorProjects; } /** diff --git a/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java b/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java index 98dccdbb..24ab9658 100644 --- a/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java +++ b/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java @@ -37,8 +37,6 @@ public class GitDirLocatorTest { @Mock MavenProject project; - List reactorProjects = Collections.emptyList(); - @Rule public TemporaryFolder folder = new TemporaryFolder(); @@ -48,7 +46,7 @@ public void shouldUseTheManuallySpecifiedDirectory() throws Exception { File dotGitDir = folder.newFolder("temp"); try { // when - GitDirLocator locator = new GitDirLocator(project, reactorProjects); + GitDirLocator locator = new GitDirLocator(project); File foundDirectory = locator.lookupGitDirectory(dotGitDir); // then @@ -81,7 +79,7 @@ public void shouldResolveRelativeSubmodule() throws Exception { try { // when - GitDirLocator locator = new GitDirLocator(project, reactorProjects); + GitDirLocator locator = new GitDirLocator(project); File foundDirectory = locator.lookupGitDirectory(dotGitDir); // then From 64d51eed7dd9d3d03f452ddfb4761947341bdb8c Mon Sep 17 00:00:00 2001 From: TheSnoozer Date: Sat, 2 Mar 2024 15:59:00 +0100 Subject: [PATCH 2/5] remove the MavenProject dependency from the GitDirLocator as it is not needed --- .../project13/maven/git/GitCommitIdMojo.java | 2 +- .../pl/project13/maven/git/GitDirLocator.java | 19 +++++++------------ .../maven/git/GitDirLocatorTest.java | 11 ++--------- 3 files changed, 10 insertions(+), 22 deletions(-) diff --git a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java index e74b0267..6a5c9ed2 100644 --- a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java +++ b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java @@ -1510,7 +1510,7 @@ private void appendPropertiesToReactorProjects(LogInterface log, Properties prop * @return the File representation of the .git directory */ private File lookupGitDirectory() throws GitCommitIdExecutionException { - return new GitDirLocator(project).lookupGitDirectory(dotGitDirectory); + return new GitDirLocator(project.getBasedir()).lookupGitDirectory(dotGitDirectory); } private void logProperties(LogInterface log, Properties propertiesToPublish) { diff --git a/src/main/java/pl/project13/maven/git/GitDirLocator.java b/src/main/java/pl/project13/maven/git/GitDirLocator.java index 89952d4a..59d3bd23 100644 --- a/src/main/java/pl/project13/maven/git/GitDirLocator.java +++ b/src/main/java/pl/project13/maven/git/GitDirLocator.java @@ -23,10 +23,8 @@ import java.io.FileReader; import java.io.IOException; import java.nio.file.Path; -import java.util.List; import javax.annotation.Nonnull; import javax.annotation.Nullable; -import org.apache.maven.project.MavenProject; import org.eclipse.jgit.lib.Constants; /** @@ -34,15 +32,16 @@ * it's not already specified, this logic will try to find it. */ public class GitDirLocator { - final MavenProject mavenProject; + final File projectBasedir; /** * Constructor to encapsulates all references required to locate a valid .git directory * - * @param mavenProject The currently used (maven) project. + * @param projectBasedir The project basedir that will be used as last resort to search + * the parent project hierarchy until a .git directory is found. */ - public GitDirLocator(MavenProject mavenProject) { - this.mavenProject = mavenProject; + public GitDirLocator(File projectBasedir) { + this.projectBasedir = projectBasedir; } /** @@ -82,17 +81,13 @@ public File lookupGitDirectory(@Nonnull File manuallyConfiguredDir) { } /** - * Search up all the maven parent project hierarchy until a .git directory is found. + * Search up all the parent project hierarchy until a .git directory is found. * * @return File which represents the location of the .git directory or NULL if none found. */ @Nullable private File findProjectGitDirectory() { - if (this.mavenProject == null) { - return null; - } - - File basedir = mavenProject.getBasedir(); + File basedir = this.projectBasedir; while (basedir != null) { File gitdir = new File(basedir, Constants.DOT_GIT); if (gitdir.exists()) { diff --git a/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java b/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java index 24ab9658..63761043 100644 --- a/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java +++ b/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java @@ -22,21 +22,14 @@ import java.io.File; import java.nio.file.Files; -import java.util.Collections; -import java.util.List; -import org.apache.maven.project.MavenProject; import org.junit.Rule; import org.junit.Test; import org.junit.rules.TemporaryFolder; import org.junit.runner.RunWith; -import org.mockito.Mock; import org.mockito.junit.MockitoJUnitRunner; @RunWith(MockitoJUnitRunner.class) public class GitDirLocatorTest { - - @Mock MavenProject project; - @Rule public TemporaryFolder folder = new TemporaryFolder(); @@ -46,7 +39,7 @@ public void shouldUseTheManuallySpecifiedDirectory() throws Exception { File dotGitDir = folder.newFolder("temp"); try { // when - GitDirLocator locator = new GitDirLocator(project); + GitDirLocator locator = new GitDirLocator(dotGitDir); File foundDirectory = locator.lookupGitDirectory(dotGitDir); // then @@ -79,7 +72,7 @@ public void shouldResolveRelativeSubmodule() throws Exception { try { // when - GitDirLocator locator = new GitDirLocator(project); + GitDirLocator locator = new GitDirLocator(dotGitDir); File foundDirectory = locator.lookupGitDirectory(dotGitDir); // then From 0d17e0627e7fc7a1a90d3eab27f03658fe337eb8 Mon Sep 17 00:00:00 2001 From: TheSnoozer Date: Sat, 2 Mar 2024 18:08:10 +0100 Subject: [PATCH 3/5] remove logic that was moved to the git-commit-id-plugin-core --- .../project13/maven/git/GitCommitIdMojo.java | 28 --- .../pl/project13/maven/git/GitDirLocator.java | 174 ------------------ .../maven/git/GitDirLocatorTest.java | 120 ------------ 3 files changed, 322 deletions(-) delete mode 100644 src/main/java/pl/project13/maven/git/GitDirLocator.java delete mode 100644 src/test/java/pl/project13/maven/git/GitDirLocatorTest.java diff --git a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java index 6a5c9ed2..f956da32 100644 --- a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java +++ b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java @@ -1207,24 +1207,10 @@ public void error(String msg, Throwable t) { return; } - dotGitDirectory = lookupGitDirectory(); - if (failOnNoGitDirectory && !directoryExists(dotGitDirectory)) { - throw new GitCommitIdExecutionException( - ".git directory is not found! Please specify a valid [dotGitDirectory] in your" - + " pom.xml"); - } - if (gitDescribe == null) { gitDescribe = new GitDescribeConfig(); } - if (dotGitDirectory != null) { - log.info("dotGitDirectory '" + dotGitDirectory.getAbsolutePath() + "'"); - } else { - log.info("dotGitDirectory is null, aborting execution!"); - return; - } - try { commitIdGenerationModeEnum = CommitIdGenerationMode.valueOf(commitIdGenerationMode.toUpperCase()); @@ -1503,16 +1489,6 @@ private void appendPropertiesToReactorProjects(LogInterface log, Properties prop log.info("Added properties to '" + reactorProjects.size() + "' projects"); } - /** - * Find the git directory of the currently used project. If it's not already specified, this - * method will try to find it. - * - * @return the File representation of the .git directory - */ - private File lookupGitDirectory() throws GitCommitIdExecutionException { - return new GitDirLocator(project.getBasedir()).lookupGitDirectory(dotGitDirectory); - } - private void logProperties(LogInterface log, Properties propertiesToPublish) { for (String propertyName : propertiesToPublish.stringPropertyNames()) { log.info("including property '" + propertyName + "' in results"); @@ -1522,8 +1498,4 @@ private void logProperties(LogInterface log, Properties propertiesToPublish) { private boolean isPomProject(@Nonnull MavenProject project) { return project.getPackaging().equalsIgnoreCase("pom"); } - - private boolean directoryExists(@Nullable File fileLocation) { - return fileLocation != null && fileLocation.exists() && fileLocation.isDirectory(); - } } diff --git a/src/main/java/pl/project13/maven/git/GitDirLocator.java b/src/main/java/pl/project13/maven/git/GitDirLocator.java deleted file mode 100644 index 59d3bd23..00000000 --- a/src/main/java/pl/project13/maven/git/GitDirLocator.java +++ /dev/null @@ -1,174 +0,0 @@ -/* - * This file is part of git-commit-id-maven-plugin - * Originally invented by Konrad 'ktoso' Malawski - * - * git-commit-id-maven-plugin is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * git-commit-id-maven-plugin is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with git-commit-id-maven-plugin. If not, see . - */ - -package pl.project13.maven.git; - -import java.io.BufferedReader; -import java.io.File; -import java.io.FileReader; -import java.io.IOException; -import java.nio.file.Path; -import javax.annotation.Nonnull; -import javax.annotation.Nullable; -import org.eclipse.jgit.lib.Constants; - -/** - * This class encapsulates logic to locate a valid .git directory of the currently used project. If - * it's not already specified, this logic will try to find it. - */ -public class GitDirLocator { - final File projectBasedir; - - /** - * Constructor to encapsulates all references required to locate a valid .git directory - * - * @param projectBasedir The project basedir that will be used as last resort to search - * the parent project hierarchy until a .git directory is found. - */ - public GitDirLocator(File projectBasedir) { - this.projectBasedir = projectBasedir; - } - - /** - * Attempts to lookup a valid .git directory of the currently used project. - * - * @param manuallyConfiguredDir A user has the ability to configure a git-directory with the - * {@code dotGitDirectory} configuration setting. By default it should be simply {@code - * ${project.basedir}/.git} - * @return A valid .git directory, or {@code null} if none could be found under the user specified - * location or within the project or it's reactor projects. - */ - @Nullable - public File lookupGitDirectory(@Nonnull File manuallyConfiguredDir) { - if (manuallyConfiguredDir.exists()) { - - // If manuallyConfiguredDir is a directory then we can use it as the git path. - if (manuallyConfiguredDir.isDirectory()) { - return manuallyConfiguredDir; - } - - // If the path exists but is not a directory it might be a git submodule "gitdir" link. - File gitDirLinkPath = processGitDirFile(manuallyConfiguredDir); - - // If the linkPath was found from the file and it exists then use it. - if (isExistingDirectory(gitDirLinkPath)) { - return gitDirLinkPath; - } - - /* - * FIXME: I think we should fail here because a manual path was set and it was not found - * but I'm leaving it falling back to searching for the git path because that is the current - * behaviour - Unluckypixie. - */ - } - - return findProjectGitDirectory(); - } - - /** - * Search up all the parent project hierarchy until a .git directory is found. - * - * @return File which represents the location of the .git directory or NULL if none found. - */ - @Nullable - private File findProjectGitDirectory() { - File basedir = this.projectBasedir; - while (basedir != null) { - File gitdir = new File(basedir, Constants.DOT_GIT); - if (gitdir.exists()) { - if (gitdir.isDirectory()) { - return gitdir; - } else if (gitdir.isFile()) { - return processGitDirFile(gitdir); - } else { - return null; - } - } - basedir = basedir.getParentFile(); - } - return null; - } - - /** - * Load a ".git" git submodule file and read the gitdir path from it. - * - * @return File object with path loaded or null - */ - private File processGitDirFile(@Nonnull File file) { - try (BufferedReader reader = new BufferedReader(new FileReader(file))) { - // There should be just one line in the file, e.g. - // "gitdir: /usr/local/src/parentproject/.git/modules/submodule" - String line = reader.readLine(); - if (line == null) { - return null; - } - // Separate the key and the value in the string. - String[] parts = line.split(": "); - - // If we don't have 2 parts or if the key is not gitdir then give up. - if (parts.length != 2 || !parts[0].equals("gitdir")) { - return null; - } - - // All seems ok so return the "gitdir" value read from the file. - String extractFromConfig = parts[1]; - File gitDir = resolveWorktree(new File(extractFromConfig)); - if (gitDir.isAbsolute()) { - // gitdir value is an absolute path. Return as-is - return gitDir; - } else { - // gitdir value is relative. - return new File(file.getParentFile(), extractFromConfig); - } - } catch (IOException e) { - return null; - } - } - - /** - * Attempts to resolve the actual location of the .git folder for a given - * worktree. - * For example for a worktree like {@code a/.git/worktrees/X} structure would - * return {@code a/.git}. - * - * If the conditions for a git worktree like file structure are met simply return the provided - * argument as is. - */ - static File resolveWorktree(File fileLocation) { - Path parent = fileLocation.toPath().getParent(); - if (parent == null) { - return fileLocation; - } - if (parent.endsWith(Path.of(".git", "worktrees"))) { - return parent.getParent().toFile(); - } - return fileLocation; - } - - /** - * Helper method to validate that the specified {@code File} is an existing directory. - * - * @param fileLocation The {@code File} that should be checked if it's actually an existing - * directory. - * @return {@code true} if the specified {@code File} is an existing directory, {@false} - * otherwise. - */ - private static boolean isExistingDirectory(@Nullable File fileLocation) { - return fileLocation != null && fileLocation.exists() && fileLocation.isDirectory(); - } -} diff --git a/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java b/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java deleted file mode 100644 index 63761043..00000000 --- a/src/test/java/pl/project13/maven/git/GitDirLocatorTest.java +++ /dev/null @@ -1,120 +0,0 @@ -/* - * This file is part of git-commit-id-maven-plugin - * Originally invented by Konrad 'ktoso' Malawski - * - * git-commit-id-maven-plugin is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * git-commit-id-maven-plugin is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with git-commit-id-maven-plugin. If not, see . - */ - -package pl.project13.maven.git; - -import static org.assertj.core.api.Assertions.assertThat; - -import java.io.File; -import java.nio.file.Files; -import org.junit.Rule; -import org.junit.Test; -import org.junit.rules.TemporaryFolder; -import org.junit.runner.RunWith; -import org.mockito.junit.MockitoJUnitRunner; - -@RunWith(MockitoJUnitRunner.class) -public class GitDirLocatorTest { - @Rule - public TemporaryFolder folder = new TemporaryFolder(); - - @Test - public void shouldUseTheManuallySpecifiedDirectory() throws Exception { - // given - File dotGitDir = folder.newFolder("temp"); - try { - // when - GitDirLocator locator = new GitDirLocator(dotGitDir); - File foundDirectory = locator.lookupGitDirectory(dotGitDir); - - // then - assertThat(foundDirectory).isNotNull(); - assertThat(foundDirectory.getAbsolutePath()).isEqualTo(dotGitDir.getAbsolutePath()); - } finally { - if (!dotGitDir.delete()) { - dotGitDir.deleteOnExit(); - } - } - } - - @Test - public void shouldResolveRelativeSubmodule() throws Exception { - // given - folder.newFolder("main-project"); - folder.newFolder("main-project", ".git", "modules", "sub-module"); - folder.newFolder("main-project", "sub-module"); - - // and a .git dir in submodule that points to the main's project .git/modules/submodule - File dotGitDir = folder.getRoot().toPath() - .resolve("main-project") - .resolve("sub-module") - .resolve(".git") - .toFile(); - Files.write( - dotGitDir.toPath(), - "gitdir: ../.git/modules/sub-module".getBytes() - ); - - try { - // when - GitDirLocator locator = new GitDirLocator(dotGitDir); - File foundDirectory = locator.lookupGitDirectory(dotGitDir); - - // then - assertThat(foundDirectory).isNotNull(); - assertThat( - foundDirectory.getCanonicalFile() - ).isEqualTo( - folder.getRoot().toPath() - .resolve("main-project") - .resolve(".git") - .resolve("modules") - .resolve("sub-module") - .toFile() - ); - } finally { - if (!dotGitDir.delete()) { - dotGitDir.deleteOnExit(); - } - } - } - - @Test - public void testWorktreeResolution() { - // tests to ensure we do not try to modify things that should not be modified - String[] noopCases = { - "", - "a", - "a/b", - ".git/worktrees", - ".git/worktrees/", - "a.git/worktrees/b", - ".git/modules", - ".git/modules/", - "a.git/modules/b", - }; - for (String path : noopCases) { - assertThat(GitDirLocator.resolveWorktree(new File(path))).isEqualTo(new File(path)); - } - // tests that worktree resolution works - assertThat(GitDirLocator.resolveWorktree(new File("a/.git/worktrees/b"))) - .isEqualTo(new File("a/.git")); - assertThat(GitDirLocator.resolveWorktree(new File("/a/.git/worktrees/b"))) - .isEqualTo(new File("/a/.git")); - } -} From 4555113c109348e9f110de322bf35e8e6c262861 Mon Sep 17 00:00:00 2001 From: TheSnoozer Date: Sat, 2 Mar 2024 19:22:56 +0100 Subject: [PATCH 4/5] https://github.com/git-commit-id/git-commit-id-maven-plugin/issues/701: adopt to the new git-commit-id-plugin-core --- pom.xml | 2 +- src/main/java/pl/project13/maven/git/GitCommitIdMojo.java | 5 +++++ .../project13/maven/git/GitCommitIdMojoIntegrationTest.java | 3 ++- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/pom.xml b/pom.xml index c757aca3..598e3ab1 100644 --- a/pom.xml +++ b/pom.xml @@ -63,7 +63,7 @@ ${project.groupId} git-commit-id-plugin-core - 6.0.0-rc.6 + 6.1.0-SNAPSHOT com.google.code.findbugs diff --git a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java index f956da32..a61e8f64 100644 --- a/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java +++ b/src/main/java/pl/project13/maven/git/GitCommitIdMojo.java @@ -1397,6 +1397,11 @@ public Charset getPropertiesSourceCharset() { public boolean shouldPropertiesEscapeUnicode() { return generateGitPropertiesFileWithEscapedUnicode; } + + @Override + public boolean shouldFailOnNoGitDirectory() { + return failOnNoGitDirectory; + } }; GitCommitIdPlugin.runPlugin(cb, properties); diff --git a/src/test/java/pl/project13/maven/git/GitCommitIdMojoIntegrationTest.java b/src/test/java/pl/project13/maven/git/GitCommitIdMojoIntegrationTest.java index ee1a0608..a920620f 100644 --- a/src/test/java/pl/project13/maven/git/GitCommitIdMojoIntegrationTest.java +++ b/src/test/java/pl/project13/maven/git/GitCommitIdMojoIntegrationTest.java @@ -585,7 +585,8 @@ public void shouldSkipWithoutFailOnNoGitDirectoryWhenNoGitRepoFound(boolean useN mojo.execute(); // then - assertThat(targetProject.getProperties()).isEmpty(); + assertThat(targetProject.getProperties().keySet()).containsOnly( + "git.build.time", "git.build.version", "git.build.host"); } @Test From 723e8c23a722e3c03eeb1e4c073be37a2174bd7a Mon Sep 17 00:00:00 2001 From: TheSnoozer Date: Sun, 3 Mar 2024 21:09:36 +0100 Subject: [PATCH 5/5] make use of git-commit-id-plugin-core:6.0.0-rc.7 --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 598e3ab1..341971de 100644 --- a/pom.xml +++ b/pom.xml @@ -63,7 +63,7 @@ ${project.groupId} git-commit-id-plugin-core - 6.1.0-SNAPSHOT + 6.0.0-rc.7 com.google.code.findbugs