From 99902dfcd7cae02fb21254f60a6dfa39d75b014b Mon Sep 17 00:00:00 2001 From: Marquis Wong Date: Fri, 23 Apr 2021 12:26:25 -0500 Subject: [PATCH] Send comments as robotComments (#238) Robot comments show up in the Findings tab, instead of in the comments. This makes it much easier to differentiate from them a reviewer's comments. The API requires a "runId" for the comment. I've chosen to just send a random UUID for now, but eventually we could wire in something like a build number or something. --- .../connector/gerrit/ReviewInputBuilder.java | 20 ++++++++++++------- .../gerrit/ReviewInputBuilderTest.java | 14 ++++++++++--- 2 files changed, 24 insertions(+), 10 deletions(-) diff --git a/src/main/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilder.java b/src/main/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilder.java index 972ec6e8..5929cb99 100644 --- a/src/main/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilder.java +++ b/src/main/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilder.java @@ -2,6 +2,7 @@ import com.google.common.base.Joiner; import com.google.gerrit.extensions.api.changes.ReviewInput; +import java.util.UUID; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; @@ -18,7 +19,7 @@ @AllArgsConstructor @Slf4j public class ReviewInputBuilder { - + private static final String ROBOT_ID = "sputnik"; private static final String MESSAGE_SEPARATOR = ". "; @NotNull @@ -29,21 +30,26 @@ public ReviewInput toReviewInput(@NotNull Review review, @Nullable String tag) { if (StringUtils.isNotBlank(tag)) { reviewInput.tag = tag; } - reviewInput.comments = review.getFiles().stream() - .collect(Collectors.toMap(ReviewFile::getReviewFilename, this::buildFileComments)); + + String runId = UUID.randomUUID().toString(); + reviewInput.robotComments = review.getFiles().stream() + .collect(Collectors.toMap(ReviewFile::getReviewFilename, reviewFile -> buildFileComments(reviewFile, runId))); return reviewInput; } @NotNull - private List buildFileComments(@NotNull ReviewFile reviewFile) { + private List buildFileComments(@NotNull ReviewFile reviewFile, String runId) { return reviewFile.getComments().stream() - .map(this::buildCommentInput) + .map((Comment comment) -> buildCommentInput(comment, runId)) .collect(Collectors.toList()); } @NotNull - private ReviewInput.CommentInput buildCommentInput(Comment comment) { - ReviewInput.CommentInput commentInput = new ReviewInput.CommentInput(); + private ReviewInput.RobotCommentInput buildCommentInput(Comment comment, String runId) { + ReviewInput.RobotCommentInput commentInput = new ReviewInput.RobotCommentInput(); + + commentInput.robotId = ROBOT_ID; + commentInput.robotRunId = runId; commentInput.line = comment.getLine(); commentInput.message = comment.getMessage(); return commentInput; diff --git a/src/test/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilderTest.java b/src/test/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilderTest.java index 4799769f..7c21317c 100644 --- a/src/test/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilderTest.java +++ b/src/test/java/pl/touk/sputnik/connector/gerrit/ReviewInputBuilderTest.java @@ -1,6 +1,7 @@ package pl.touk.sputnik.connector.gerrit; import com.google.gerrit.extensions.api.changes.ReviewInput; +import com.google.gerrit.extensions.api.changes.ReviewInput.RobotCommentInput; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.junit.jupiter.params.ParameterizedTest; @@ -11,6 +12,8 @@ import pl.touk.sputnik.configuration.ConfigurationBuilder; import pl.touk.sputnik.review.Review; +import java.util.List; + import static org.assertj.core.api.Assertions.assertThat; @ExtendWith(MockitoExtension.class) @@ -28,10 +31,15 @@ void shouldBuildReviewInput() { ReviewInput reviewInput = reviewInputBuilder.toReviewInput(review, TAG); assertThat(reviewInput.message).isEqualTo("Total 8 violations found"); - assertThat(reviewInput.comments).hasSize(4); + assertThat(reviewInput.comments).isNull(); + assertThat(reviewInput.robotComments).hasSize(4); assertThat(reviewInput.tag).isEqualTo(TAG); - assertThat(reviewInput.comments.get("filename1")).hasSize(2); - assertThat(reviewInput.comments.get("filename1").get(0).message).isEqualTo("test1"); + List file1comments = reviewInput.robotComments.get("filename1"); + assertThat(file1comments).hasSize(2); + RobotCommentInput comment1 = file1comments.get(0); + assertThat(comment1.message).isEqualTo("test1"); + assertThat(comment1.robotId).isEqualTo("sputnik"); + assertThat(comment1.robotRunId).isNotEmpty(); assertThat(reviewInput.labels.get("Code-Review")).isEqualTo((short) 1); }