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

patterntesting.runtime.log.AbstractTraceAspect.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: AbstractTraceAspect.aj,v 1.1 2011/12/22 16:32:26 oboehm Exp $
 *
 * Copyright (c) 2010 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 30.09.2010 by oliver ([email protected])
 */

package patterntesting.runtime.log;

import org.aspectj.lang.annotation.SuppressAjWarnings;

/**
 * This aspect handles the logging output. It may slow down your application
 * because it uses the stacktrace for determing the right indent for pretty
 * printing. So use this aspect with care.
 * 
 * @author oliver
 * @since 1.0.3 (30.09.2010)
 */
public abstract aspect AbstractTraceAspect {

    /**
     * Application code.
     */
    public abstract pointcut applicationCode();
    
    private pointcut allMethods() :
        execution(*..*.new(..)) || execution(* *..*.*(..));
    
    private pointcut voidMethods() :
        execution(void *..*.*(..));
    
    private pointcut nonVoidMethods() :
        execution(* *..*.*(..)) && !voidMethods();
    
    private pointcut constructors() :
        execution(*..*.new(..));
    
    private pointcut setFields() :
        set(* *..*);

    /**
     * Trace the start of a method or piece of code.
     */
    @SuppressAjWarnings({"adviceDidNotMatch"})
    before() : applicationCode() && (allMethods() || staticinitialization(*..*)) {
        Trace.start(thisJoinPoint);
    }
    
    /**
     * Trace the exception handling.
     */
    @SuppressAjWarnings({"adviceDidNotMatch"})
    before() : applicationCode() && handler(Throwable+) {
        Trace.trace(thisJoinPoint);
    }
    
    /**
     * Trace the result of a finished method.
     * 
     * @param result the return value
     */
    @SuppressAjWarnings({"adviceDidNotMatch"})
    after() returning(Object result) : applicationCode() && 
            (nonVoidMethods()) {
        Trace.end(thisJoinPoint, result);
    }
 
    /**
     * Trace the end of a method, constructor or initialization code.
     */
    @SuppressAjWarnings({"adviceDidNotMatch"})
    after() returning : applicationCode() && 
            (constructors() || voidMethods() || staticinitialization(*..*)) {
        Trace.end(thisJoinPoint);
    }

    /**
     * Trace a thrown exception.
     * 
     * @param t the thrown exception
     */
    @SuppressAjWarnings({"adviceDidNotMatch"})
    after() throwing(Throwable t) : applicationCode() && allMethods() {
        Trace.throwing(thisJoinPoint, t);
    }
    
    /**
     * Trace the setting of an attribute.
     */
    @SuppressAjWarnings({"adviceDidNotMatch"})
    after() : applicationCode() && setFields() {
        Trace.trace(thisJoinPoint);
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy