patterntesting.runtime.monitor.ProfileAspect.aj Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of patterntesting-rt Show documentation
Show all versions of patterntesting-rt Show documentation
PatternTesting Runtime (patterntesting-rt) is the runtime component for
the PatternTesting framework. It provides the annotations and base classes
for the PatternTesting testing framework (e.g. patterntesting-check,
patterntesting-concurrent or patterntesting-exception) but can be also
used standalone for classpath monitoring or profiling.
It uses AOP and AspectJ to perform this feat.
/**
* $Id: ProfileAspect.aj,v 1.2 2014/04/21 16:04:52 oboehm Exp $
*
* Copyright (c) 2008 by Oliver Boehm
*
* 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 orimplied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
* (c)reated 19.12.2008 by oliver ([email protected])
*/
package patterntesting.runtime.monitor;
import org.aspectj.lang.*;
import org.aspectj.lang.annotation.SuppressAjWarnings;
import org.slf4j.*;
import patterntesting.runtime.annotation.*;
/**
* @author oliver
* @since 19.12.2008
*/
public aspect ProfileAspect extends AbstractProfileAspect {
private static final Logger log = LoggerFactory.getLogger(ProfileAspect.class);
/**
* To return the aspect specific logger to the super aspect.
* @return the aspect specific logger
*/
public final Logger getLog() {
return log;
}
/**
* applicationCode() includes all methods and constructors marked with
* "@ProfileMe" but exclude the methods and constructors marked with
* "@DontProfileMe".
*/
public pointcut applicationCode() :
profiledMethods() && !unprofiledMethods();
/**
* profiledMethods() includes also the constructors marked with
* "@ProfileMe".
*/
pointcut profiledMethods() :
((execution(* *..*.*(..)) || execution(*..*.new(..)))
&& within(@ProfileMe *))
|| execution(@ProfileMe *..*.new(..))
|| execution(@ProfileMe * *..*.*(..))
;
/**
* unprofiledMethods() includes both: methods and constructors marked with
* "@DontProfileMe".
*/
pointcut unprofiledMethods() :
execution(@DontProfileMe *..*.new(..))
|| execution(@DontProfileMe * *..*.*(..));
pointcut profiledClasses() :
staticinitialization(@ProfileMe *..*);
/**
* Put the profiled into the internal statistic table after the the class
* is initialized.
*/
@SuppressAjWarnings({"adviceDidNotMatch"})
after() : profiledClasses() {
Signature sig = thisJoinPointStaticPart.getSignature();
ProfileStatistic.getInstance().init(sig.getDeclaringType());
}
}