aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLukasz Jarocki <lukasz.jarocki@sonarsource.com>2021-06-16 12:26:19 +0200
committersonartech <sonartech@sonarsource.com>2021-06-16 20:03:04 +0000
commit4b3c4c470de083be2f7245d9c38dabc10f943026 (patch)
tree21a1be1f779801732ad3f92b347cbc46f4e44613
parent1ed0e60ea8bbcbd242f00b018b209f41848ada4c (diff)
downloadsonarqube-4b3c4c470de083be2f7245d9c38dabc10f943026.tar.gz
sonarqube-4b3c4c470de083be2f7245d9c38dabc10f943026.zip
SONAR-14924 fixed a bug where running analysis inside submodule sometimes were not detecting any changes
-rw-r--r--sonar-scanner-engine/src/main/java/org/sonar/scm/git/GitScmProvider.java11
-rw-r--r--sonar-scanner-engine/src/test/java/org/sonar/scm/git/GitScmProviderTest.java89
2 files changed, 84 insertions, 16 deletions
diff --git a/sonar-scanner-engine/src/main/java/org/sonar/scm/git/GitScmProvider.java b/sonar-scanner-engine/src/main/java/org/sonar/scm/git/GitScmProvider.java
index 8342668300f..f728b2be2ac 100644
--- a/sonar-scanner-engine/src/main/java/org/sonar/scm/git/GitScmProvider.java
+++ b/sonar-scanner-engine/src/main/java/org/sonar/scm/git/GitScmProvider.java
@@ -170,10 +170,9 @@ public class GitScmProvider extends ScmProvider {
}
Map<Path, Set<Integer>> changedLines = new HashMap<>();
- Path repoRootDir = repo.getDirectory().toPath().getParent();
for (Path path : changedFiles) {
- collectChangedLines(repo, mergeBaseCommit.get(), changedLines, repoRootDir, path);
+ collectChangedLines(repo, mergeBaseCommit.get(), changedLines, path);
}
return changedLines;
} catch (Exception e) {
@@ -182,7 +181,7 @@ public class GitScmProvider extends ScmProvider {
return null;
}
- private void collectChangedLines(Repository repo, RevCommit mergeBaseCommit, Map<Path, Set<Integer>> changedLines, Path repoRootDir, Path changedFile) {
+ private void collectChangedLines(Repository repo, RevCommit mergeBaseCommit, Map<Path, Set<Integer>> changedLines, Path changedFile) {
ChangedLinesComputer computer = new ChangedLinesComputer();
try (DiffFormatter diffFmt = new DiffFormatter(new BufferedOutputStream(computer.receiver()))) {
@@ -190,7 +189,11 @@ public class GitScmProvider extends ScmProvider {
diffFmt.setRepository(repo);
diffFmt.setProgressMonitor(NullProgressMonitor.INSTANCE);
diffFmt.setDiffComparator(RawTextComparator.WS_IGNORE_ALL);
- diffFmt.setPathFilter(PathFilter.create(toGitPath(repoRootDir.relativize(changedFile).toString())));
+
+ Path workTree = repo.getWorkTree().toPath();
+ String relativePath = workTree.relativize(changedFile).toString();
+ PathFilter pathFilter = PathFilter.create(toGitPath(relativePath));
+ diffFmt.setPathFilter(pathFilter);
AbstractTreeIterator mergeBaseTree = prepareTreeParser(repo, mergeBaseCommit);
List<DiffEntry> diffEntries = diffFmt.scan(mergeBaseTree, new FileTreeIterator(repo));
diff --git a/sonar-scanner-engine/src/test/java/org/sonar/scm/git/GitScmProviderTest.java b/sonar-scanner-engine/src/test/java/org/sonar/scm/git/GitScmProviderTest.java
index 8f603f32b08..3082c716bc9 100644
--- a/sonar-scanner-engine/src/test/java/org/sonar/scm/git/GitScmProviderTest.java
+++ b/sonar-scanner-engine/src/test/java/org/sonar/scm/git/GitScmProviderTest.java
@@ -44,8 +44,11 @@ import org.eclipse.jgit.api.Git;
import org.eclipse.jgit.api.errors.GitAPIException;
import org.eclipse.jgit.lib.ObjectId;
import org.eclipse.jgit.lib.PersonIdent;
+import org.eclipse.jgit.lib.Ref;
import org.eclipse.jgit.lib.RefDatabase;
import org.eclipse.jgit.lib.Repository;
+import org.eclipse.jgit.lib.RepositoryBuilder;
+import org.eclipse.jgit.merge.MergeStrategy;
import org.eclipse.jgit.revwalk.RevCommit;
import org.eclipse.jgit.storage.file.FileRepositoryBuilder;
import org.eclipse.jgit.treewalk.AbstractTreeIterator;
@@ -125,10 +128,7 @@ public class GitScmProviderTest {
@Before
public void before() throws IOException, GitAPIException {
worktree = temp.newFolder().toPath();
- Repository repo = FileRepositoryBuilder.create(worktree.resolve(".git").toFile());
- repo.create();
-
- git = new Git(repo);
+ git = createRepository(worktree);
createAndCommitFile("file-in-first-commit.xoo");
}
@@ -269,6 +269,58 @@ public class GitScmProviderTest {
}
@Test
+ public void branchChangedLines_given2NestedSubmodulesWithChangesInTheBottomSubmodule_detectChanges() throws IOException, GitAPIException {
+ Git gitForRepo2, gitForRepo3;
+ Path worktreeForRepo2, worktreeForRepo3;
+
+ worktreeForRepo2 = temp.newFolder().toPath();
+ gitForRepo2 = createRepository(worktreeForRepo2);
+
+ worktreeForRepo3 = temp.newFolder().toPath();
+ gitForRepo3 = createRepository(worktreeForRepo3);
+
+ createAndCommitFile("sub2.js", gitForRepo3, worktreeForRepo3);
+
+ addSubmodule(gitForRepo2, "sub2", worktreeForRepo3.toUri().toString());
+ addSubmodule(git, "sub1", worktreeForRepo2.toUri().toString());
+
+ File mainFolderWithAllSubmodules = temp.newFolder();
+ Git.cloneRepository()
+ .setURI(worktree.toUri().toString())
+ .setDirectory(mainFolderWithAllSubmodules)
+ .setCloneSubmodules(true)
+ .call();
+ Path submodule2Path = mainFolderWithAllSubmodules.toPath().resolve("sub1/sub2");
+ Repository submodule2 = new RepositoryBuilder().findGitDir(submodule2Path.toFile()).build();
+ Git gitForSubmodule2 = new Git(submodule2);
+
+ gitForSubmodule2.branchCreate().setName("develop").call();
+ gitForSubmodule2.checkout().setName("develop").call();
+
+ Path submodule2File = mainFolderWithAllSubmodules.toPath().resolve("sub1/sub2/sub2.js");
+
+ Files.write(submodule2File, randomizedContent("sub2.js", 3).getBytes(), StandardOpenOption.APPEND);
+ gitForSubmodule2.add().addFilepattern("sub2.js").call();
+ gitForSubmodule2.commit().setAuthor("joe", "joe@example.com").setMessage("important change").call();
+
+ Map<Path, Set<Integer>> changedLines = newScmProvider().branchChangedLines("master", submodule2Path, Set.of(submodule2File));
+
+ assertThat(changedLines).hasSize(1);
+ assertThat(changedLines.entrySet().iterator().next().getValue()).containsOnly(4, 5, 6);
+ }
+
+ private Git createRepository(Path worktree) throws IOException {
+ Repository repo = FileRepositoryBuilder.create(worktree.resolve(".git").toFile());
+ repo.create();
+ return new Git(repo);
+ }
+
+ private void addSubmodule(Git mainGit, String submoduleName, String uriToSubmodule) throws GitAPIException {
+ mainGit.submoduleAdd().setPath(submoduleName).setURI(uriToSubmodule).call();
+ mainGit.commit().setAuthor("joe", "joe@example.com").setMessage("adding submodule").call();
+ }
+
+ @Test
public void forkDate_from_diverged() throws IOException, GitAPIException {
createAndCommitFile("file-m1.xoo", Instant.now().minus(8, ChronoUnit.DAYS));
createAndCommitFile("file-m2.xoo", Instant.now().minus(7, ChronoUnit.DAYS));
@@ -767,20 +819,29 @@ public class GitScmProviderTest {
}
private void createAndCommitFile(String relativePath) throws IOException, GitAPIException {
- createAndCommitFile(relativePath, randomizedContent(relativePath, 3));
+ createAndCommitFile(relativePath, randomizedContent(relativePath, 3), git, this.worktree);
}
private void createAndCommitFile(String relativePath, Instant commitDate) throws IOException, GitAPIException {
- createFile(relativePath, randomizedContent(relativePath, 3));
+ createFile(relativePath, randomizedContent(relativePath, 3), this.worktree);
commit(relativePath, commitDate);
}
+
+ private void createAndCommitFile(String fileName, Git git, Path worktree) throws IOException, GitAPIException {
+ createAndCommitFile(fileName, randomizedContent(fileName, 3), git, worktree);
+ }
+
private void createAndCommitFile(String relativePath, String content) throws IOException, GitAPIException {
- createFile(relativePath, content);
- commit(relativePath);
+ createAndCommitFile(relativePath, content, this.git, this.worktree);
+ }
+
+ private void createAndCommitFile(String relativePath, String content, Git git, Path worktree) throws IOException, GitAPIException {
+ createFile(relativePath, content, worktree);
+ commit(git, relativePath);
}
- private void createFile(String relativePath, String content) throws IOException {
+ private void createFile(String relativePath, String content, Path worktree) throws IOException {
Path newFile = worktree.resolve(relativePath);
Files.createDirectories(newFile.getParent());
Files.write(newFile, content.getBytes(), StandardOpenOption.CREATE);
@@ -802,15 +863,15 @@ public class GitScmProviderTest {
private void appendToAndCommitFile(String relativePath) throws IOException, GitAPIException {
Files.write(worktree.resolve(relativePath), randomizedContent(relativePath, 1).getBytes(), StandardOpenOption.APPEND);
- commit(relativePath);
+ commit(this.git, relativePath);
}
private void deleteAndCommitFile(String relativePath) throws GitAPIException {
git.rm().addFilepattern(relativePath).call();
- commit(relativePath);
+ commit(this.git, relativePath);
}
- private void commit(String... relativePaths) throws GitAPIException {
+ private void commit(Git git, String... relativePaths) throws GitAPIException {
for (String path : relativePaths) {
git.add().addFilepattern(path).call();
}
@@ -818,6 +879,10 @@ public class GitScmProviderTest {
git.commit().setAuthor("joe", "joe@example.com").setMessage(msg).call();
}
+ private void commit(String... relativePaths) throws GitAPIException {
+ commit(this.git, relativePaths);
+ }
+
private void commit(String relativePath, Instant date) throws GitAPIException {
PersonIdent person = new PersonIdent("joe", "joe@example.com", Date.from(date), TimeZone.getDefault());
git.commit().setAuthor(person).setCommitter(person).setMessage(relativePath).call();