summaryrefslogtreecommitdiffstats
path: root/server
diff options
context:
space:
mode:
authorSébastien Lesaint <sebastien.lesaint@sonarsource.com>2015-08-25 12:01:02 +0200
committerSébastien Lesaint <sebastien.lesaint@sonarsource.com>2015-08-29 15:58:41 +0200
commit34c21b609ba78b19107c066577035dd3a9d27ea4 (patch)
tree57491bfe5333b28e363ccd4f8b78336815ce70a6 /server
parent16adc162711440a74b954de18d3939b4cc0c34a5 (diff)
downloadsonarqube-34c21b609ba78b19107c066577035dd3a9d27ea4.tar.gz
sonarqube-34c21b609ba78b19107c066577035dd3a9d27ea4.zip
add support for Views Component tree to UnitTestMeasuresStep
Diffstat (limited to 'server')
-rw-r--r--server/sonar-server/src/main/java/org/sonar/server/computation/step/UnitTestMeasuresStep.java7
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/computation/step/ReportUnitTestMeasuresStepTest.java (renamed from server/sonar-server/src/test/java/org/sonar/server/computation/step/UnitTestMeasuresStepTest.java)41
-rw-r--r--server/sonar-server/src/test/java/org/sonar/server/computation/step/ViewsUnitTestMeasuresStepTest.java282
3 files changed, 304 insertions, 26 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/computation/step/UnitTestMeasuresStep.java b/server/sonar-server/src/main/java/org/sonar/server/computation/step/UnitTestMeasuresStep.java
index 34bfb28cc85..8846c8fcde6 100644
--- a/server/sonar-server/src/main/java/org/sonar/server/computation/step/UnitTestMeasuresStep.java
+++ b/server/sonar-server/src/main/java/org/sonar/server/computation/step/UnitTestMeasuresStep.java
@@ -23,6 +23,7 @@ package org.sonar.server.computation.step;
import com.google.common.base.Optional;
import com.google.common.collect.ImmutableList;
import org.sonar.server.computation.component.Component;
+import org.sonar.server.computation.component.CrawlerDepthLimit;
import org.sonar.server.computation.component.PathAwareCrawler;
import org.sonar.server.computation.component.TreeRootHolder;
import org.sonar.server.computation.formula.Counter;
@@ -97,8 +98,10 @@ public class UnitTestMeasuresStep implements ComputationStep {
}
private static Optional<Measure> createMeasure(Component.Type componentType, Optional<Integer> metricValue) {
- return (componentType.isHigherThan(Component.Type.FILE) && metricValue.isPresent()) ? Optional.of(Measure.newMeasureBuilder().create(metricValue.get()))
- : Optional.<Measure>absent();
+ if (metricValue.isPresent() && CrawlerDepthLimit.LEAVES.isDeeperThan(componentType)) {
+ return Optional.of(Measure.newMeasureBuilder().create(metricValue.get()));
+ }
+ return Optional.absent();
}
private static Optional<Measure> createDensityMeasure(UnitTestsCounter counter) {
diff --git a/server/sonar-server/src/test/java/org/sonar/server/computation/step/UnitTestMeasuresStepTest.java b/server/sonar-server/src/test/java/org/sonar/server/computation/step/ReportUnitTestMeasuresStepTest.java
index 143af7e3010..02f7f589675 100644
--- a/server/sonar-server/src/test/java/org/sonar/server/computation/step/UnitTestMeasuresStepTest.java
+++ b/server/sonar-server/src/test/java/org/sonar/server/computation/step/ReportUnitTestMeasuresStepTest.java
@@ -21,7 +21,6 @@
package org.sonar.server.computation.step;
import org.assertj.core.data.Offset;
-import org.junit.Before;
import org.junit.Rule;
import org.junit.Test;
import org.sonar.server.computation.batch.TreeRootHolderRule;
@@ -52,7 +51,7 @@ import static org.sonar.server.computation.measure.Measure.newMeasureBuilder;
import static org.sonar.server.computation.measure.MeasureRepoEntry.entryOf;
import static org.sonar.server.computation.measure.MeasureRepoEntry.toEntries;
-public class UnitTestMeasuresStepTest {
+public class ReportUnitTestMeasuresStepTest {
private static final Offset<Double> DEFAULT_OFFSET = Offset.offset(0.01d);
@@ -64,8 +63,22 @@ public class UnitTestMeasuresStepTest {
private static final int FILE_2_REF = 12342;
@Rule
- public TreeRootHolderRule treeRootHolder = new TreeRootHolderRule();
-
+ public TreeRootHolderRule treeRootHolder = new TreeRootHolderRule()
+ .setRoot(
+ builder(PROJECT, ROOT_REF)
+ .addChildren(
+ builder(MODULE, MODULE_REF)
+ .addChildren(
+ builder(MODULE, SUB_MODULE_REF)
+ .addChildren(
+ builder(DIRECTORY, DIRECTORY_REF)
+ .addChildren(
+ builder(FILE, FILE_1_REF).setFileAttributes(new FileAttributes(true, null)).build(),
+ builder(FILE, FILE_2_REF).setFileAttributes(new FileAttributes(true, null)).build())
+ .build())
+ .build())
+ .build())
+ .build());
@Rule
public MetricRepositoryRule metricRepository = new MetricRepositoryRule()
.add(TESTS)
@@ -74,31 +87,11 @@ public class UnitTestMeasuresStepTest {
.add(TEST_EXECUTION_TIME)
.add(SKIPPED_TESTS)
.add(TEST_SUCCESS_DENSITY);
-
@Rule
public MeasureRepositoryRule measureRepository = MeasureRepositoryRule.create(treeRootHolder, metricRepository);
ComputationStep underTest = new UnitTestMeasuresStep(treeRootHolder, metricRepository, measureRepository);
- @Before
- public void setUp() throws Exception {
- treeRootHolder.setRoot(
- builder(PROJECT, ROOT_REF)
- .addChildren(
- builder(MODULE, MODULE_REF)
- .addChildren(
- builder(MODULE, SUB_MODULE_REF)
- .addChildren(
- builder(DIRECTORY, DIRECTORY_REF)
- .addChildren(
- builder(FILE, FILE_1_REF).setFileAttributes(new FileAttributes(true, null)).build(),
- builder(FILE, FILE_2_REF).setFileAttributes(new FileAttributes(true, null)).build()
- ).build()
- ).build()
- ).build()
- ).build());
- }
-
@Test
public void aggregate_tests() {
checkMeasuresAggregation(TESTS_KEY, 100, 400, 500);
diff --git a/server/sonar-server/src/test/java/org/sonar/server/computation/step/ViewsUnitTestMeasuresStepTest.java b/server/sonar-server/src/test/java/org/sonar/server/computation/step/ViewsUnitTestMeasuresStepTest.java
new file mode 100644
index 00000000000..020016b501f
--- /dev/null
+++ b/server/sonar-server/src/test/java/org/sonar/server/computation/step/ViewsUnitTestMeasuresStepTest.java
@@ -0,0 +1,282 @@
+/*
+ * SonarQube, open source software quality management tool.
+ * Copyright (C) 2008-2014 SonarSource
+ * mailto:contact AT sonarsource DOT com
+ *
+ * SonarQube 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.
+ *
+ * SonarQube 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.computation.step;
+
+import org.junit.Rule;
+import org.junit.Test;
+import org.sonar.server.computation.batch.TreeRootHolderRule;
+import org.sonar.server.computation.measure.MeasureRepositoryRule;
+import org.sonar.server.computation.metric.MetricRepositoryRule;
+
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.assertj.guava.api.Assertions.assertThat;
+import static org.sonar.api.measures.CoreMetrics.SKIPPED_TESTS;
+import static org.sonar.api.measures.CoreMetrics.SKIPPED_TESTS_KEY;
+import static org.sonar.api.measures.CoreMetrics.TESTS;
+import static org.sonar.api.measures.CoreMetrics.TESTS_KEY;
+import static org.sonar.api.measures.CoreMetrics.TEST_ERRORS;
+import static org.sonar.api.measures.CoreMetrics.TEST_ERRORS_KEY;
+import static org.sonar.api.measures.CoreMetrics.TEST_EXECUTION_TIME;
+import static org.sonar.api.measures.CoreMetrics.TEST_EXECUTION_TIME_KEY;
+import static org.sonar.api.measures.CoreMetrics.TEST_FAILURES;
+import static org.sonar.api.measures.CoreMetrics.TEST_FAILURES_KEY;
+import static org.sonar.api.measures.CoreMetrics.TEST_SUCCESS_DENSITY;
+import static org.sonar.api.measures.CoreMetrics.TEST_SUCCESS_DENSITY_KEY;
+import static org.sonar.server.computation.component.Component.Type.PROJECT_VIEW;
+import static org.sonar.server.computation.component.Component.Type.SUBVIEW;
+import static org.sonar.server.computation.component.Component.Type.VIEW;
+import static org.sonar.server.computation.component.ViewsComponent.builder;
+import static org.sonar.server.computation.measure.Measure.newMeasureBuilder;
+import static org.sonar.server.computation.measure.MeasureRepoEntry.entryOf;
+import static org.sonar.server.computation.measure.MeasureRepoEntry.toEntries;
+
+public class ViewsUnitTestMeasuresStepTest {
+
+ private static final int ROOT_REF = 1;
+ private static final int SUBVIEW_REF = 12;
+ private static final int SUB_SUBVIEW_1_REF = 123;
+ private static final int PROJECT_VIEW_1_REF = 12341;
+ private static final int PROJECT_VIEW_2_REF = 12342;
+ private static final int SUB_SUBVIEW_2_REF = 124;
+
+ @Rule
+ public TreeRootHolderRule treeRootHolder = new TreeRootHolderRule()
+ .setRoot(
+ builder(VIEW, ROOT_REF)
+ .addChildren(
+ builder(SUBVIEW, SUBVIEW_REF)
+ .addChildren(
+ builder(SUBVIEW, SUB_SUBVIEW_1_REF)
+ .addChildren(
+ builder(PROJECT_VIEW, PROJECT_VIEW_1_REF).build(),
+ builder(PROJECT_VIEW, PROJECT_VIEW_2_REF).build())
+ .build(),
+ builder(SUBVIEW, SUB_SUBVIEW_2_REF).build())
+ .build())
+ .build());
+ @Rule
+ public MetricRepositoryRule metricRepository = new MetricRepositoryRule()
+ .add(TESTS)
+ .add(TEST_ERRORS)
+ .add(TEST_FAILURES)
+ .add(TEST_EXECUTION_TIME)
+ .add(SKIPPED_TESTS)
+ .add(TEST_SUCCESS_DENSITY);
+ @Rule
+ public MeasureRepositoryRule measureRepository = MeasureRepositoryRule.create(treeRootHolder, metricRepository);
+
+ ComputationStep underTest = new UnitTestMeasuresStep(treeRootHolder, metricRepository, measureRepository);
+
+ @Test
+ public void aggregate_tests() {
+ checkMeasuresAggregation(TESTS_KEY, 100, 400, 500);
+ }
+
+ @Test
+ public void aggregate_tests_in_errors() {
+ checkMeasuresAggregation(TEST_ERRORS_KEY, 100, 400, 500);
+ }
+
+ @Test
+ public void aggregate_tests_in_failures() {
+ checkMeasuresAggregation(TEST_FAILURES_KEY, 100, 400, 500);
+ }
+
+ @Test
+ public void aggregate_tests_execution_time() {
+ checkMeasuresAggregation(TEST_EXECUTION_TIME_KEY, 100, 400, 500);
+ }
+
+ @Test
+ public void aggregate_skipped_tests_time() {
+ checkMeasuresAggregation(SKIPPED_TESTS_KEY, 100, 400, 500);
+ }
+
+ @Test
+ public void compute_test_success_density() {
+ addedRawMeasure(PROJECT_VIEW_1_REF, TESTS_KEY, 10);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_ERRORS_KEY, 2);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_ERRORS_KEY, 5);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_FAILURES_KEY, 4);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_FAILURES_KEY, 1);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertAddedRawMeasureValue(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY, 60d);
+ assertAddedRawMeasureValue(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY, 60d);
+ assertAddedRawMeasureValue(ROOT_REF, TEST_SUCCESS_DENSITY_KEY, 60d);
+ }
+
+ @Test
+ public void compute_test_success_density_when_zero_tests_in_errors() {
+ addedRawMeasure(PROJECT_VIEW_1_REF, TESTS_KEY, 10);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_ERRORS_KEY, 0);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_ERRORS_KEY, 0);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_FAILURES_KEY, 4);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_FAILURES_KEY, 1);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertAddedRawMeasureValue(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY, 83.3d);
+ assertNoAddedRawMeasure(SUB_SUBVIEW_2_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertAddedRawMeasureValue(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY, 83.3d);
+ assertAddedRawMeasureValue(ROOT_REF, TEST_SUCCESS_DENSITY_KEY, 83.3d);
+ }
+
+ @Test
+ public void compute_test_success_density_when_zero_tests_in_failures() {
+ addedRawMeasure(PROJECT_VIEW_1_REF, TESTS_KEY, 10);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_ERRORS_KEY, 2);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_ERRORS_KEY, 5);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_FAILURES_KEY, 0);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_FAILURES_KEY, 0);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertAddedRawMeasureValue(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY, 76.7d);
+ assertNoAddedRawMeasure(SUB_SUBVIEW_2_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertAddedRawMeasureValue(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY, 76.7d);
+ assertAddedRawMeasureValue(ROOT_REF, TEST_SUCCESS_DENSITY_KEY, 76.7d);
+ }
+
+ @Test
+ public void compute_100_percent_test_success_density_when_no_tests_in_errors_or_failures() {
+ addedRawMeasure(PROJECT_VIEW_1_REF, TESTS_KEY, 10);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_ERRORS_KEY, 0);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_ERRORS_KEY, 0);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_FAILURES_KEY, 0);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_FAILURES_KEY, 0);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertAddedRawMeasureValue(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY, 100d);
+ assertNoAddedRawMeasure(SUB_SUBVIEW_2_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertAddedRawMeasureValue(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY, 100d);
+ assertAddedRawMeasureValue(ROOT_REF, TEST_SUCCESS_DENSITY_KEY, 100d);
+ }
+
+ @Test
+ public void compute_0_percent_test_success_density() {
+ int value = 10;
+ String metricKey = TESTS_KEY;
+ int componentRef = PROJECT_VIEW_1_REF;
+ addedRawMeasure(componentRef, metricKey, value);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_ERRORS_KEY, 8);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_ERRORS_KEY, 15);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_FAILURES_KEY, 2);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_FAILURES_KEY, 5);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertAddedRawMeasureValue(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY, 0d);
+ assertNoAddedRawMeasure(SUB_SUBVIEW_2_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertAddedRawMeasureValue(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY, 0d);
+ assertAddedRawMeasureValue(ROOT_REF, TEST_SUCCESS_DENSITY_KEY, 0d);
+ }
+
+ @Test
+ public void do_not_compute_test_success_density_when_no_tests_in_errors() {
+ addedRawMeasure(PROJECT_VIEW_1_REF, TESTS_KEY, 10);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_FAILURES_KEY, 4);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_FAILURES_KEY, 1);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertNoAddedRawMeasure(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertNoAddedRawMeasure(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertNoAddedRawMeasure(ROOT_REF, TEST_SUCCESS_DENSITY_KEY);
+ }
+
+ @Test
+ public void do_not_compute_test_success_density_when_no_tests_in_failure() {
+ addedRawMeasure(PROJECT_VIEW_1_REF, TESTS_KEY, 10);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TESTS_KEY, 20);
+
+ addedRawMeasure(PROJECT_VIEW_1_REF, TEST_ERRORS_KEY, 0);
+ addedRawMeasure(PROJECT_VIEW_2_REF, TEST_ERRORS_KEY, 0);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertNoAddedRawMeasure(SUB_SUBVIEW_1_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertNoAddedRawMeasure(SUBVIEW_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertNoAddedRawMeasure(ROOT_REF, TEST_SUCCESS_DENSITY_KEY);
+ }
+
+ private void checkMeasuresAggregation(String metricKey, int file1Value, int file2Value, int expectedValue) {
+ addedRawMeasure(PROJECT_VIEW_1_REF, metricKey, file1Value);
+ addedRawMeasure(PROJECT_VIEW_2_REF, metricKey, file2Value);
+
+ underTest.execute();
+
+ assertNoAddedRawMeasureOnProjectViews();
+ assertAddedRawMeasureValue(SUB_SUBVIEW_1_REF, metricKey, expectedValue);
+ assertNoAddedRawMeasure(SUB_SUBVIEW_2_REF, TEST_SUCCESS_DENSITY_KEY);
+ assertAddedRawMeasureValue(SUBVIEW_REF, metricKey, expectedValue);
+ assertAddedRawMeasureValue(ROOT_REF, metricKey, expectedValue);
+ }
+
+ private void addedRawMeasure(int componentRef, String metricKey, int value) {
+ measureRepository.addRawMeasure(componentRef, metricKey, newMeasureBuilder().create(value));
+ }
+
+ private void assertAddedRawMeasureValue(int componentRef, String metricKey, double value) {
+ assertThat(entryOf(metricKey, measureRepository.getAddedRawMeasure(componentRef, metricKey).get()))
+ .isEqualTo(entryOf(metricKey, newMeasureBuilder().create(value)));
+ }
+
+ private void assertNoAddedRawMeasure(int componentRef, String metricKey) {
+ assertThat(measureRepository.getAddedRawMeasure(componentRef, metricKey)).isAbsent();
+ }
+
+ private void assertAddedRawMeasureValue(int componentRef, String metricKey, int expectedValue) {
+ assertThat(toEntries(measureRepository.getAddedRawMeasures(componentRef))).containsOnly(entryOf(metricKey, newMeasureBuilder().create(expectedValue)));
+ }
+
+ private void assertNoAddedRawMeasureOnProjectViews() {
+ assertThat(measureRepository.getAddedRawMeasures(PROJECT_VIEW_1_REF)).isEmpty();
+ assertThat(measureRepository.getAddedRawMeasures(PROJECT_VIEW_2_REF)).isEmpty();
+ }
+
+}