Package mondrian.test

Source Code of mondrian.test.MonitorTest

/*
// This software is subject to the terms of the Eclipse Public License v1.0
// Agreement, available at the following URL:
// http://www.eclipse.org/legal/epl-v10.html.
// You must accept the terms of that agreement to use this software.
//
// Copyright (C) 2011-2014 Pentaho
// All Rights Reserved.
*/
package mondrian.test;

import mondrian.olap.MondrianServer;
import mondrian.server.monitor.*;

import org.olap4j.CellSet;
import org.olap4j.OlapStatement;
import org.olap4j.layout.RectangularCellSetFormatter;

import java.io.PrintWriter;
import java.io.StringWriter;
import java.sql.SQLException;
import java.util.List;

/**
* Unit test for monitoring, including {@link mondrian.server.monitor.Monitor}.
*
* @author jhyde
*/
public class MonitorTest extends FoodMartTestCase {
    private void println(Object x) {
        // Enable for debugging, but not for checked-in code.
        if (false) {
            System.out.println(x);
        }
    }

    /**
     * Exercises as many fields of the monitoring stats classes as possible.
     * So that we can check that they are being populated.
     */
    public void testMe() throws SQLException {
        String queryString =
            "WITH MEMBER [Measures].[Foo] AS\n"
            + " [Measures].[Unit Sales]"
            + " + case when [Measures].[Unit Sales] > 0\n"
            + "   then CInt( ([Measures].[Foo], [Time].PrevMember) )\n"
            + "   end\n"
            + "SELECT [Measures].[Foo] on 0\n"
            + "from [Sales]\n"
            + "where [Time].[1997].[Q3].[9]";

        final OlapStatement statement1 =
            getTestContext().getOlap4jConnection().createStatement();
        CellSet cellSet = statement1.executeOlapQuery(queryString);
        StringWriter stringWriter = new StringWriter();
        new RectangularCellSetFormatter(true).format(
            cellSet,
            new PrintWriter(stringWriter));
        statement1.close();
        println(stringWriter);

        final MondrianServer mondrianServer =
            MondrianServer.forConnection(getConnection());
        final Monitor monitor = mondrianServer.getMonitor();
        final ServerInfo server = monitor.getServer();

        println(
            "# stmts open: "
            + server.getStatementCurrentlyOpenCount());

        println(
            "# connections open: "
            + server.getConnectionCurrentlyOpenCount());

        println("# rows fetched: " + server.sqlStatementRowFetchCount);

        println(
            "# sql stmts open: "
            + server.getSqlStatementCurrentlyOpenCount());

        // # sql stmts by category (cell query, member query, other)
        //  -- if you want to do this, capture sql statement events

        // cell cache requests
        // cell cache misses
        // cell cache hits
        final List<ConnectionInfo> connections = monitor.getConnections();
        ConnectionInfo lastConnection = connections.get(connections.size() - 1);

        // Cannot reliably retrieve the last statement, since statements are
        // removed from the map on completion.
        //final List<StatementInfo> statements = monitor.getStatements();
        //StatementInfo lastStatement = statements.get(statements.size() - 1);

        println(
            "# cell cache requests, misses, hits; "
            + "by server, connection, mdx statement: "
            + server.cellCacheRequestCount
            + ", " + server.getCellCacheMissCount()
            + ", " + server.cellCacheHitCount
            + "; " + lastConnection.cellCacheRequestCount
            + ", " + (lastConnection.cellCacheRequestCount
                      - lastConnection.cellCacheHitCount)
            + ", " + lastConnection.cellCacheHitCount);

        // cache misses in the last minute
        // cache hits in the last minute
        // -- build a layer on top of monitor that polls say every 15 seconds,
        //    and keeps results for a few minutes

        println(
            "number of mdx statements currently open: "
            + server.getStatementCurrentlyOpenCount());
        println(
            "number of mdx statements currently executing: "
            + server.getStatementCurrentlyExecutingCount());

        println(
            "jvm memory: " + server.jvmHeapBytesUsed
            + ", max: " + server.jvmHeapBytesMax
            + ", committed: " + server.jvmHeapBytesCommitted);

        println(
            "number of segments: " + server.segmentCount
            + ", ever created: " + server.segmentCreateCount
            + ", number of cells: " + server.cellCount
            + ", number of cell coordinates: " + server.cellCoordinateCount
            + ", average cell dimensionality: "
            + ((float) server.cellCoordinateCount / (float) server.cellCount));

        println("Connection: " + lastConnection);
        println("Server: " + server);

        // number of mdx function calls cumulative
        // how many operations have been evaluated in sql?
        // number of members in cache
        // number of cells in segments
        // mdx query time
        // sql query time
        // sql rows
        // olap4j connection pool size
        // sql connection pool size
        // thread count
        // # schemas in schema cache
        // cells fulfilled by sql statements
        // mondrian server count (other stats relate to just one server)
        //
        // Events:
        //
        // SQL statement start
        // SQL statment stop
        // external cache call
        // sort
        // (other expensive operations similar to sort?)
    }
}

// End MonitorTest.java
TOP

Related Classes of mondrian.test.MonitorTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.