/**
* Copyright 2014 SAP AG
*
* 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 org.aim.artifacts.probes;
import org.aim.api.instrumentation.AbstractEnclosingProbe;
import org.aim.api.instrumentation.ProbeAfterPart;
import org.aim.api.instrumentation.ProbeBeforePart;
import org.aim.api.instrumentation.ProbeVariable;
import org.aim.artifacts.records.NanoResponseTimeRecord;
import org.aim.description.probes.MeasurementProbe;
import org.aim.description.scopes.MethodsEnclosingScope;
import org.lpe.common.extension.IExtension;
/**
* Probe for measuring response time in nano-seconds.
*
* @author Alexander Wert
*
*/
public class NanoResponsetimeProbe extends AbstractEnclosingProbe {
public static final MeasurementProbe<MethodsEnclosingScope> MODEL_PROBE = new MeasurementProbe<>(
NanoResponsetimeProbe.class.getName());
/**
* Constructor.
*
* @param provider
* extension provider.
*/
public NanoResponsetimeProbe(IExtension<?> provider) {
super(provider);
}
@ProbeVariable
public long _NanoResponsetimeProbe_startTime;
@ProbeVariable
public long _NanoResponsetimeProbe_stopTime;
@ProbeVariable
public NanoResponseTimeRecord _NanoResponsetimeProbe_record;
/**
* Before part.
*/
@ProbeBeforePart
public void beforePart() {
_NanoResponsetimeProbe_startTime = System.nanoTime();
}
/**
* After part.
*/
@ProbeAfterPart
public void afterPart() {
_NanoResponsetimeProbe_stopTime = System.nanoTime();
_NanoResponsetimeProbe_record = new NanoResponseTimeRecord();
_NanoResponsetimeProbe_record.setCallId(_GenericProbe_callId);
_NanoResponsetimeProbe_record.setOperation(__methodSignature);
_NanoResponsetimeProbe_record.setNanoTimestamp(_NanoResponsetimeProbe_startTime);
_NanoResponsetimeProbe_record.setResponseTime(_NanoResponsetimeProbe_stopTime
- _NanoResponsetimeProbe_startTime);
_NanoResponsetimeProbe_record.setTimeStamp(_GenericProbe_startTime);
_GenericProbe_collector.newRecord(_NanoResponsetimeProbe_record);
}
}