Package measurements.suites

Source Code of measurements.suites.JoinPointMeasurements1_aj

// $Id: JoinPointMeasurements1_aj.java,v 1.3 2008/11/18 10:41:01 anicoara Exp $
// ====================================================

package measurements.suites;

import java.lang.reflect.Field;
import java.lang.reflect.Method;

import junit.framework.Test;
import ch.ethz.inf.util.junit.PerformanceTest;
import ch.ethz.inf.util.junit.PerformanceTestSuite;
import ch.ethz.jvmai.*;

/**
* JoinPoint micro-measurements.
*
* Performance micro-measurements tests for method boundaries,
* fields accesses and modifications, exception handlers:
*
* 1) INVOKEVIRTUAL -> invoke a normal method
* 2) SYNC INVOKEVIRTUAL -> invoke a normal but synchronized method
* 3) INVOKEINTERFACE -> invoke a method through an interface
* 4) INVOKESPECIAL -> invoke a private method
* 5) INVOKESTATIC -> invoke a static method
* 6) GETFIELD -> used when a field has been read
* 7) PUTFIELD -> used when a field has been write
* 8) Exception Catch
* 9) Exception Throw
*
* Each test is executed "RUNS" times.
*
* @author Angela Nicoara
*/
public class JoinPointMeasurements1_aj extends PerformanceTest {

  public boolean useProse = false;
  public boolean checkAssert = true;

  protected JVMAspectInterface aspectInterface;
  protected TestHook hook;

  // INVOKEVIRTUAL
  public void localMethod() { }
  public void localMethodLongO(Object ob1, Object ob2) { }
  public void localMethodLongI(int ob1, int ob2) { }
  public void localMethodLongL(long ob1, long ob2) { }
  public void localMethodLongD(double ob1, double ob2) { }

  // INVOKESPECIAL
  private void privatelocalMethod() { }
  private void privatelocalMethodLongO(Object ob1, Object ob2) { }
  private void privatelocalMethodLongI(int ob1, int ob2) { }
  private void privatelocalMethodLongL(long ob1, long ob2) { }
  private void privatelocalMethodLongD(double ob1, double ob2) { }

  // INVOKEINTERFACE
  protected JoinPointTestInterface obInterface = new JoinPointTestClass();

  // SYNC INVOKEVIRTUAL
  protected JoinPointTestClass obSync = new JoinPointTestClass();

  public int theField = 0;

  // GETFIELD
  // In case of fullcode weaving the field that is accessed or modified has to be in a method
  public void theFieldAccess(int runs) {
    int n = 0;

    startChronometer();
    for (int i = 0; i < RUNS; i++) n = this.theField;
    stopChronometer();
  }

  // PUTFIELD
  // In case of fullcode weaving the field that is accessed or modified has to be in a method
  public void theFieldModification(int runs) {
    startChronometer();
    for (int i = 0; i < RUNS; i++) this.theField = i;
    stopChronometer();
  }

  // INVOKEVIRTUAL
  protected Method method;
  protected Method methodLongO;
  protected Method methodLongI;
  protected Method methodLongL;
  protected Method methodLongD;

  // SYNC INVOKEVIRTUAL
  protected Method syncMethod;
  protected Method syncMethodLongO;
  protected Method syncMethodLongI;
  protected Method syncMethodLongL;
  protected Method syncMethodLongD;

  // INVOKEINTERFACE
  protected Method interfaceMethod;
  protected Method interfaceMethodLongO;
  protected Method interfaceMethodLongI;
  protected Method interfaceMethodLongL;
  protected Method interfaceMethodLongD;

  // INVOKESTATIC
  protected Method staticMethod;
  protected Method staticMethodLongO;
  protected Method staticMethodLongI;
  protected Method staticMethodLongL;
  protected Method staticMethodLongD;

  // INVOKESPECIAL
  protected Method privateMethod;
  protected Method privateMethodLongO;
  protected Method privateMethodLongI;
  protected Method privateMethodLongL;
  protected Method privateMethodLongD;

  protected Field field;

  public class TestException extends Exception {};   
  public TestException exception = new TestException()

  /*
  public static int fieldAccessCount;
  public static int fieldModificationCount;
  public static int methodEntryCount;
  public static int methodExitCount;
  public static int exceptionThrowCount;
    public static int exceptionCatchCount;
   */
  public static int counter;


  public static class TestHook extends JoinPointHook {
    /*
      public void onFieldAccess(FieldAccessJoinPoint joinPoint) { fieldAccessCount++; }
      public void onFieldModification(FieldModificationJoinPoint joinPoint) { fieldModificationCount++; }
      public void onMethodEntry(MethodEntryJoinPoint joinPoint) { methodEntryCount++; }
      public void onMethodExit(MethodExitJoinPoint joinPoint) { methodExitCount++; }
      public void onExceptionThrow(ExceptionJoinPoint joinPoint) { exceptionThrowCount++; }
      public void onExceptionCatch(ExceptionCatchJoinPoint joinPoint) { exceptionCatchCount++; }
      public void onClassLoad(Class cls) {}
     */
    public void onFieldAccess(FieldAccessJoinPoint joinPoint) { counter++; }
    public void onFieldModification(FieldModificationJoinPoint joinPoint) { counter++; }
    public void onMethodEntry(MethodEntryJoinPoint joinPoint) { counter++; }
    public void onMethodExit(MethodExitJoinPoint joinPoint) { counter++; }
    public void onExceptionThrow(ExceptionJoinPoint joinPoint) { counter++; }
    public void onExceptionCatch(ExceptionCatchJoinPoint joinPoint) { counter++; }
    public void onClassLoad(Class cls) {}
    public void onConstructor (ConstructorJoinPoint joinPoint) { }
  }

  public JoinPointMeasurements1_aj(String name) {
    super(name);
    RANGE = new int[] { 100000000 };

    String proseParam = System.getProperty("useprose");
    if (proseParam != null) useProse = true;
  }

  protected void setUp() throws Exception {
    if (useProse) {
      String providerName = System.getProperty("ch.ethz.prose.JVMAIProvider");
      Class providerClass = Class.forName(providerName);
      Provider provider = (Provider) providerClass.newInstance();

      aspectInterface = provider.getAspectInterface();
      aspectInterface.startup(null, true);

      hook = new TestHook();
      aspectInterface.setJoinPointHook(hook);

      // INVOKEVIRTUAL
      method = JoinPointMeasurements1_aj.class.getDeclaredMethod("localMethod", new Class[] {});
      methodLongO = JoinPointMeasurements1_aj.class.getDeclaredMethod("localMethodLongO", new Class[] {Object.class, Object.class});
      methodLongI = JoinPointMeasurements1_aj.class.getDeclaredMethod("localMethodLongI", new Class[] {Integer.TYPE, Integer.TYPE});
      methodLongL = JoinPointMeasurements1_aj.class.getDeclaredMethod("localMethodLongL", new Class[] {Long.TYPE, Long.TYPE});
      methodLongD = JoinPointMeasurements1_aj.class.getDeclaredMethod("localMethodLongD", new Class[] {Double.TYPE, Double.TYPE});

      // SYNC INVOKEVIRTUAL
      syncMethod = JoinPointTestClass.class.getDeclaredMethod("syncMethodShort", new Class[] {});
      syncMethodLongO = JoinPointTestClass.class.getDeclaredMethod("syncMethodLongO", new Class[] {Object.class, Object.class});
      syncMethodLongI = JoinPointTestClass.class.getDeclaredMethod("syncMethodLongI", new Class[] {Integer.TYPE, Integer.TYPE});
      syncMethodLongL = JoinPointTestClass.class.getDeclaredMethod("syncMethodLongL", new Class[] {Long.TYPE, Long.TYPE});
      syncMethodLongD = JoinPointTestClass.class.getDeclaredMethod("syncMethodLongD", new Class[] {Double.TYPE, Double.TYPE});

      // INVOKEINTERFACE
      interfaceMethod = JoinPointTestClass.class.getDeclaredMethod("interfaceMethodShort", new Class[] {});
      interfaceMethodLongO = JoinPointTestClass.class.getDeclaredMethod("interfaceMethodLongO", new Class[] {Object.class, Object.class});
      interfaceMethodLongI = JoinPointTestClass.class.getDeclaredMethod("interfaceMethodLongI", new Class[] {Integer.TYPE, Integer.TYPE});
      interfaceMethodLongL = JoinPointTestClass.class.getDeclaredMethod("interfaceMethodLongL", new Class[] {Long.TYPE, Long.TYPE});
      interfaceMethodLongD = JoinPointTestClass.class.getDeclaredMethod("interfaceMethodLongD", new Class[] {Double.TYPE, Double.TYPE});

      // INVOKESTATIC
      staticMethod = JoinPointTestClass.class.getDeclaredMethod("staticMethodShort", new Class[] {});
      staticMethodLongO = JoinPointTestClass.class.getDeclaredMethod("staticMethodLongO", new Class[] {Object.class, Object.class});
      staticMethodLongI = JoinPointTestClass.class.getDeclaredMethod("staticMethodLongI", new Class[] {Integer.TYPE, Integer.TYPE});
      staticMethodLongL = JoinPointTestClass.class.getDeclaredMethod("staticMethodLongL", new Class[] {Long.TYPE, Long.TYPE});
      staticMethodLongD = JoinPointTestClass.class.getDeclaredMethod("staticMethodLongD", new Class[] {Double.TYPE, Double.TYPE});

      // INVOKESPECIAL
      privateMethod = JoinPointMeasurements1_aj.class.getDeclaredMethod("privatelocalMethod", new Class[] {});
      privateMethodLongO = JoinPointMeasurements1_aj.class.getDeclaredMethod("privatelocalMethodLongO", new Class[] {Object.class, Object.class});
      privateMethodLongI = JoinPointMeasurements1_aj.class.getDeclaredMethod("privatelocalMethodLongI", new Class[] {Integer.TYPE, Integer.TYPE});
      privateMethodLongL = JoinPointMeasurements1_aj.class.getDeclaredMethod("privatelocalMethodLongL", new Class[] {Long.TYPE, Long.TYPE});
      privateMethodLongD = JoinPointMeasurements1_aj.class.getDeclaredMethod("privatelocalMethodLongD", new Class[] {Double.TYPE, Double.TYPE});

      field = JoinPointMeasurements1_aj.class.getDeclaredField("theField");
    }
    /*
      fieldAccessCount = 0;
      fieldModificationCount = 0;
      methodEntryCount = 0;
      methodExitCount = 0;
      exceptionThrowCount = 0;
      exceptionCatchCount = 0;
     */
    counter = 0;
  }

  protected void tearDown() {
    if (useProse) aspectInterface.teardown();
  }

  //=====================================================

  // 1) INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testVirtualMethod_no_jp_NoArg() {
    startChronometer();
    for (int i = 0; i < RUNS; i++) localMethod();
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) SYNC INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testSyncVirtualMethod_no_jp_NoArg() {
    startChronometer();
    for (int i = 0; i < RUNS; i++) obSync.syncMethodShort();
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKEINTERFACE - no call to weaver because the joinpoint isn't activated
  public void testInterfaceMethod_no_jp_NoArg() {
    startChronometer();
    for (int i = 0; i < RUNS; i++) obInterface.interfaceMethodShort();
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESTATIC - no call to weaver because the joinpoint isn't activated
  public void testStaticMethod_no_jp_NoArg() {
    startChronometer();
    for (int i = 0; i < RUNS; i++) JoinPointTestClass.staticMethodShort();
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESPECIAL - no call to weaver because the joinpoint isn't activated
  public void testSpecialMethod_no_jp_NoArg() {
    startChronometer();
    for (int i = 0; i < RUNS; i++) privatelocalMethod();
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) GETFIELD - no call to weaver because the joinpoint isn't activated
  public void testFieldAccess_no_jp_NoArg() {
    this.theFieldAccess(RUNS);

    //  if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) PUTFIELD - no call to weaver because the joinpoint isn't activated
  public void testFieldModification_no_jp_NoArg() {
    this.theFieldModification(RUNS);

    //  if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  public void exceptionThrow() throws TestException {
    throw exception;
  }

  public void exceptionCatch() {
    try {
      exceptionThrow();
    } catch (TestException e) {}
  }   

  //=====================================================
  /*   
    // 1) THROW - no call to weaver because the joinpoint isn't activated
    public void testExceptionThrow_no_jp_NoArg()
    {
      //RUNS = 1000000;
      TestException e = new TestException();

      startChronometer();
      for (int i = 0; i < RUNS; i++) exceptionCatch();
      stopChronometer(); 
    }
   */   
  //=====================================================

  // 1) CATCH - no call to weaver because the joinpoint isn't activated
  public void testExceptionCatch_no_jp_NoArg() {
    //RUNS = 1000000;
    TestException e = new TestException();

    startChronometer();
    for (int i = 0; i < RUNS; i++) exceptionCatch();
    stopChronometer()

    //  if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }


  //=====================================================
  //=====================================================
  //=====================================================
  //=====================================================
  //=====================================================

  // Method arguments: (Object, Object)
  //=====================================================

  // 1) INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testVirtualMethod_LongO() {
    Object obj = new Object();
    startChronometer();
    for (int i = 0; i < RUNS; i++) localMethodLongO(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) SYNC INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testSyncVirtualMethod_LongO() {
    Object obj = new Object();
    startChronometer();
    for (int i = 0; i < RUNS; i++) obSync.syncMethodLongO(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKEINTERFACE - no call to weaver because the joinpoint isn't activated
  public void testInterfaceMethod_LongO() {
    Object obj = new Object();
    startChronometer();
    for (int i = 0; i < RUNS; i++) obInterface.interfaceMethodLongO(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESTATIC - no call to weaver because the joinpoint isn't activated
  public void testStaticMethod_LongO() {
    Object obj = new Object();
    startChronometer();
    for (int i = 0; i < RUNS; i++) JoinPointTestClass.staticMethodLongO(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESPECIAL - no call to weaver because the joinpoint isn't activated
  public void testSpecialMethod_LongO() {
    Object obj = new Object();
    startChronometer();
    for (int i = 0; i < RUNS; i++) privatelocalMethodLongO(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================
  //=====================================================


  // Method arguments: (int, int)
  //=====================================================

  // 1) INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testVirtualMethod_LongI() {
    int obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) localMethodLongI(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) SYNC INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testSyncVirtualMethod_LongI() {
    int obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) obSync.syncMethodLongI(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKEINTERFACE - no call to weaver because the joinpoint isn't activated
  public void testInterfaceMethod_LongI() {
    int obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) obInterface.interfaceMethodLongI(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESTATIC - no call to weaver because the joinpoint isn't activated
  public void testStaticMethod_LongI() {
    int obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) JoinPointTestClass.staticMethodLongI(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESPECIAL - no call to weaver because the joinpoint isn't activated
  public void testSpecialMethod_LongI() {
    int obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) privatelocalMethodLongI(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================
  //=====================================================   


  // Method arguments: (long, long)
  //=====================================================

  // 1) INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testVirtualMethod_LongL() {
    long obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) localMethodLongL(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) SYNC INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testSyncVirtualMethod_LongL() {
    long obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) obSync.syncMethodLongL(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKEINTERFACE - no call to weaver because the joinpoint isn't activated
  public void testInterfaceMethod_LongL() {
    long obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) obInterface.interfaceMethodLongL(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESTATIC - no call to weaver because the joinpoint isn't activated
  public void testStaticMethod_LongL() {
    long obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) JoinPointTestClass.staticMethodLongL(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESPECIAL - no call to weaver because the joinpoint isn't activated
  public void testSpecialMethod_LongL() {
    long obj = 1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) privatelocalMethodLongL(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================
  //=====================================================   


  // Method arguments: (double, double)
  //=====================================================

  // 1) INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testVirtualMethod_LongD() {
    double obj = 10.1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) localMethodLongD(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) SYNC INVOKEVIRTUAL - no call to weaver because the joinpoint isn't activated
  public void testSyncVirtualMethod_LongD() {
    double obj = 10.1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) obSync.syncMethodLongD(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKEINTERFACE - no call to weaver because the joinpoint isn't activated
  public void testInterfaceMethod_LongD() {
    double obj = 10.1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) obInterface.interfaceMethodLongD(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESTATIC - no call to weaver because the joinpoint isn't activated
  public void testStaticMethod_LongD() {
    double obj = 10.1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) JoinPointTestClass.staticMethodLongD(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================

  // 1) INVOKESPECIAL - no call to weaver because the joinpoint isn't activated
  public void testSpecialMethod_LongD() {
    double obj = 10.1;
    startChronometer();
    for (int i = 0; i < RUNS; i++) privatelocalMethodLongD(obj, obj);
    stopChronometer();

    if(checkAssert) assertEquals("Hook notifications", RUNS, counter);
  }

  //=====================================================
  //=====================================================   

  public static Test suite() {
    return new PerformanceTestSuite(JoinPointMeasurements1_aj.class);
  }

}
TOP

Related Classes of measurements.suites.JoinPointMeasurements1_aj

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.