/*
* Copyright 2013 BiasedBit
*
* 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.biasedbit.http.client;
import com.biasedbit.http.client.event.EventType;
/**
* Provides statistics for an event processor.
* <p/>
* This is used mostly for development stages, to compare improvements of modifications.
* <p/>
* @see StatsGatheringHttpClient
*
* @author <a href="http://biasedbit.com/">Bruno de Carvalho</a>
*/
public interface EventProcessorStatsProvider {
/**
* @return Total execution time of the event processor, in milliseconds.
*/
long getTotalExecutionTime();
/**
* @param event Type of event to query for.
*
* @return Processing time for events of given type, in milliseconds.
*/
long getEventProcessingTime(EventType event);
/**
* @param event Type of event to query for.
*
* @return Processing percentage (ratio) of a given type, between 0 and 100
*/
float getEventProcessingPercentage(EventType event);
/**
* @return Total of processed events.
*/
long getProcessedEvents();
long getProcessedEvents(EventType event);
}