]> source.dussan.org Git - sonarqube.git/commitdiff
SONAR-13941 move api/views/app endpoint to DE and rename to api/metrics/user_metrics
authorDuarte Meneses <duarte.meneses@sonarsource.com>
Thu, 8 Oct 2020 16:43:02 +0000 (11:43 -0500)
committersonartech <sonartech@sonarsource.com>
Fri, 23 Oct 2020 20:08:29 +0000 (20:08 +0000)
server/sonar-webserver-webapi/src/main/java/org/sonar/server/metric/ws/MetricsWsModule.java
server/sonar-webserver-webapi/src/main/java/org/sonar/server/metric/ws/UserMetricsAction.java [new file with mode: 0644]
server/sonar-webserver-webapi/src/main/resources/org/sonar/server/metric/ws/example-user-metrics.json [new file with mode: 0644]
server/sonar-webserver-webapi/src/test/java/org/sonar/server/metric/ws/MetricsWsModuleTest.java
server/sonar-webserver-webapi/src/test/java/org/sonar/server/metric/ws/UserMetricsActionTest.java [new file with mode: 0644]
server/sonar-webserver-webapi/src/test/resources/org/sonar/server/metric/ws/UserMetricsActionTest/app.json [new file with mode: 0644]

index 989a7ff3ce5a54c5b79eb645ea9ea588d6f02a15..3177cca460fa3bc6caa82ac22f3b885f529fcf5b 100644 (file)
@@ -31,6 +31,7 @@ public class MetricsWsModule extends Module {
       DomainsAction.class,
       SearchAction.class,
       UpdateAction.class,
+      UserMetricsAction.class,
       TypesAction.class);
   }
 }
diff --git a/server/sonar-webserver-webapi/src/main/java/org/sonar/server/metric/ws/UserMetricsAction.java b/server/sonar-webserver-webapi/src/main/java/org/sonar/server/metric/ws/UserMetricsAction.java
new file mode 100644 (file)
index 0000000..2fcbef7
--- /dev/null
@@ -0,0 +1,64 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2020 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.server.metric.ws;
+
+import java.util.Collection;
+import org.sonar.api.measures.Metric;
+import org.sonar.api.measures.Metric.ValueType;
+import org.sonar.api.measures.MetricFinder;
+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;
+
+public class UserMetricsAction implements MetricsWsAction {
+
+  private final MetricFinder metricFinder;
+
+  public UserMetricsAction(MetricFinder metricFinder) {
+    this.metricFinder = metricFinder;
+  }
+
+  @Override
+  public void handle(Request request, Response response) {
+    Collection<Metric> metrics = metricFinder.findAll();
+    try (JsonWriter json = response.newJsonWriter()) {
+      json.beginObject()
+        .name("manual_metrics")
+        .beginObject();
+      metrics.stream()
+        .filter(metric -> metric.getUserManaged() && ValueType.STRING == metric.getType())
+        .forEach(metric -> json.prop(metric.getKey(), metric.getName()));
+      json.endObject();
+      json.name("remote_servers").beginArray().endArray().endObject();
+    }
+  }
+
+  @Override
+  public void define(WebService.NewController controller) {
+    controller.createAction("user_metrics")
+      .setDescription("Metrics managed by users")
+      .setSince("1.0")
+      .setDeprecatedSince("7.4")
+      .setInternal(true)
+      .setResponseExample(getClass().getResource("example-user-metrics.json"))
+      .setHandler(this);
+  }
+}
diff --git a/server/sonar-webserver-webapi/src/main/resources/org/sonar/server/metric/ws/example-user-metrics.json b/server/sonar-webserver-webapi/src/main/resources/org/sonar/server/metric/ws/example-user-metrics.json
new file mode 100644 (file)
index 0000000..a6d65f6
--- /dev/null
@@ -0,0 +1,6 @@
+{
+  "manual_metrics": {
+    "entity_name": "Entity Name"
+  },
+  "remote_servers": []
+}
index 09254cae0c1d9353a74f67b8d24191686860c032..1ba8e0b631110b275395c82a770ab236ced0bff5 100644 (file)
@@ -29,6 +29,6 @@ public class MetricsWsModuleTest {
   public void verify_count_of_added_components() {
     ComponentContainer container = new ComponentContainer();
     new MetricsWsModule().configure(container);
-    assertThat(container.size()).isEqualTo(9);
+    assertThat(container.size()).isEqualTo(10);
   }
 }
diff --git a/server/sonar-webserver-webapi/src/test/java/org/sonar/server/metric/ws/UserMetricsActionTest.java b/server/sonar-webserver-webapi/src/test/java/org/sonar/server/metric/ws/UserMetricsActionTest.java
new file mode 100644 (file)
index 0000000..0c1915e
--- /dev/null
@@ -0,0 +1,71 @@
+/*
+ * SonarQube
+ * Copyright (C) 2009-2020 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.server.metric.ws;
+
+import com.google.common.collect.Lists;
+import org.junit.Test;
+import org.sonar.api.measures.Metric;
+import org.sonar.api.measures.Metric.ValueType;
+import org.sonar.api.measures.MetricFinder;
+import org.sonar.server.ws.WsActionTester;
+
+import static org.assertj.core.api.Assertions.assertThat;
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.when;
+import static org.sonar.test.JsonAssert.assertJson;
+
+public class UserMetricsActionTest {
+
+  MetricFinder metrics = mock(MetricFinder.class);
+
+  WsActionTester ws = new WsActionTester(new UserMetricsAction(metrics));
+
+  @Test
+  public void test_definition() {
+    assertThat(ws.getDef().key()).isEqualTo("user_metrics");
+    assertThat(ws.getDef().isInternal()).isTrue();
+    assertThat(ws.getDef().responseExampleAsString()).isNotEmpty();
+    assertThat(ws.getDef().params()).isEmpty();
+  }
+
+  @Test
+  public void should_list_manual_metrics() {
+    Metric m1 = mock(Metric.class);
+    when(m1.getUserManaged()).thenReturn(true);
+    when(m1.getKey()).thenReturn("m1");
+    when(m1.getName()).thenReturn("Metric 1");
+    when(m1.getType()).thenReturn(ValueType.STRING);
+    Metric m2 = mock(Metric.class);
+    when(m2.getUserManaged()).thenReturn(false);
+    Metric m3 = mock(Metric.class);
+    when(m3.getUserManaged()).thenReturn(true);
+    when(m3.getKey()).thenReturn("m3");
+    when(m3.getName()).thenReturn("Metric 3");
+    when(m3.getType()).thenReturn(ValueType.STRING);
+    Metric m4 = mock(Metric.class);
+    when(m4.getUserManaged()).thenReturn(true);
+    when(m4.getKey()).thenReturn("m3");
+    when(m4.getName()).thenReturn("Metric 4");
+    when(m4.getType()).thenReturn(ValueType.INT);
+    when(metrics.findAll()).thenReturn(Lists.newArrayList(m1, m2, m3, m4));
+
+    assertJson(ws.newRequest().execute().getInput()).isSimilarTo(getClass().getResource("UserMetricsActionTest/app.json"));
+  }
+}
diff --git a/server/sonar-webserver-webapi/src/test/resources/org/sonar/server/metric/ws/UserMetricsActionTest/app.json b/server/sonar-webserver-webapi/src/test/resources/org/sonar/server/metric/ws/UserMetricsActionTest/app.json
new file mode 100644 (file)
index 0000000..d290005
--- /dev/null
@@ -0,0 +1,7 @@
+{
+  "manual_metrics": {
+    "m1": "Metric 1",
+    "m3": "Metric 3"
+  },
+  "remote_servers": []
+}