class com.oracle.mxtool.junit.TimingDecorator extends com.oracle.mxtool.junit.MxRunListenerDecorator
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: com.oracle.mxtool.junit.TimingDecorator
  super_class: com.oracle.mxtool.junit.MxRunListenerDecorator
{
  private long startTime;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private long classStartTime;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private org.junit.runner.Description currentTest;
    descriptor: Lorg/junit/runner/Description;
    flags: (0x0002) ACC_PRIVATE

  final java.util.Map<java.lang.Class<?>, java.lang.Long> classTimes;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/Class<*>;Ljava/lang/Long;>;

  final java.util.Map<org.junit.runner.Description, java.lang.Long> testTimes;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Lorg/junit/runner/Description;Ljava/lang/Long;>;

  void <init>(com.oracle.mxtool.junit.MxRunListener);
    descriptor: (Lcom/oracle/mxtool/junit/MxRunListener;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.oracle.mxtool.junit.TimingDecorator this
        start local 1 // com.oracle.mxtool.junit.MxRunListener l
         0: .line 44
            aload 0 /* this */
            aload 1 /* l */
            invokespecial com.oracle.mxtool.junit.MxRunListenerDecorator.<init>:(Lcom/oracle/mxtool/junit/MxRunListener;)V
         1: .line 45
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield com.oracle.mxtool.junit.TimingDecorator.classTimes:Ljava/util/Map;
         2: .line 46
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield com.oracle.mxtool.junit.TimingDecorator.testTimes:Ljava/util/Map;
         3: .line 47
            return
        end local 1 // com.oracle.mxtool.junit.MxRunListener l
        end local 0 // com.oracle.mxtool.junit.TimingDecorator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lcom/oracle/mxtool/junit/TimingDecorator;
            0    4     1     l  Lcom/oracle/mxtool/junit/MxRunListener;
    MethodParameters:
      Name  Flags
      l     

  public void testClassStarted(java.lang.Class<?>);
    descriptor: (Ljava/lang/Class;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.oracle.mxtool.junit.TimingDecorator this
        start local 1 // java.lang.Class clazz
         0: .line 51
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield com.oracle.mxtool.junit.TimingDecorator.classStartTime:J
         1: .line 52
            aload 0 /* this */
            aload 1 /* clazz */
            invokespecial com.oracle.mxtool.junit.MxRunListenerDecorator.testClassStarted:(Ljava/lang/Class;)V
         2: .line 53
            return
        end local 1 // java.lang.Class clazz
        end local 0 // com.oracle.mxtool.junit.TimingDecorator this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    3     0   this  Lcom/oracle/mxtool/junit/TimingDecorator;
            0    3     1  clazz  Ljava/lang/Class<*>;
    Signature: (Ljava/lang/Class<*>;)V
    MethodParameters:
       Name  Flags
      clazz  

  public void testClassFinished(java.lang.Class<?>, int, );
    descriptor: (Ljava/lang/Class;II)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=6, args_size=4
        start local 0 // com.oracle.mxtool.junit.TimingDecorator this
        start local 1 // java.lang.Class clazz
        start local 2 // int numPassed
        start local 3 // int numFailed
         0: .line 57
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield com.oracle.mxtool.junit.TimingDecorator.classStartTime:J
            lsub
            lstore 4 /* totalTime */
        start local 4 // long totalTime
         1: .line 58
            aload 0 /* this */
            aload 1 /* clazz */
            iload 2 /* numPassed */
            iload 3 /* numFailed */
            invokespecial com.oracle.mxtool.junit.MxRunListenerDecorator.testClassFinished:(Ljava/lang/Class;II)V
         2: .line 59
            aload 0 /* this */
            invokevirtual com.oracle.mxtool.junit.TimingDecorator.beVerbose:()Z
            ifeq 4
         3: .line 60
            aload 0 /* this */
            invokevirtual com.oracle.mxtool.junit.TimingDecorator.getWriter:()Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            bipush 32
            invokestatic java.lang.String.valueOf:(C)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            lload 4 /* totalTime */
            invokestatic com.oracle.mxtool.junit.TimingDecorator.valueToString:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         4: .line 62
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield com.oracle.mxtool.junit.TimingDecorator.classTimes:Ljava/util/Map;
            aload 1 /* clazz */
            lload 4 /* totalTime */
            ldc 1000000
            ldiv
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 63
            return
        end local 4 // long totalTime
        end local 3 // int numFailed
        end local 2 // int numPassed
        end local 1 // java.lang.Class clazz
        end local 0 // com.oracle.mxtool.junit.TimingDecorator this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    6     0       this  Lcom/oracle/mxtool/junit/TimingDecorator;
            0    6     1      clazz  Ljava/lang/Class<*>;
            0    6     2  numPassed  I
            0    6     3  numFailed  I
            1    6     4  totalTime  J
    Signature: (Ljava/lang/Class<*>;II)V
    MethodParameters:
           Name  Flags
      clazz      
      numPassed  
      numFailed  

  public void testStarted(org.junit.runner.Description);
    descriptor: (Lorg/junit/runner/Description;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.oracle.mxtool.junit.TimingDecorator this
        start local 1 // org.junit.runner.Description description
         0: .line 67
            aload 0 /* this */
            aload 1 /* description */
            putfield com.oracle.mxtool.junit.TimingDecorator.currentTest:Lorg/junit/runner/Description;
         1: .line 68
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield com.oracle.mxtool.junit.TimingDecorator.startTime:J
         2: .line 69
            aload 0 /* this */
            aload 1 /* description */
            invokespecial com.oracle.mxtool.junit.MxRunListenerDecorator.testStarted:(Lorg/junit/runner/Description;)V
         3: .line 70
            return
        end local 1 // org.junit.runner.Description description
        end local 0 // com.oracle.mxtool.junit.TimingDecorator this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    4     0         this  Lcom/oracle/mxtool/junit/TimingDecorator;
            0    4     1  description  Lorg/junit/runner/Description;
    MethodParameters:
             Name  Flags
      description  

  public void testFinished(org.junit.runner.Description);
    descriptor: (Lorg/junit/runner/Description;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=4, args_size=2
        start local 0 // com.oracle.mxtool.junit.TimingDecorator this
        start local 1 // org.junit.runner.Description description
         0: .line 74
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield com.oracle.mxtool.junit.TimingDecorator.startTime:J
            lsub
            lstore 2 /* totalTime */
        start local 2 // long totalTime
         1: .line 75
            aload 0 /* this */
            aload 1 /* description */
            invokespecial com.oracle.mxtool.junit.MxRunListenerDecorator.testFinished:(Lorg/junit/runner/Description;)V
         2: .line 76
            aload 0 /* this */
            invokevirtual com.oracle.mxtool.junit.TimingDecorator.beVerbose:()Z
            ifeq 4
         3: .line 77
            aload 0 /* this */
            invokevirtual com.oracle.mxtool.junit.TimingDecorator.getWriter:()Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc " "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            lload 2 /* totalTime */
            invokestatic com.oracle.mxtool.junit.TimingDecorator.valueToString:(J)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.print:(Ljava/lang/String;)V
         4: .line 79
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield com.oracle.mxtool.junit.TimingDecorator.currentTest:Lorg/junit/runner/Description;
         5: .line 80
            aload 0 /* this */
            getfield com.oracle.mxtool.junit.TimingDecorator.testTimes:Ljava/util/Map;
            aload 1 /* description */
            lload 2 /* totalTime */
            ldc 1000000
            ldiv
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 81
            return
        end local 2 // long totalTime
        end local 1 // org.junit.runner.Description description
        end local 0 // com.oracle.mxtool.junit.TimingDecorator this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    7     0         this  Lcom/oracle/mxtool/junit/TimingDecorator;
            0    7     1  description  Lorg/junit/runner/Description;
            1    7     2    totalTime  J
    MethodParameters:
             Name  Flags
      description  

  private static java.lang.String valueToString(long);
    descriptor: (J)Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=6, args_size=1
        start local 0 // long valueNS
         0: .line 84
            lload 0 /* valueNS */
            ldc 1000000
            ldiv
            lstore 2 /* timeWholeMS */
        start local 2 // long timeWholeMS
         1: .line 85
            lload 0 /* valueNS */
            ldc 100000
            ldiv
            ldc 10
            lrem
            lstore 4 /* timeFractionMS */
        start local 4 // long timeFractionMS
         2: .line 86
            ldc "%d.%d ms"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            lload 2 /* timeWholeMS */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            lload 4 /* timeFractionMS */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            areturn
        end local 4 // long timeFractionMS
        end local 2 // long timeWholeMS
        end local 0 // long valueNS
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    3     0         valueNS  J
            1    3     2     timeWholeMS  J
            2    3     4  timeFractionMS  J
    MethodParameters:
         Name  Flags
      valueNS  

  public java.lang.Object[] getCurrentTestDuration();
    descriptor: ()[Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // com.oracle.mxtool.junit.TimingDecorator this
         0: .line 96
            aload 0 /* this */
            getfield com.oracle.mxtool.junit.TimingDecorator.currentTest:Lorg/junit/runner/Description;
            astore 1 /* current */
        start local 1 // org.junit.runner.Description current
         1: .line 97
            aload 1 /* current */
            ifnull 4
         2: .line 98
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield com.oracle.mxtool.junit.TimingDecorator.startTime:J
            lsub
            ldc 1000000
            ldiv
            lstore 2 /* timeMS */
        start local 2 // long timeMS
         3: .line 99
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* current */
            aastore
            dup
            iconst_1
            lload 2 /* timeMS */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            areturn
        end local 2 // long timeMS
         4: .line 101
      StackMap locals: org.junit.runner.Description
      StackMap stack:
            aconst_null
            areturn
        end local 1 // org.junit.runner.Description current
        end local 0 // com.oracle.mxtool.junit.TimingDecorator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0     this  Lcom/oracle/mxtool/junit/TimingDecorator;
            1    5     1  current  Lorg/junit/runner/Description;
            3    4     2   timeMS  J
}
SourceFile: "TimingDecorator.java"