summaryrefslogtreecommitdiffstats
path: root/sonar-db
diff options
context:
space:
mode:
authorSimon Brandhof <simon.brandhof@sonarsource.com>2015-07-23 11:15:33 +0200
committerSimon Brandhof <simon.brandhof@sonarsource.com>2015-07-24 10:15:22 +0200
commit890c19cffe1fd59f9f2f716ce8b8333454a31737 (patch)
treeff64a4a799416854ba2f5f9eaf614960a93c1b30 /sonar-db
parent3d5c0f21706bd44755de23ead87e833f2a12db6f (diff)
downloadsonarqube-890c19cffe1fd59f9f2f716ce8b8333454a31737.tar.gz
sonarqube-890c19cffe1fd59f9f2f716ce8b8333454a31737.zip
Add IssueDao#selectByOrderedKeys(...)
Diffstat (limited to 'sonar-db')
-rw-r--r--sonar-db/src/main/java/org/sonar/db/issue/IssueDao.java41
-rw-r--r--sonar-db/src/main/java/org/sonar/db/issue/IssueDto.java7
-rw-r--r--sonar-db/src/test/java/org/sonar/db/issue/IssueDaoTest.java28
-rw-r--r--sonar-db/src/test/resources/org/sonar/db/issue/IssueDaoTest/get_by_key.xml29
4 files changed, 91 insertions, 14 deletions
diff --git a/sonar-db/src/main/java/org/sonar/db/issue/IssueDao.java b/sonar-db/src/main/java/org/sonar/db/issue/IssueDao.java
index cecd0fe0f08..fb65086103a 100644
--- a/sonar-db/src/main/java/org/sonar/db/issue/IssueDao.java
+++ b/sonar-db/src/main/java/org/sonar/db/issue/IssueDao.java
@@ -20,9 +20,17 @@
package org.sonar.db.issue;
+import com.google.common.base.Function;
+import com.google.common.base.Predicates;
+import com.google.common.collect.FluentIterable;
+import java.util.Collection;
+import java.util.HashMap;
import java.util.List;
+import java.util.Map;
import java.util.Set;
import javax.annotation.CheckForNull;
+import javax.annotation.Nonnull;
+import javax.annotation.Nullable;
import org.apache.ibatis.session.ResultHandler;
import org.apache.ibatis.session.SqlSession;
import org.sonar.db.Dao;
@@ -64,10 +72,43 @@ public class IssueDao implements Dao {
return mapper(session).selectByActionPlan(actionPlan);
}
+ /**
+ * Gets a list issues by their keys. The result does NOT contain {@code null} values for issues not found, so
+ * the size of result may be less than the number of keys. A single issue is returned
+ * if input keys contain multiple occurrences of a key.
+ * <p>Results may be in a different order as input keys (see {@link #selectByOrderedKeys(DbSession, List)}).</p>
+ */
public List<IssueDto> selectByKeys(DbSession session, List<String> keys) {
return mapper(session).selectByKeys(keys);
}
+ /**
+ * Gets a list issues by their keys. The result does NOT contain {@code null} values for issues not found, so
+ * the size of result may be less than the number of keys. A single issue is returned
+ * if input keys contain multiple occurrences of a key.
+ * <p>Contrary to {@link #selectByKeys(DbSession, List)}, results are in the same order as input keys.</p>
+ */
+ public Iterable<IssueDto> selectByOrderedKeys(DbSession session, List<String> keys) {
+ List<IssueDto> unordered = selectByKeys(session, keys);
+ return FluentIterable.from(keys).transform(new KeyToIssue(unordered)).filter(Predicates.notNull());
+ }
+
+ private static class KeyToIssue implements Function<String, IssueDto> {
+ private final Map<String, IssueDto> map = new HashMap<>();
+
+ private KeyToIssue(Collection<IssueDto> unordered) {
+ for (IssueDto dto : unordered) {
+ map.put(dto.getKey(), dto);
+ }
+ }
+
+ @Nullable
+ @Override
+ public IssueDto apply(@Nonnull String issueKey) {
+ return map.get(issueKey);
+ }
+ }
+
public Set<String> selectComponentUuidsOfOpenIssuesForProjectUuid(DbSession session, String projectUuid) {
return mapper(session).selectComponentUuidsOfOpenIssuesForProjectUuid(projectUuid);
}
diff --git a/sonar-db/src/main/java/org/sonar/db/issue/IssueDto.java b/sonar-db/src/main/java/org/sonar/db/issue/IssueDto.java
index f5eff6e3095..ede94b1f5e2 100644
--- a/sonar-db/src/main/java/org/sonar/db/issue/IssueDto.java
+++ b/sonar-db/src/main/java/org/sonar/db/issue/IssueDto.java
@@ -44,9 +44,6 @@ import org.sonar.db.rule.RuleDto;
import static org.sonar.api.utils.DateUtils.dateToLong;
import static org.sonar.api.utils.DateUtils.longToDate;
-/**
- * @since 3.6
- */
public final class IssueDto implements Serializable {
private static final char TAGS_SEPARATOR = ',';
@@ -131,7 +128,7 @@ public final class IssueDto implements Serializable {
.setIssueUpdateDate(issue.updateDate())
.setSelectedAt(issue.selectedAt())
- // technical dates
+ // technical dates
.setCreatedAt(now)
.setUpdatedAt(now);
}
@@ -176,7 +173,7 @@ public final class IssueDto implements Serializable {
.setIssueUpdateDate(issue.updateDate())
.setSelectedAt(issue.selectedAt())
- // technical date
+ // technical date
.setUpdatedAt(now);
}
diff --git a/sonar-db/src/test/java/org/sonar/db/issue/IssueDaoTest.java b/sonar-db/src/test/java/org/sonar/db/issue/IssueDaoTest.java
index fd5f5040009..2e11ebc9b7d 100644
--- a/sonar-db/src/test/java/org/sonar/db/issue/IssueDaoTest.java
+++ b/sonar-db/src/test/java/org/sonar/db/issue/IssueDaoTest.java
@@ -21,6 +21,7 @@
package org.sonar.db.issue;
import java.util.Arrays;
+import java.util.Collection;
import java.util.List;
import org.apache.ibatis.executor.result.DefaultResultHandler;
import org.junit.Rule;
@@ -33,6 +34,7 @@ import org.sonar.db.component.ComponentDto;
import org.sonar.db.rule.RuleTesting;
import org.sonar.test.DbTests;
+import static java.util.Arrays.asList;
import static org.assertj.core.api.Assertions.assertThat;
@Category(DbTests.class)
@@ -90,12 +92,12 @@ public class IssueDaoTest {
}
@Test
- public void get_by_key() {
+ public void selectByKey() {
dbTester.prepareDbUnit(getClass(), "shared.xml", "get_by_key.xml");
- IssueDto issue = dao.selectByKey(dbTester.getSession(), "ABCDE");
- assertThat(issue.getKee()).isEqualTo("ABCDE");
- assertThat(issue.getId()).isEqualTo(100L);
+ IssueDto issue = dao.selectByKey(dbTester.getSession(), "I1");
+ assertThat(issue.getKee()).isEqualTo("I1");
+ assertThat(issue.getId()).isEqualTo(1L);
assertThat(issue.getComponentUuid()).isEqualTo("CDEF");
assertThat(issue.getProjectUuid()).isEqualTo("ABCD");
assertThat(issue.getRuleId()).isEqualTo(500);
@@ -124,11 +126,23 @@ public class IssueDaoTest {
}
@Test
- public void get_by_keys() {
+ public void selectByKeys() {
dbTester.prepareDbUnit(getClass(), "shared.xml", "get_by_key.xml");
- List<IssueDto> issues = dao.selectByKeys(dbTester.getSession(), Arrays.asList("ABCDE"));
- assertThat(issues).hasSize(1);
+ List<IssueDto> issues = dao.selectByKeys(dbTester.getSession(), asList("I1", "I2", "I3"));
+ // results are not ordered, so do not use "containsExactly"
+ assertThat(issues).extracting("key").containsOnly("I1", "I2");
+ }
+
+ @Test
+ public void selectByOrderedKeys() {
+ dbTester.prepareDbUnit(getClass(), "shared.xml", "get_by_key.xml");
+
+ Iterable<IssueDto> issues = dao.selectByOrderedKeys(dbTester.getSession(), asList("I1", "I2", "I3"));
+ assertThat(issues).extracting("key").containsExactly("I1", "I2");
+
+ issues = dao.selectByOrderedKeys(dbTester.getSession(), asList("I2", "I3", "I1"));
+ assertThat(issues).extracting("key").containsExactly("I2", "I1");
}
@Test
diff --git a/sonar-db/src/test/resources/org/sonar/db/issue/IssueDaoTest/get_by_key.xml b/sonar-db/src/test/resources/org/sonar/db/issue/IssueDaoTest/get_by_key.xml
index 154a7a67883..3d5a5c70e2e 100644
--- a/sonar-db/src/test/resources/org/sonar/db/issue/IssueDaoTest/get_by_key.xml
+++ b/sonar-db/src/test/resources/org/sonar/db/issue/IssueDaoTest/get_by_key.xml
@@ -1,8 +1,33 @@
<dataset>
<issues
- id="100"
- kee="ABCDE"
+ id="1"
+ kee="I1"
+ component_uuid="CDEF"
+ project_uuid="ABCD"
+ rule_id="500"
+ severity="BLOCKER"
+ manual_severity="[false]"
+ message="[null]"
+ line="200"
+ effort_to_fix="4.2"
+ status="OPEN"
+ resolution="FIXED"
+ checksum="XXX"
+ reporter="arthur"
+ assignee="perceval"
+ author_login="karadoc"
+ issue_attributes="JIRA=FOO-1234"
+ issue_creation_date="1366063200000"
+ issue_update_date="1366063200000"
+ issue_close_date="1366063200000"
+ created_at="1400000000000"
+ updated_at="1450000000000"
+ />
+
+ <issues
+ id="2"
+ kee="I2"
component_uuid="CDEF"
project_uuid="ABCD"
rule_id="500"