All Downloads are FREE. Search and download functionalities are using the official Maven repository.

patterntesting.runtime.monitor.ProfileAspect.aj Maven / Gradle / Ivy

Go to download

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.

There is a newer version: 2.4.0
Show newest version
/**
 * $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());
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy