From 1f5842ee24c4b544acb2c8dea81754809e70dab9 Mon Sep 17 00:00:00 2001 From: Duarte Meneses Date: Tue, 29 Nov 2022 03:49:09 -0600 Subject: SONAR-17592 Manage formattings for truncation of messages --- .../issue/internal/DefaultIssueLocationTest.java | 48 +++++++++++++++++++++- 1 file changed, 46 insertions(+), 2 deletions(-) (limited to 'sonar-plugin-api-impl/src/test') diff --git a/sonar-plugin-api-impl/src/test/java/org/sonar/api/batch/sensor/issue/internal/DefaultIssueLocationTest.java b/sonar-plugin-api-impl/src/test/java/org/sonar/api/batch/sensor/issue/internal/DefaultIssueLocationTest.java index 128ed060392..1c26aaa4400 100644 --- a/sonar-plugin-api-impl/src/test/java/org/sonar/api/batch/sensor/issue/internal/DefaultIssueLocationTest.java +++ b/sonar-plugin-api-impl/src/test/java/org/sonar/api/batch/sensor/issue/internal/DefaultIssueLocationTest.java @@ -19,13 +19,17 @@ */ package org.sonar.api.batch.sensor.issue.internal; +import java.util.List; import org.apache.commons.lang.StringUtils; import org.junit.Test; import org.sonar.api.batch.fs.InputFile; import org.sonar.api.batch.fs.internal.TestInputFileBuilder; +import org.sonar.api.batch.sensor.issue.MessageFormatting; +import org.sonar.api.batch.sensor.issue.NewMessageFormatting; import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThatThrownBy; +import static org.assertj.core.api.AssertionsForClassTypes.tuple; public class DefaultIssueLocationTest { @@ -56,11 +60,51 @@ public class DefaultIssueLocationTest { public void prevent_too_long_messages() { assertThat(new DefaultIssueLocation() .on(inputFile) - .message(StringUtils.repeat("a", 4000)).message()).hasSize(4000); + .message(StringUtils.repeat("a", 1333)).message()).hasSize(1333); assertThat(new DefaultIssueLocation() .on(inputFile) - .message(StringUtils.repeat("a", 4001)).message()).hasSize(4000); + .message(StringUtils.repeat("a", 1334)).message()).hasSize(1333); + } + + @Test + public void should_ignore_messageFormatting_if_message_is_trimmed() { + DefaultMessageFormatting messageFormatting = new DefaultMessageFormatting() + .start(1500) + .end(1501) + .type(MessageFormatting.Type.CODE); + + DefaultIssueLocation location = new DefaultIssueLocation() + .message(StringUtils.repeat("a", 2000), List.of(messageFormatting)); + + assertThat(location.messageFormattings()).isEmpty(); + } + + @Test + public void should_truncate_messageFormatting_if_necessary() { + DefaultMessageFormatting messageFormatting = new DefaultMessageFormatting() + .start(1300) + .end(1501) + .type(MessageFormatting.Type.CODE); + + DefaultIssueLocation location = new DefaultIssueLocation() + .message(StringUtils.repeat("a", 2000), List.of(messageFormatting)); + + assertThat(location.messageFormattings()) + .extracting(MessageFormatting::start, MessageFormatting::end) + .containsOnly(tuple(1300, 1333)); + } + + @Test + public void should_validate_message_formatting() { + List messageFormattings = List.of(new DefaultMessageFormatting() + .start(1) + .end(3) + .type(MessageFormatting.Type.CODE)); + DefaultIssueLocation location = new DefaultIssueLocation(); + + assertThatThrownBy(() -> location.message("aa", messageFormattings)) + .isInstanceOf(IllegalArgumentException.class); } @Test -- cgit v1.2.3