aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTeryk Bellahsene <teryk.bellahsene@sonarsource.com>2016-02-01 17:59:39 +0100
committerTeryk Bellahsene <teryk.bellahsene@sonarsource.com>2016-02-01 18:07:49 +0100
commit40b377727fb47c4640d597f4bd3ff192ab143833 (patch)
tree49489a6cfd4b347ff0ae77ba47a88c3125ba0ad3
parent67ebdfe31073e8bb8b019990d9c0f463a85da204 (diff)
downloadsonarqube-40b377727fb47c4640d597f4bd3ff192ab143833.tar.gz
sonarqube-40b377727fb47c4640d597f4bd3ff192ab143833.zip
Fix quality flaws
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java2
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/SearchAction.java2
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentAction.java4
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeDataLoader.java31
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeSort.java2
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/measure/ws/SnapshotDtoToWsPeriods.java2
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/metric/ws/DomainsAction.java5
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/permission/PermissionUpdater.java2
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/component/ws/ShowDataTest.java81
-rw-r--r--sonar-db/src/test/java/org/sonar/db/metric/MetricDtoFunctionsTest.java81
10 files changed, 173 insertions, 39 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java
index c604904529a..b21f8052d95 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/component/ws/SearchAction.java
@@ -133,7 +133,7 @@ public class SearchAction implements ComponentsWsAction {
paging.pageSize());
}
- private SearchWsResponse buildResponse(List<ComponentDto> components, Paging paging) {
+ private static SearchWsResponse buildResponse(List<ComponentDto> components, Paging paging) {
WsComponents.SearchWsResponse.Builder responseBuilder = SearchWsResponse.newBuilder();
responseBuilder.getPagingBuilder()
.setPageIndex(paging.pageIndex())
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/SearchAction.java
index 3820a4ddc05..dc5c61e1787 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/SearchAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/measure/custom/ws/SearchAction.java
@@ -33,6 +33,7 @@ import org.sonar.api.server.ws.Response;
import org.sonar.api.server.ws.WebService;
import org.sonar.api.user.User;
import org.sonar.api.utils.text.JsonWriter;
+import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.MyBatis;
import org.sonar.db.component.ComponentDto;
@@ -40,7 +41,6 @@ import org.sonar.db.component.SnapshotDto;
import org.sonar.db.measure.custom.CustomMeasureDto;
import org.sonar.db.metric.MetricDto;
import org.sonar.server.component.ComponentFinder;
-import org.sonar.server.db.DbClient;
import org.sonar.server.es.SearchOptions;
import org.sonar.server.user.UserSession;
import org.sonar.server.user.index.UserIndex;
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentAction.java b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentAction.java
index b7af8e1b042..2c8b748e8ae 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentAction.java
@@ -64,7 +64,7 @@ import static org.sonar.server.measure.ws.ComponentDtoToWsComponent.componentDto
import static org.sonar.server.measure.ws.MeasuresWsParametersBuilder.createAdditionalFieldsParameter;
import static org.sonar.server.measure.ws.MeasuresWsParametersBuilder.createMetricKeysParameter;
import static org.sonar.server.measure.ws.MetricDtoToWsMetric.metricDtoToWsMetric;
-import static org.sonar.server.measure.ws.SnapshotDtoToWsPeriods.snapshotsToPeriods;
+import static org.sonar.server.measure.ws.SnapshotDtoToWsPeriods.snapshotToWsPeriods;
import static org.sonar.server.user.AbstractUserSession.insufficientPrivilegesException;
import static org.sonar.server.ws.KeyExamples.KEY_PROJECT_EXAMPLE_001;
import static org.sonar.server.ws.WsUtils.checkRequest;
@@ -131,7 +131,7 @@ public class ComponentAction implements MeasuresWsAction {
checkPermissions(component);
SnapshotDto lastSnapshot = dbClient.snapshotDao().selectLastSnapshotByComponentId(dbSession, component.getId());
List<MetricDto> metrics = searchMetrics(dbSession, request);
- List<WsMeasures.Period> periods = snapshotsToPeriods(lastSnapshot);
+ List<WsMeasures.Period> periods = snapshotToWsPeriods(lastSnapshot);
List<MeasureDto> measures = searchMeasures(dbSession, component, lastSnapshot, metrics, periods);
return buildResponse(request, component, refComponent, measures, metrics, periods);
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeDataLoader.java b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeDataLoader.java
index 3bb6254614a..42f695add9b 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeDataLoader.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeDataLoader.java
@@ -65,13 +65,13 @@ import static com.google.common.collect.Sets.newHashSet;
import static java.lang.String.format;
import static java.util.Collections.emptyMap;
import static java.util.Collections.singletonList;
-import static org.sonar.api.utils.DateUtils.formatDateTime;
import static org.sonar.server.component.ComponentFinder.ParamNames.BASE_COMPONENT_ID_AND_KEY;
import static org.sonar.server.measure.ws.ComponentTreeAction.ALL_STRATEGY;
import static org.sonar.server.measure.ws.ComponentTreeAction.CHILDREN_STRATEGY;
import static org.sonar.server.measure.ws.ComponentTreeAction.LEAVES_STRATEGY;
import static org.sonar.server.measure.ws.ComponentTreeAction.METRIC_SORT;
import static org.sonar.server.measure.ws.ComponentTreeAction.NAME_SORT;
+import static org.sonar.server.measure.ws.SnapshotDtoToWsPeriods.snapshotToWsPeriods;
import static org.sonar.server.user.AbstractUserSession.insufficientPrivilegesException;
public class ComponentTreeDataLoader {
@@ -106,7 +106,7 @@ public class ComponentTreeDataLoader {
List<ComponentDtoWithSnapshotId> components = componentDtosAndTotal.componentDtos;
int componentCount = componentDtosAndTotal.total;
List<MetricDto> metrics = searchMetrics(dbSession, wsRequest);
- List<WsMeasures.Period> periods = periodsFromSnapshot(baseSnapshot);
+ List<WsMeasures.Period> periods = snapshotToWsPeriods(baseSnapshot);
Table<String, MetricDto, MeasureDto> measuresByComponentUuidAndMetric = searchMeasuresByComponentUuidAndMetric(dbSession, baseComponent, baseSnapshot, components, metrics,
periods);
@@ -230,33 +230,6 @@ public class ComponentTreeDataLoader {
}
}
- private static List<WsMeasures.Period> periodsFromSnapshot(SnapshotDto baseSnapshot) {
- List<WsMeasures.Period> periods = new ArrayList<>();
- for (int periodIndex = 1; periodIndex <= 5; periodIndex++) {
- if (baseSnapshot.getPeriodDate(periodIndex) != null) {
- periods.add(snapshotDtoToWsPeriod(baseSnapshot, periodIndex));
- }
- }
-
- return periods;
- }
-
- private static WsMeasures.Period snapshotDtoToWsPeriod(SnapshotDto snapshot, int periodIndex) {
- WsMeasures.Period.Builder period = WsMeasures.Period.newBuilder();
- period.setIndex(periodIndex);
- if (snapshot.getPeriodMode(periodIndex) != null) {
- period.setMode(snapshot.getPeriodMode(periodIndex));
- }
- if (snapshot.getPeriodModeParameter(periodIndex) != null) {
- period.setParameter(snapshot.getPeriodModeParameter(periodIndex));
- }
- if (snapshot.getPeriodDate(periodIndex) != null) {
- period.setDate(formatDateTime(snapshot.getPeriodDate(periodIndex)));
- }
-
- return period.build();
- }
-
private static List<ComponentDtoWithSnapshotId> sortComponents(List<ComponentDtoWithSnapshotId> components, ComponentTreeWsRequest wsRequest, List<MetricDto> metrics,
Table<String, MetricDto, MeasureDto> measuresByComponentUuidAndMetric) {
if (!wsRequest.getSort().contains(METRIC_SORT)) {
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeSort.java b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeSort.java
index 50b7c1a0292..b99ec27a3b3 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeSort.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/ComponentTreeSort.java
@@ -101,7 +101,7 @@ class ComponentTreeSort {
*/
private static Ordering<ComponentDtoWithSnapshotId> metricOrdering(ComponentTreeWsRequest wsRequest, List<MetricDto> metrics,
Table<String, MetricDto, MeasureDto> measuresByComponentUuidAndMetric) {
- if (wsRequest.getMetricSort()==null) {
+ if (wsRequest.getMetricSort() == null) {
return componentNameOrdering(wsRequest.getAsc());
}
Map<String, MetricDto> metricsByKey = Maps.uniqueIndex(metrics, MetricDtoFunctions.toKey());
diff --git a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SnapshotDtoToWsPeriods.java b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SnapshotDtoToWsPeriods.java
index 8418f3a4f96..1f3864175c0 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SnapshotDtoToWsPeriods.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/measure/ws/SnapshotDtoToWsPeriods.java
@@ -33,7 +33,7 @@ class SnapshotDtoToWsPeriods {
// prevent instantiation
}
- static List<WsMeasures.Period> snapshotsToPeriods(@Nullable SnapshotDto snapshot) {
+ static List<WsMeasures.Period> snapshotToWsPeriods(@Nullable SnapshotDto snapshot) {
if (snapshot == null) {
return emptyList();
}
diff --git a/server/sonar-server/src/main/java/org/sonar/server/metric/ws/DomainsAction.java b/server/sonar-server/src/main/java/org/sonar/server/metric/ws/DomainsAction.java
index c90585e25a3..7ecd84e7b29 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/metric/ws/DomainsAction.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/metric/ws/DomainsAction.java
@@ -19,15 +19,14 @@
*/
package org.sonar.server.metric.ws;
+import java.util.List;
import org.sonar.api.server.ws.Request;
import org.sonar.api.server.ws.Response;
import org.sonar.api.server.ws.WebService;
import org.sonar.api.utils.text.JsonWriter;
+import org.sonar.db.DbClient;
import org.sonar.db.DbSession;
import org.sonar.db.MyBatis;
-import org.sonar.server.db.DbClient;
-
-import java.util.List;
public class DomainsAction implements MetricsWsAction {
diff --git a/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionUpdater.java b/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionUpdater.java
index 6583bcda716..a9cd97db6a3 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionUpdater.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/permission/PermissionUpdater.java
@@ -177,7 +177,7 @@ public class PermissionUpdater {
}
}
- private boolean shouldSkipPermissionChange(Operation operation, List<String> existingPermissions, PermissionChange permissionChange) {
+ private static boolean shouldSkipPermissionChange(Operation operation, List<String> existingPermissions, PermissionChange permissionChange) {
return (Operation.ADD == operation && existingPermissions.contains(permissionChange.permission())) ||
(Operation.REMOVE == operation && !existingPermissions.contains(permissionChange.permission()));
}
diff --git a/server/sonar-server/src/test/java/org/sonar/server/component/ws/ShowDataTest.java b/server/sonar-server/src/test/java/org/sonar/server/component/ws/ShowDataTest.java
new file mode 100644
index 00000000000..3de3853872e
--- /dev/null
+++ b/server/sonar-server/src/test/java/org/sonar/server/component/ws/ShowDataTest.java
@@ -0,0 +1,81 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2016 SonarSource SA
+ * mailto:contact 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.component.ws;
+
+import java.util.Collections;
+import org.junit.Rule;
+import org.junit.Test;
+import org.junit.rules.ExpectedException;
+import org.sonar.db.component.ComponentDto;
+import org.sonar.db.component.SnapshotDto;
+
+import static com.google.common.collect.Lists.newArrayList;
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.sonar.db.component.ComponentTesting.newProjectDto;
+import static org.sonar.db.component.SnapshotTesting.newSnapshotForProject;
+
+public class ShowDataTest {
+
+ @Rule
+ public ExpectedException expectedException = ExpectedException.none();
+
+ ComponentDto project = newProjectDto().setId(42L);
+
+ ShowData underTest;
+
+ @Test
+ public void no_ancestors() {
+ underTest = ShowData.builder(
+ newSnapshotForProject(project).setPath(null))
+ .withAncestorsSnapshots(Collections.<SnapshotDto>emptyList())
+ .andAncestorComponents(Collections.<ComponentDto>emptyList());
+
+ assertThat(underTest.getComponents()).isEmpty();
+ }
+
+ @Test
+ public void fail_when_inconsistent_snapshot_ancestors_data() {
+ expectedException.expect(IllegalStateException.class);
+ expectedException.expectMessage("Missing ancestor");
+
+ underTest = ShowData.builder(
+ newSnapshotForProject(project).setPath("1.2.3."))
+ .withAncestorsSnapshots(newArrayList(
+ newSnapshotForProject(project).setId(1L),
+ newSnapshotForProject(project).setId(2L)))
+ // missing snapshot with id = 3
+ .andAncestorComponents(Collections.<ComponentDto>emptyList());
+ }
+
+ @Test
+ public void fail_when_inconsistent_component_ancestors_data() {
+ expectedException.expect(IllegalStateException.class);
+ expectedException.expectMessage("Missing ancestor");
+
+ underTest = ShowData.builder(
+ newSnapshotForProject(project).setPath("1.2.3."))
+ .withAncestorsSnapshots(newArrayList(
+ newSnapshotForProject(project).setId(1L),
+ newSnapshotForProject(project).setId(2L),
+ newSnapshotForProject(project).setId(3L)))
+ .andAncestorComponents(Collections.<ComponentDto>emptyList());
+ }
+}
diff --git a/sonar-db/src/test/java/org/sonar/db/metric/MetricDtoFunctionsTest.java b/sonar-db/src/test/java/org/sonar/db/metric/MetricDtoFunctionsTest.java
new file mode 100644
index 00000000000..386b6b604c6
--- /dev/null
+++ b/sonar-db/src/test/java/org/sonar/db/metric/MetricDtoFunctionsTest.java
@@ -0,0 +1,81 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2016 SonarSource SA
+ * mailto:contact 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.db.metric;
+
+import org.junit.Test;
+
+import static org.assertj.core.api.Assertions.assertThat;
+
+public class MetricDtoFunctionsTest {
+
+ MetricDto metric;
+
+ @Test
+ public void toId() {
+ metric = new MetricDto().setId(42);
+
+ Integer result = MetricDtoFunctions.toId().apply(metric);
+
+ assertThat(result).isEqualTo(42);
+ }
+
+ @Test
+ public void toKey() {
+ metric = new MetricDto().setKey("my-metric-key");
+
+ String result = MetricDtoFunctions.toKey().apply(metric);
+
+ assertThat(result).isEqualTo("my-metric-key");
+ }
+
+ @Test
+ public void isOptimizedForBestValue_at_true() {
+ metric = new MetricDto()
+ .setBestValue(42.0d)
+ .setOptimizedBestValue(true);
+
+ boolean result = MetricDtoFunctions.isOptimizedForBestValue().apply(metric);
+
+ assertThat(result).isTrue();
+ }
+
+ @Test
+ public void isOptimizedForBestValue_is_false_when_no_best_value() {
+ metric = new MetricDto()
+ .setBestValue(null)
+ .setOptimizedBestValue(true);
+
+ boolean result = MetricDtoFunctions.isOptimizedForBestValue().apply(metric);
+
+ assertThat(result).isFalse();
+ }
+
+ @Test
+ public void isOptimizedForBestValue_is_false_when_is_not_optimized() {
+ metric = new MetricDto()
+ .setBestValue(42.0d)
+ .setOptimizedBestValue(false);
+
+ boolean result = MetricDtoFunctions.isOptimizedForBestValue().apply(metric);
+
+ assertThat(result).isFalse();
+ }
+}