aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-core
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-core')
-rw-r--r--sonar-core/src/main/java/org/sonar/core/issue/AnticipatedTransition.java150
-rw-r--r--sonar-core/src/test/java/org/sonar/core/issue/AnticipatedTransitionTest.java74
2 files changed, 224 insertions, 0 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/issue/AnticipatedTransition.java b/sonar-core/src/main/java/org/sonar/core/issue/AnticipatedTransition.java
new file mode 100644
index 00000000000..5d0fe394964
--- /dev/null
+++ b/sonar-core/src/main/java/org/sonar/core/issue/AnticipatedTransition.java
@@ -0,0 +1,150 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2023 SonarSource SA
+ * mailto:info AT sonarsource DOT com
+ *
+ * This program 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.
+ *
+ * This program 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+package org.sonar.core.issue;
+
+import java.time.Instant;
+import java.util.Date;
+import java.util.Objects;
+import org.apache.commons.lang.builder.HashCodeBuilder;
+import org.jetbrains.annotations.Nullable;
+import org.sonar.api.issue.Issue;
+import org.sonar.api.rule.RuleKey;
+import org.sonar.core.issue.tracking.Trackable;
+
+public class AnticipatedTransition implements Trackable {
+
+ private final String projectKey;
+ private final String branch;
+ private final String transition;
+ private final String userUuid;
+ private final String comment;
+ private final String filePath;
+ private final Integer line;
+ private final String message;
+ private final String lineHash;
+ private final RuleKey ruleKey;
+
+ public AnticipatedTransition(
+ String projectKey,
+ @Nullable String branch,
+ String userUuid,
+ @Nullable RuleKey ruleKey,
+ @Nullable String message,
+ @Nullable String filePath,
+ @Nullable Integer line,
+ @Nullable String lineHash,
+ String transition,
+ @Nullable String comment) {
+ this.projectKey = projectKey;
+ this.branch = branch;
+ this.transition = transition;
+ this.userUuid = userUuid;
+ this.comment = comment;
+ this.filePath = filePath;
+ this.line = line;
+ this.message = message;
+ this.lineHash = lineHash;
+ this.ruleKey = ruleKey;
+ }
+
+ public String getProjectKey() {
+ return projectKey;
+ }
+
+ public String getBranch() {
+ return branch;
+ }
+
+ public String getTransition() {
+ return transition;
+ }
+
+ public String getUserUuid() {
+ return userUuid;
+ }
+
+ public String getComment() {
+ return comment;
+ }
+
+ public String getFilePath() {
+ return filePath;
+ }
+
+ @Nullable
+ @Override
+ public Integer getLine() {
+ return line;
+ }
+
+ @Nullable
+ @Override
+ public String getMessage() {
+ return message;
+ }
+
+ @Nullable
+ @Override
+ public String getLineHash() {
+ return lineHash;
+ }
+
+ @Override
+ public RuleKey getRuleKey() {
+ return ruleKey;
+ }
+
+ @Override
+ public String getStatus() {
+ // Since it's an anticipated transition, the issue will always be open upon the first analysis.
+ return Issue.STATUS_OPEN;
+ }
+
+ @Override
+ public Date getUpdateDate() {
+ return Date.from(Instant.now());
+ }
+
+ @Override
+ public boolean equals(Object o) {
+ if (this == o) {
+ return true;
+ }
+ if (o == null || getClass() != o.getClass()) {
+ return false;
+ }
+ AnticipatedTransition that = (AnticipatedTransition) o;
+ return Objects.equals(projectKey, that.projectKey)
+ && Objects.equals(branch, that.branch)
+ && Objects.equals(transition, that.transition)
+ && Objects.equals(userUuid, that.userUuid)
+ && Objects.equals(comment, that.comment)
+ && Objects.equals(filePath, that.filePath)
+ && Objects.equals(line, that.line)
+ && Objects.equals(message, that.message)
+ && Objects.equals(lineHash, that.lineHash)
+ && Objects.equals(ruleKey, that.ruleKey);
+ }
+
+ @Override
+ public int hashCode() {
+ return HashCodeBuilder.reflectionHashCode(this);
+ }
+}
diff --git a/sonar-core/src/test/java/org/sonar/core/issue/AnticipatedTransitionTest.java b/sonar-core/src/test/java/org/sonar/core/issue/AnticipatedTransitionTest.java
new file mode 100644
index 00000000000..041753af341
--- /dev/null
+++ b/sonar-core/src/test/java/org/sonar/core/issue/AnticipatedTransitionTest.java
@@ -0,0 +1,74 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2023 SonarSource SA
+ * mailto:info AT sonarsource DOT com
+ *
+ * This program 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.
+ *
+ * This program 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+package org.sonar.core.issue;
+
+import org.assertj.core.api.Assertions;
+import org.junit.Test;
+import org.sonar.api.rule.RuleKey;
+
+public class AnticipatedTransitionTest {
+
+ @Test
+ public void givenTwoAnticipatedTransitions_whenFieldsHaveTheSameValue_theyShouldBeEqual() {
+ AnticipatedTransition anticipatedTransition = getAnticipatedTransition();
+ AnticipatedTransition anticipatedTransition2 = getAnticipatedTransition();
+
+ assertFieldsAreTheSame(anticipatedTransition, anticipatedTransition2);
+ Assertions.assertThat(anticipatedTransition).isEqualTo(anticipatedTransition2);
+ }
+
+ @Test
+ public void givenTwoAnticipatedTransitions_whenFieldsHaveTheSameValue_hashcodeShouldBeTheSame() {
+ AnticipatedTransition anticipatedTransition = getAnticipatedTransition();
+ AnticipatedTransition anticipatedTransition2 = getAnticipatedTransition();
+
+ assertFieldsAreTheSame(anticipatedTransition, anticipatedTransition2);
+ Assertions.assertThat(anticipatedTransition).hasSameHashCodeAs(anticipatedTransition2);
+ }
+
+ private void assertFieldsAreTheSame(AnticipatedTransition anticipatedTransition, AnticipatedTransition anticipatedTransition2) {
+ Assertions.assertThat(anticipatedTransition.getProjectKey()).isEqualTo(anticipatedTransition2.getProjectKey());
+ Assertions.assertThat(anticipatedTransition.getBranch()).isEqualTo(anticipatedTransition2.getBranch());
+ Assertions.assertThat(anticipatedTransition.getUserUuid()).isEqualTo(anticipatedTransition2.getUserUuid());
+ Assertions.assertThat(anticipatedTransition.getTransition()).isEqualTo(anticipatedTransition2.getTransition());
+ Assertions.assertThat(anticipatedTransition.getComment()).isEqualTo(anticipatedTransition2.getComment());
+ Assertions.assertThat(anticipatedTransition.getFilePath()).isEqualTo(anticipatedTransition2.getFilePath());
+ Assertions.assertThat(anticipatedTransition.getLine()).isEqualTo(anticipatedTransition2.getLine());
+ Assertions.assertThat(anticipatedTransition.getMessage()).isEqualTo(anticipatedTransition2.getMessage());
+ Assertions.assertThat(anticipatedTransition.getLineHash()).isEqualTo(anticipatedTransition2.getLineHash());
+ Assertions.assertThat(anticipatedTransition.getRuleKey()).isEqualTo(anticipatedTransition2.getRuleKey());
+ }
+
+ private AnticipatedTransition getAnticipatedTransition() {
+ return new AnticipatedTransition(
+ "projectKey",
+ "branch",
+ "userUuid",
+ RuleKey.parse("rule:key"),
+ "message",
+ "filepath",
+ 1,
+ "lineHash",
+ "transition",
+ "comment"
+ );
+ }
+
+}