http://git-wip-us.apache.org/repos/asf/kylin/blob/8e078847/server/src/test/java/org/apache/kylin/rest/metrics/QueryMetrics2Test.java
----------------------------------------------------------------------
diff --git 
a/server/src/test/java/org/apache/kylin/rest/metrics/QueryMetrics2Test.java 
b/server/src/test/java/org/apache/kylin/rest/metrics/QueryMetrics2Test.java
new file mode 100644
index 0000000..5e3e00b
--- /dev/null
+++ b/server/src/test/java/org/apache/kylin/rest/metrics/QueryMetrics2Test.java
@@ -0,0 +1,128 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements.  See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership.  The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License.  You may obtain a copy of the License at
+ *
+ *     http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.kylin.rest.metrics;
+
+import static 
org.apache.kylin.common.metrics.common.Metricss.buildCubeMetricPrefix;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.concurrent.TimeUnit;
+
+import javax.management.MBeanServer;
+import javax.management.ObjectName;
+
+import org.apache.kylin.common.metrics.common.Metrics;
+import org.apache.kylin.common.metrics.common.MetricsConstant;
+import org.apache.kylin.common.metrics.common.MetricsFactory;
+import org.apache.kylin.common.metrics.common.Metricss;
+import org.apache.kylin.rest.request.SQLRequest;
+import org.apache.kylin.rest.response.SQLResponse;
+import org.apache.kylin.rest.service.ServiceTestBase;
+import org.junit.Assert;
+import org.junit.Before;
+import org.junit.Test;
+
+import com.codahale.metrics.Snapshot;
+
+public class QueryMetrics2Test extends ServiceTestBase {
+
+    private static MBeanServer mBeanServer;
+    private static ObjectName objectName;
+
+    @Before
+    public void setup() throws Exception {
+        super.setup();
+
+        objectName = new ObjectName("Hadoop:service=Kylin,name=Server_Total");
+    }
+
+    @Test
+    public void testQueryMetrics() throws Exception {
+        System.setProperty("kylin.server.query-metrics-enabled", "true");
+        QueryMetrics2Facade.init();
+
+        SQLRequest sqlRequest = new SQLRequest();
+        sqlRequest.setSql("select * from TEST_KYLIN_FACT");
+        sqlRequest.setProject("default");
+
+        SQLResponse sqlResponse = new SQLResponse();
+        sqlResponse.setDuration(10);
+        sqlResponse.setCube("test_cube");
+        sqlResponse.setIsException(false);
+        sqlResponse.setTotalScanCount(100);
+        List<String> list1 = new ArrayList<>();
+        list1.add("111");
+        list1.add("112");
+        List<String> list2 = new ArrayList<>();
+        list2.add("111");
+        list2.add("112");
+        List<List<String>> results = new ArrayList<>();
+        results.add(list1);
+        results.add(list2);
+        sqlResponse.setResults(results);
+        sqlResponse.setStorageCacheUsed(true);
+        Metrics metrics = MetricsFactory.getInstance();
+        QueryMetrics2Facade.updateMetrics(sqlRequest, sqlResponse);
+        String prefix = buildCubeMetricPrefix(sqlRequest.getProject(), 
sqlResponse.getCube().replace("=", "->"));
+        Thread.sleep(2000);
+
+        Assert.assertEquals(1L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_COUNT)).getCount());
+        Assert.assertEquals(1L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_SUCCESS_COUNT)).getCount());
+        Assert.assertEquals(0L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_FAIL_COUNT)).getCount());
+        Assert.assertEquals(1L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_CACHE_COUNT)).getCount());
+        //
+        Snapshot  queryScanSnapshot= metrics
+                .getHistogram(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_SCAN_ROWCOUNT)).getSnapshot();
+        Assert.assertEquals(100.0, queryScanSnapshot.getMean(), 0);
+        Assert.assertEquals(100.0, queryScanSnapshot.getMax(), 0);
+        Assert.assertEquals(100.0, queryScanSnapshot.getMin(), 0);
+
+        Snapshot queryResultSnapshot = metrics
+                .getHistogram(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_RESULT_ROWCOUNT)).getSnapshot();
+
+        Assert.assertEquals(2.0, queryResultSnapshot.getMean(), 0);
+        Assert.assertEquals(2.0, queryResultSnapshot.getMax(), 0);
+        Assert.assertEquals(2.0, queryResultSnapshot.getMin(), 0);
+
+        Snapshot queryLatencySnapshot = 
metrics.getTimer(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_DURATION)).getSnapshot();
+        Assert.assertEquals(TimeUnit.MILLISECONDS.toNanos(10), 
queryLatencySnapshot.getMean(), 0);
+        Assert.assertEquals(TimeUnit.MILLISECONDS.toNanos(10), 
queryLatencySnapshot.getMax(), 0);
+        Assert.assertEquals(TimeUnit.MILLISECONDS.toNanos(10), 
queryLatencySnapshot.getMin(), 0);
+
+                SQLResponse sqlResponse2 = new SQLResponse();
+                sqlResponse2.setDuration(10);
+                sqlResponse2.setCube("test_cube");
+                sqlResponse2.setIsException(true);
+
+
+        QueryMetrics2Facade.updateMetrics(sqlRequest, sqlResponse2);
+         prefix = buildCubeMetricPrefix(sqlRequest.getProject(), 
sqlResponse.getCube().replace("=", "->"));
+        Assert.assertEquals(2L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_COUNT)).getCount());
+        Assert.assertEquals(1L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_SUCCESS_COUNT)).getCount());
+        Assert.assertEquals(1L,
+                metrics.getCounter(Metricss.buildMetricName(prefix, 
MetricsConstant.QUERY_FAIL_COUNT)).getCount());
+    }
+
+}

Reply via email to