/** * Copyright 2015 ArcBees Inc. * * Licensed 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 com.arcbees.gaestudio.client.application.profiler.widget; import java.util.HashSet; import com.arcbees.gaestudio.client.application.profiler.DbOperationRecordProcessor; import com.arcbees.gaestudio.shared.dto.DbOperationRecordDto; import com.arcbees.gaestudio.shared.dto.query.QueryRecordDto; import com.google.inject.Inject; import com.google.web.bindery.event.shared.EventBus; import com.gwtplatform.mvp.client.PresenterWidget; import com.gwtplatform.mvp.client.View; public class StatisticsPresenter extends PresenterWidget<StatisticsPresenter.MyView> implements DbOperationRecordProcessor { interface MyView extends View { void updateRequestCount(Integer requestCount); void updateStatementCount(Integer statementCount); void updateTotalExecutionTimeMs(Integer totalExecutionTimeMs); void updateTotalObjectsRetrieved(Integer totalObjectsRetrieved); void updateTotalDataReceived(Integer totalDataReceived); } private final HashSet<Long> knownRequestIds = new HashSet<Long>(); private Integer statementCount; private Integer totalExecutionTimeMs; private Integer totalObjectsRetrieved; private Integer totalDataReceived; @Inject StatisticsPresenter( EventBus eventBus, MyView view) { super(eventBus, view); initStats(); } @Override public void processDbOperationRecord(DbOperationRecordDto record) { final long requestId = record.getRequestId(); knownRequestIds.add(requestId); statementCount++; totalExecutionTimeMs += record.getExecutionTimeMs(); if (record instanceof QueryRecordDto) { QueryRecordDto queryRecord = (QueryRecordDto) record; totalObjectsRetrieved += queryRecord.getQueryResult().getResultSize(); totalDataReceived += queryRecord.getQueryResult().getSerializedSize(); } } @Override public void displayNewDbOperationRecords() { getView().updateRequestCount(knownRequestIds.size()); getView().updateStatementCount(statementCount); getView().updateTotalExecutionTimeMs(totalExecutionTimeMs); getView().updateTotalObjectsRetrieved(totalObjectsRetrieved); getView().updateTotalDataReceived(totalDataReceived); } @Override public void clearOperationRecords() { initStats(); } private void initStats() { knownRequestIds.clear(); this.statementCount = 0; this.totalExecutionTimeMs = 0; this.totalObjectsRetrieved = 0; this.totalDataReceived = 0; } }