diff options
author | Klaudio Sinani <klaudio.sinani@sonarsource.com> | 2022-10-26 15:16:57 +0200 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2022-10-28 20:03:23 +0000 |
commit | ce409098feab4f5f5ca8168cd995775e1fa32cbb (patch) | |
tree | a04c7bf89c2b7792dbed6895b6f3db0fd3171cb1 /sonar-duplications | |
parent | 84dfd8b586f0c458d324e815f8b09ce3b395c044 (diff) | |
download | sonarqube-ce409098feab4f5f5ca8168cd995775e1fa32cbb.tar.gz sonarqube-ce409098feab4f5f5ca8168cd995775e1fa32cbb.zip |
[NO-JIRA] Fix reported code smells & bugs
Diffstat (limited to 'sonar-duplications')
10 files changed, 166 insertions, 30 deletions
diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/detector/suffixtree/TextSet.java b/sonar-duplications/src/main/java/org/sonar/duplications/detector/suffixtree/TextSet.java index 01c1bd268ec..16764bae35b 100644 --- a/sonar-duplications/src/main/java/org/sonar/duplications/detector/suffixtree/TextSet.java +++ b/sonar-duplications/src/main/java/org/sonar/duplications/detector/suffixtree/TextSet.java @@ -89,7 +89,7 @@ public final class TextSet extends AbstractText { @Override public boolean equals(Object obj) { - return (obj instanceof Terminator) && (((Terminator) obj).stringNumber == stringNumber); + return obj != null && getClass() == obj.getClass() && ((Terminator) obj).stringNumber == stringNumber; } @Override diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/index/CloneGroup.java b/sonar-duplications/src/main/java/org/sonar/duplications/index/CloneGroup.java index bfc6897e0fd..402682247b2 100644 --- a/sonar-duplications/src/main/java/org/sonar/duplications/index/CloneGroup.java +++ b/sonar-duplications/src/main/java/org/sonar/duplications/index/CloneGroup.java @@ -131,7 +131,7 @@ public class CloneGroup { */ @Override public boolean equals(Object object) { - if (!(object instanceof CloneGroup)) { + if (object == null || getClass() != object.getClass()) { return false; } CloneGroup another = (CloneGroup) object; diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/index/ClonePart.java b/sonar-duplications/src/main/java/org/sonar/duplications/index/ClonePart.java index daae5d9ace9..204b07effc0 100644 --- a/sonar-duplications/src/main/java/org/sonar/duplications/index/ClonePart.java +++ b/sonar-duplications/src/main/java/org/sonar/duplications/index/ClonePart.java @@ -60,7 +60,7 @@ public class ClonePart { @Override public boolean equals(Object obj) { - if (obj instanceof ClonePart) { + if (obj != null && getClass() == obj.getClass()) { ClonePart another = (ClonePart) obj; return another.resourceId.equals(resourceId) && another.startLine == startLine diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/statement/Statement.java b/sonar-duplications/src/main/java/org/sonar/duplications/statement/Statement.java index bb0b6c37b40..d92aebf2de9 100644 --- a/sonar-duplications/src/main/java/org/sonar/duplications/statement/Statement.java +++ b/sonar-duplications/src/main/java/org/sonar/duplications/statement/Statement.java @@ -79,7 +79,7 @@ public class Statement { @Override public boolean equals(Object obj) { - if (!(obj instanceof Statement)) { + if (obj == null || getClass() != obj.getClass()) { return false; } Statement other = (Statement) obj; diff --git a/sonar-duplications/src/main/java/org/sonar/duplications/token/Token.java b/sonar-duplications/src/main/java/org/sonar/duplications/token/Token.java index 6f2f3d00e05..58a080588d6 100644 --- a/sonar-duplications/src/main/java/org/sonar/duplications/token/Token.java +++ b/sonar-duplications/src/main/java/org/sonar/duplications/token/Token.java @@ -50,7 +50,7 @@ public class Token { @Override public boolean equals(Object object) { - if (object instanceof Token) { + if (object != null && getClass() == object.getClass()) { Token anotherToken = (Token) object; return anotherToken.line == line && anotherToken.column == column && anotherToken.value.equals(value); } diff --git a/sonar-duplications/src/test/java/org/sonar/duplications/detector/suffixtree/TextSetTest.java b/sonar-duplications/src/test/java/org/sonar/duplications/detector/suffixtree/TextSetTest.java new file mode 100644 index 00000000000..1c19aac6de2 --- /dev/null +++ b/sonar-duplications/src/test/java/org/sonar/duplications/detector/suffixtree/TextSetTest.java @@ -0,0 +1,38 @@ +/* + * SonarQube + * Copyright (C) 2009-2022 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.duplications.detector.suffixtree; + +import org.junit.Test; + +import static org.assertj.core.api.Assertions.assertThat; + +public class TextSetTest { + + @Test + public void test_terminator_equals() { + TextSet.Terminator terminator = new TextSet.Terminator(1); + + assertThat(terminator) + .isEqualTo(terminator) + .isNotEqualTo(null) + .isNotEqualTo(new TextSet.Terminator(0)) + .isEqualTo(new TextSet.Terminator(1)); + } +} diff --git a/sonar-duplications/src/test/java/org/sonar/duplications/index/CloneGroupTest.java b/sonar-duplications/src/test/java/org/sonar/duplications/index/CloneGroupTest.java new file mode 100644 index 00000000000..54deaf3e479 --- /dev/null +++ b/sonar-duplications/src/test/java/org/sonar/duplications/index/CloneGroupTest.java @@ -0,0 +1,52 @@ +/* + * SonarQube + * Copyright (C) 2009-2022 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.duplications.index; + +import java.util.List; +import org.junit.Test; + +import static org.assertj.core.api.Assertions.assertThat; + +public class CloneGroupTest { + + @Test + public void test_equals() { + ClonePart clone = new ClonePart("id", 1, 1, 2); + CloneGroup group = composeGroup(1, 1, clone, List.of(clone)); + + assertThat(group) + .isEqualTo(group) + .isNotEqualTo(null) + .isNotEqualTo(new Object()) + .isNotEqualTo(composeGroup(1, 1, clone, List.of())) + .isNotEqualTo(composeGroup(1, 1, new ClonePart("", 1, 1, 2), List.of(clone))) + .isNotEqualTo(composeGroup(0, 1, clone, List.of(clone))) + .isEqualTo(composeGroup(1, 1, clone, List.of(new ClonePart("id", 1, 1, 2)))); + } + + private static CloneGroup composeGroup(int length, int lengthInUnits, ClonePart origin, List<ClonePart> parts) { + return CloneGroup.builder() + .setLength(length) + .setLengthInUnits(lengthInUnits) + .setOrigin(origin) + .setParts(parts) + .build(); + } +} diff --git a/sonar-duplications/src/test/java/org/sonar/duplications/index/ClonePartTest.java b/sonar-duplications/src/test/java/org/sonar/duplications/index/ClonePartTest.java new file mode 100644 index 00000000000..a004d014352 --- /dev/null +++ b/sonar-duplications/src/test/java/org/sonar/duplications/index/ClonePartTest.java @@ -0,0 +1,42 @@ +/* + * SonarQube + * Copyright (C) 2009-2022 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.duplications.index; + +import org.junit.Test; + +import static org.assertj.core.api.Assertions.assertThat; + +public class ClonePartTest { + + @Test + public void test_equals() { + ClonePart part = new ClonePart("id_1", 1, 2, 3); + + assertThat(part) + .isEqualTo(part) + .isNotEqualTo(null) + .isNotEqualTo(new Object()) + .isNotEqualTo(new ClonePart("id_1", 1, 2, 0)) + .isNotEqualTo(new ClonePart("id_1", 1, 0, 3)) + .isNotEqualTo(new ClonePart("id_1", 0, 2, 3)) + .isNotEqualTo(new ClonePart("id_2", 1, 2, 3)) + .isEqualTo(new ClonePart("id_1", 1, 2, 3)); + } +} diff --git a/sonar-duplications/src/test/java/org/sonar/duplications/statement/StatementTest.java b/sonar-duplications/src/test/java/org/sonar/duplications/statement/StatementTest.java index c25f565894e..20517537537 100644 --- a/sonar-duplications/src/test/java/org/sonar/duplications/statement/StatementTest.java +++ b/sonar-duplications/src/test/java/org/sonar/duplications/statement/StatementTest.java @@ -19,15 +19,15 @@ */ package org.sonar.duplications.statement; -import static org.hamcrest.CoreMatchers.is; -import static org.junit.Assert.assertThat; - import java.util.ArrayList; import java.util.Arrays; - import org.junit.Test; import org.sonar.duplications.token.Token; +import static org.assertj.core.api.Assertions.assertThat; +import static org.hamcrest.CoreMatchers.is; +import static org.junit.Assert.assertThat; + public class StatementTest { @Test(expected = IllegalArgumentException.class) @@ -48,4 +48,17 @@ public class StatementTest { assertThat(statement.getEndLine(), is(2)); } + @Test + public void test_equals() { + Statement statement = new Statement(1, 2, "value_1"); + + assertThat(statement) + .isEqualTo(statement) + .isNotEqualTo(null) + .isNotEqualTo(new Object()) + .isNotEqualTo(new Statement(1, 2, "value_2")) + .isNotEqualTo(new Statement(1, 0, "value_1")) + .isNotEqualTo(new Statement(0, 2, "value_1")) + .isEqualTo(new Statement(1, 2, "value_1")); + } } diff --git a/sonar-duplications/src/test/java/org/sonar/duplications/token/TokenTest.java b/sonar-duplications/src/test/java/org/sonar/duplications/token/TokenTest.java index 21e22d7c317..3419864be98 100644 --- a/sonar-duplications/src/test/java/org/sonar/duplications/token/TokenTest.java +++ b/sonar-duplications/src/test/java/org/sonar/duplications/token/TokenTest.java @@ -19,31 +19,22 @@ */ package org.sonar.duplications.token; +import org.assertj.core.api.Assertions; import org.junit.Test; -import static org.junit.Assert.assertThat; - -import static org.hamcrest.CoreMatchers.is; -import static org.hamcrest.CoreMatchers.not; - public class TokenTest { @Test - public void shouldBeEqual() { - Token firstToken = new Token("MyValue", 1, 3); - Token secondToken = new Token("MyValue", 1, 3); - - assertThat(firstToken, is(secondToken)); + public void test_equals() { + Token token = new Token("value_1", 1, 2); + + Assertions.assertThat(token) + .isEqualTo(token) + .isNotEqualTo(null) + .isNotEqualTo(new Object()) + .isNotEqualTo(new Token("value_1", 1, 0)) + .isNotEqualTo(new Token("value_1", 0, 2)) + .isNotEqualTo(new Token("value_2", 1, 2)) + .isEqualTo(new Token("value_1", 1, 2)); } - - @Test - public void shouldNotBeEqual() { - Token firstToken = new Token("MyValue", 1, 3); - Token secondToken = new Token("MySecondValue", 1, 3); - Token thirdToken = new Token("MyValue", 3, 3); - - assertThat(firstToken, not(is(secondToken))); - assertThat(firstToken, not(is(thirdToken))); - } - } |