/** * 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.ProbeVariable; import org.aim.artifacts.records.ResponseTimeRecord; import org.aim.description.probes.MeasurementProbe; import org.aim.description.scopes.MethodsEnclosingScope; import org.lpe.common.extension.IExtension; /** * Probe for measuring response time in milli-seconds. * * @author Alexander Wert * */ public class ResponsetimeProbe extends AbstractEnclosingProbe { /** * Constructor. * * @param provider * extension provider. */ public ResponsetimeProbe(IExtension<?> provider) { super(provider); } public static final MeasurementProbe<MethodsEnclosingScope> MODEL_PROBE = new MeasurementProbe<>( ResponsetimeProbe.class.getName()); @ProbeVariable public long _ResponsetimeProbe_stopTime; @ProbeVariable public ResponseTimeRecord _ResponsetimeProbe_record; /** * After part. */ @ProbeAfterPart() public void afterPart() { _ResponsetimeProbe_stopTime = System.currentTimeMillis(); _ResponsetimeProbe_record = new ResponseTimeRecord(); _ResponsetimeProbe_record.setCallId(_GenericProbe_callId); _ResponsetimeProbe_record.setOperation(__methodSignature); _ResponsetimeProbe_record.setResponseTime(_ResponsetimeProbe_stopTime - _GenericProbe_startTime); _ResponsetimeProbe_record.setTimeStamp(_GenericProbe_startTime); _GenericProbe_collector.newRecord(_ResponsetimeProbe_record); } }