123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- /*
- * SonarQube
- * Copyright (C) 2009-2020 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.server.issue.notification;
-
- import com.google.common.collect.ImmutableSet;
- import java.util.Collections;
- import java.util.Random;
- import java.util.Set;
- import java.util.stream.Collectors;
- import java.util.stream.IntStream;
- import org.junit.Test;
- import org.sonar.server.issue.notification.IssuesChangesNotificationBuilder.AnalysisChange;
- import org.sonar.server.issue.notification.IssuesChangesNotificationBuilder.ChangedIssue;
- import org.sonar.server.issue.notification.IssuesChangesNotificationBuilder.Project;
- import org.sonar.server.issue.notification.IssuesChangesNotificationBuilder.Rule;
- import org.sonar.server.issue.notification.IssuesChangesNotificationBuilder.User;
-
- import static org.assertj.core.api.Assertions.assertThat;
- import static org.sonar.server.issue.notification.FPOrWontFixNotification.FpOrWontFix.FP;
- import static org.sonar.server.issue.notification.FPOrWontFixNotification.FpOrWontFix.WONT_FIX;
- import static org.sonar.server.issue.notification.IssuesChangesNotificationBuilderTesting.newRandomNotAHotspotRule;
-
- public class FPOrWontFixNotificationTest {
- @Test
- public void equals_is_based_on_issues_change_and_resolution() {
- Rule rule = newRandomNotAHotspotRule("rule_name");
- Project project = new Project.Builder("prj_uuid").setKey("prj_key").setProjectName("prj_name").build();
- Set<ChangedIssue> changedIssues = IntStream.range(0, 2 + new Random().nextInt(5))
- .mapToObj(i -> new ChangedIssue.Builder("key_" + i)
- .setNewStatus("status")
- .setRule(rule)
- .setProject(project)
- .build())
- .collect(Collectors.toSet());
- AnalysisChange change = new AnalysisChange(12);
- User user = new User("uuid", "login", null);
- FPOrWontFixNotification underTest = new FPOrWontFixNotification(change, changedIssues, WONT_FIX);
-
- assertThat(underTest)
- .isEqualTo(new FPOrWontFixNotification(change, changedIssues, WONT_FIX))
- .isEqualTo(new FPOrWontFixNotification(change, ImmutableSet.copyOf(changedIssues), WONT_FIX))
- .isNotEqualTo(new Object())
- .isNotEqualTo(null)
- .isNotEqualTo(new FPOrWontFixNotification(change, Collections.emptySet(), WONT_FIX))
- .isNotEqualTo(new FPOrWontFixNotification(change, ImmutableSet.of(changedIssues.iterator().next()), WONT_FIX))
- .isNotEqualTo(new FPOrWontFixNotification(new AnalysisChange(14), changedIssues, WONT_FIX))
- .isNotEqualTo(new FPOrWontFixNotification(new IssuesChangesNotificationBuilder.UserChange(12, user), changedIssues, WONT_FIX))
- .isNotEqualTo(new FPOrWontFixNotification(change, changedIssues, FP));
- }
-
- @Test
- public void hashcode_is_based_on_issues_change_and_resolution() {
- Rule rule = newRandomNotAHotspotRule("rule_name");
- Project project = new Project.Builder("prj_uuid").setKey("prj_key").setProjectName("prj_name").build();
- Set<ChangedIssue> changedIssues = IntStream.range(0, 2 + new Random().nextInt(5))
- .mapToObj(i -> new ChangedIssue.Builder("key_" + i)
- .setNewStatus("status")
- .setRule(rule)
- .setProject(project)
- .build())
- .collect(Collectors.toSet());
- AnalysisChange change = new AnalysisChange(12);
- User user = new User("uuid", "login", null);
- FPOrWontFixNotification underTest = new FPOrWontFixNotification(change, changedIssues, WONT_FIX);
-
- assertThat(underTest.hashCode())
- .isEqualTo(new FPOrWontFixNotification(change, changedIssues, WONT_FIX).hashCode())
- .isEqualTo(new FPOrWontFixNotification(change, ImmutableSet.copyOf(changedIssues), WONT_FIX).hashCode())
- .isNotEqualTo(new Object().hashCode())
- .isNotEqualTo(new FPOrWontFixNotification(change, Collections.emptySet(), WONT_FIX).hashCode())
- .isNotEqualTo(new FPOrWontFixNotification(change, ImmutableSet.of(changedIssues.iterator().next()), WONT_FIX).hashCode())
- .isNotEqualTo(new FPOrWontFixNotification(new AnalysisChange(14), changedIssues, WONT_FIX).hashCode())
- .isNotEqualTo(new FPOrWontFixNotification(new IssuesChangesNotificationBuilder.UserChange(12, user), changedIssues, WONT_FIX).hashCode())
- .isNotEqualTo(new FPOrWontFixNotification(change, changedIssues, FP)).hashCode();
- }
- }
|