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/resource/ResourceDao.java30
-rw-r--r--sonar-core/src/test/java/org/sonar/core/measure/db/PastMeasureDtoTest.java20
2 files changed, 36 insertions, 14 deletions
diff --git a/sonar-core/src/main/java/org/sonar/core/resource/ResourceDao.java b/sonar-core/src/main/java/org/sonar/core/resource/ResourceDao.java
index ad12d18d368..49ee6b18d38 100644
--- a/sonar-core/src/main/java/org/sonar/core/resource/ResourceDao.java
+++ b/sonar-core/src/main/java/org/sonar/core/resource/ResourceDao.java
@@ -21,6 +21,12 @@ package org.sonar.core.resource;
import com.google.common.base.Function;
import com.google.common.collect.Iterables;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Date;
+import java.util.List;
+import javax.annotation.CheckForNull;
+import javax.annotation.Nonnull;
import org.apache.ibatis.session.SqlSession;
import org.sonar.api.component.Component;
import org.sonar.api.resources.Scopes;
@@ -32,14 +38,6 @@ import org.sonar.core.persistence.DaoComponent;
import org.sonar.core.persistence.DbSession;
import org.sonar.core.persistence.MyBatis;
-import javax.annotation.CheckForNull;
-import javax.annotation.Nullable;
-
-import java.util.Collection;
-import java.util.Collections;
-import java.util.Date;
-import java.util.List;
-
import static com.google.common.collect.Lists.newArrayList;
public class ResourceDao implements DaoComponent {
@@ -358,16 +356,20 @@ public class ResourceDao implements DaoComponent {
}
public static List<Component> toComponents(List<ResourceDto> resourceDto) {
- return newArrayList(Iterables.transform(resourceDto, new Function<ResourceDto, Component>() {
- @Override
- public Component apply(@Nullable ResourceDto resourceDto) {
- return resourceDto == null ? null : toComponent(resourceDto);
- }
- }));
+ return newArrayList(Iterables.transform(resourceDto, ToComponent.INSTANCE));
}
public void insertUsingExistingSession(ResourceDto resourceDto, SqlSession session) {
ResourceMapper resourceMapper = session.getMapper(ResourceMapper.class);
resourceMapper.insert(resourceDto);
}
+
+ private enum ToComponent implements Function<ResourceDto, Component> {
+ INSTANCE;
+
+ @Override
+ public Component apply(@Nonnull ResourceDto resourceDto) {
+ return toComponent(resourceDto);
+ }
+ }
}
diff --git a/sonar-core/src/test/java/org/sonar/core/measure/db/PastMeasureDtoTest.java b/sonar-core/src/test/java/org/sonar/core/measure/db/PastMeasureDtoTest.java
index 2baf547ff16..9808471c1b0 100644
--- a/sonar-core/src/test/java/org/sonar/core/measure/db/PastMeasureDtoTest.java
+++ b/sonar-core/src/test/java/org/sonar/core/measure/db/PastMeasureDtoTest.java
@@ -45,6 +45,26 @@ public class PastMeasureDtoTest {
assertThat(dto.getPersonId()).isEqualTo(5);
}
+ @Test
+ public void test_has_value() throws Exception {
+ PastMeasureDto measureWithValue = new PastMeasureDto()
+ .setId(10L)
+ .setValue(1d)
+ .setMetricId(2)
+ .setRuleId(3)
+ .setCharacteristicId(4)
+ .setPersonId(5);
+ assertThat(measureWithValue.hasValue()).isTrue();
+
+ PastMeasureDto measureWithoutValue = new PastMeasureDto()
+ .setId(10L)
+ .setMetricId(2)
+ .setRuleId(3)
+ .setCharacteristicId(4)
+ .setPersonId(5);
+ assertThat(measureWithoutValue.hasValue()).isFalse();
+ }
+
@Test(expected = NullPointerException.class)
public void get_value_throw_a_NPE_if_value_is_null() throws Exception {
new PastMeasureDto().getValue();