public final class org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest extends org.graalvm.compiler.truffle.test.TestWithPolyglotOptions
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  super_class: org.graalvm.compiler.truffle.test.TestWithPolyglotOptions
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 53
            aload 0 /* this */
            invokespecial org.graalvm.compiler.truffle.test.TestWithPolyglotOptions.<init>:()V
            return
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;

  public void testCompilationSuccess();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 57
            aload 0 /* this */
            iconst_4
            anewarray java.lang.String
            dup
            iconst_0
            ldc "engine.CompileImmediately"
            aastore
            dup
            iconst_1
            ldc "true"
            aastore
            dup
            iconst_2
            ldc "engine.BackgroundCompilation"
            aastore
            dup
            iconst_3
            ldc "false"
            aastore
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.setupContext:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context;
            pop
         1: .line 58
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 1 /* runtime */
        start local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         2: .line 59
            aload 1 /* runtime */
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokestatic com.oracle.truffle.api.nodes.RootNode.createConstantNode:(Ljava/lang/Object;)Lcom/oracle/truffle/api/nodes/RootNode;
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.createCallTarget:(Lcom/oracle/truffle/api/nodes/RootNode;)Lcom/oracle/truffle/api/RootCallTarget;
            checkcast org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
            astore 2 /* compilable */
        start local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
         3: .line 60
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
            dup
            aload 2 /* compilable */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.<init>:(Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)V
            astore 3 /* listener */
        start local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
         4: .line 62
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
         5: .line 63
            aload 2 /* compilable */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.call:([Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 64
            aload 3 /* listener */
            iconst_5
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType
            dup
            iconst_0
         7: .line 65
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_1
         8: .line 66
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_2
         9: .line 67
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_3
        10: .line 68
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_4
        11: .line 69
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
        12: .line 64
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.assertEvents:([Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;)V
        13: .line 70
            goto 17
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: java.lang.Throwable
        14: astore 4
        15: .line 71
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        16: .line 72
            aload 4
            athrow
        17: .line 71
      StackMap locals:
      StackMap stack:
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        18: .line 73
            return
        end local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        end local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        end local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   19     0        this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;
            2   19     1     runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            3   19     2  compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            4   19     3    listener  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$TestListener;
      Exception table:
        from    to  target  type
           4    14      14  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  public void testCompilationFailure();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 77
            aload 0 /* this */
            iconst_4
            anewarray java.lang.String
            dup
            iconst_0
            ldc "engine.CompileImmediately"
            aastore
            dup
            iconst_1
            ldc "true"
            aastore
            dup
            iconst_2
            ldc "engine.BackgroundCompilation"
            aastore
            dup
            iconst_3
            ldc "false"
            aastore
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.setupContext:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context;
            pop
         1: .line 78
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 1 /* runtime */
        start local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         2: .line 79
            aload 1 /* runtime */
            invokestatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.createFailureNode:()Lcom/oracle/truffle/api/nodes/RootNode;
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.createCallTarget:(Lcom/oracle/truffle/api/nodes/RootNode;)Lcom/oracle/truffle/api/RootCallTarget;
            checkcast org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
            astore 2 /* compilable */
        start local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
         3: .line 80
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
            dup
            aload 2 /* compilable */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.<init>:(Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)V
            astore 3 /* listener */
        start local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
         4: .line 82
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
         5: .line 83
            aload 2 /* compilable */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.call:([Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 84
            aload 3 /* listener */
            iconst_3
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType
            dup
            iconst_0
         7: .line 85
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_1
         8: .line 86
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_2
         9: .line 87
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_FAILURE:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
        10: .line 84
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.assertEvents:([Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;)V
        11: .line 88
            goto 15
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: java.lang.Throwable
        12: astore 4
        13: .line 89
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        14: .line 90
            aload 4
            athrow
        15: .line 89
      StackMap locals:
      StackMap stack:
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        16: .line 91
            return
        end local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        end local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        end local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   17     0        this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;
            2   17     1     runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            3   17     2  compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            4   17     3    listener  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$TestListener;
      Exception table:
        from    to  target  type
           4    12      12  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  public void testCompilationFailureRetry();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 95
            aload 0 /* this */
            iconst_0
            anewarray java.lang.String
            invokestatic org.graalvm.polyglot.Context.newBuilder:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context$Builder;
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$1
            dup
            aload 0 /* this */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$1.<init>:(Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;)V
            invokevirtual org.graalvm.polyglot.Context$Builder.logHandler:(Ljava/io/OutputStream;)Lorg/graalvm/polyglot/Context$Builder;
         1: .line 99
            iconst_1
            invokevirtual org.graalvm.polyglot.Context$Builder.allowExperimentalOptions:(Z)Lorg/graalvm/polyglot/Context$Builder;
            ldc "engine.CompileImmediately"
            ldc "true"
            invokevirtual org.graalvm.polyglot.Context$Builder.option:(Ljava/lang/String;Ljava/lang/String;)Lorg/graalvm/polyglot/Context$Builder;
            ldc "engine.BackgroundCompilation"
            ldc "false"
            invokevirtual org.graalvm.polyglot.Context$Builder.option:(Ljava/lang/String;Ljava/lang/String;)Lorg/graalvm/polyglot/Context$Builder;
            ldc "engine.CompilationFailureAction"
            ldc "Diagnose"
            invokevirtual org.graalvm.polyglot.Context$Builder.option:(Ljava/lang/String;Ljava/lang/String;)Lorg/graalvm/polyglot/Context$Builder;
         2: .line 95
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.setupContext:(Lorg/graalvm/polyglot/Context$Builder;)Lorg/graalvm/polyglot/Context;
            pop
         3: .line 100
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 1 /* runtime */
        start local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         4: .line 101
            aload 1 /* runtime */
            invokestatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.createFailureNode:()Lcom/oracle/truffle/api/nodes/RootNode;
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.createCallTarget:(Lcom/oracle/truffle/api/nodes/RootNode;)Lcom/oracle/truffle/api/RootCallTarget;
            checkcast org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
            astore 2 /* compilable */
        start local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
         5: .line 102
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
            dup
            aload 2 /* compilable */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.<init>:(Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)V
            astore 3 /* listener */
        start local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
         6: .line 104
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
         7: .line 105
            aload 2 /* compilable */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.call:([Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 106
            aload 3 /* listener */
            bipush 6
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType
            dup
            iconst_0
         9: .line 107
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_1
        10: .line 108
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_2
        11: .line 109
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_FAILURE:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_3
        12: .line 110
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_4
        13: .line 111
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_5
        14: .line 112
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_FAILURE:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
        15: .line 106
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.assertEvents:([Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;)V
        16: .line 113
            goto 20
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: java.lang.Throwable
        17: astore 4
        18: .line 114
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        19: .line 115
            aload 4
            athrow
        20: .line 114
      StackMap locals:
      StackMap stack:
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        21: .line 116
            return
        end local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        end local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        end local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   22     0        this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;
            4   22     1     runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            5   22     2  compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            6   22     3    listener  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$TestListener;
      Exception table:
        from    to  target  type
           6    17      17  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  public void testBlockCompilation();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 120
            aload 0 /* this */
            bipush 6
            anewarray java.lang.String
            dup
            iconst_0
            ldc "engine.CompileImmediately"
            aastore
            dup
            iconst_1
            ldc "true"
            aastore
            dup
            iconst_2
         1: .line 121
            ldc "engine.BackgroundCompilation"
            aastore
            dup
            iconst_3
            ldc "false"
            aastore
            dup
            iconst_4
         2: .line 122
            ldc "engine.PartialBlockCompilationSize"
            aastore
            dup
            iconst_5
            ldc "1"
            aastore
         3: .line 120
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.setupContext:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context;
            pop
         4: .line 123
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 1 /* runtime */
        start local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         5: .line 124
            aload 1 /* runtime */
            invokestatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.createBlocks:()Lcom/oracle/truffle/api/nodes/RootNode;
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.createCallTarget:(Lcom/oracle/truffle/api/nodes/RootNode;)Lcom/oracle/truffle/api/RootCallTarget;
            checkcast org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
            astore 2 /* compilable */
        start local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
         6: .line 125
            aload 2 /* compilable */
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.computeBlockCompilations:()Z
            pop
         7: .line 126
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
            dup
            aload 2 /* compilable */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.<init>:(Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)V
            astore 3 /* listener */
        start local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
         8: .line 128
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
         9: .line 129
            aload 2 /* compilable */
            aload 2 /* compilable */
            getfield org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.engine:Lorg/graalvm/compiler/truffle/runtime/EngineData;
            getfield org.graalvm.compiler.truffle.runtime.EngineData.multiTier:Z
            ifeq 10
            iconst_0
            goto 11
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
        10: iconst_1
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: org.graalvm.compiler.truffle.runtime.OptimizedCallTarget int
        11: invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.compile:(Z)Z
            pop
        12: .line 130
            aload 3 /* listener */
            bipush 15
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType
            dup
            iconst_0
        13: .line 132
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_1
        14: .line 134
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_2
        15: .line 135
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_3
        16: .line 136
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_4
        17: .line 137
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_5
        18: .line 138
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 6
        19: .line 140
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 7
        20: .line 141
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 8
        21: .line 142
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 9
        22: .line 143
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 10
        23: .line 144
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 11
        24: .line 146
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 12
        25: .line 147
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 13
        26: .line 148
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 14
        27: .line 149
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
        28: .line 130
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.assertEvents:([Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;)V
        29: .line 150
            goto 33
      StackMap locals:
      StackMap stack: java.lang.Throwable
        30: astore 4
        31: .line 151
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        32: .line 152
            aload 4
            athrow
        33: .line 151
      StackMap locals:
      StackMap stack:
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        34: .line 153
            return
        end local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        end local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        end local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   35     0        this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;
            5   35     1     runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            6   35     2  compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            8   35     3    listener  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$TestListener;
      Exception table:
        from    to  target  type
           8    30      30  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  public void testBlockCompilationLargeBlocks();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 157
            aload 0 /* this */
            bipush 8
            anewarray java.lang.String
            dup
            iconst_0
            ldc "engine.CompileImmediately"
            aastore
            dup
            iconst_1
            ldc "true"
            aastore
            dup
            iconst_2
         1: .line 158
            ldc "engine.BackgroundCompilation"
            aastore
            dup
            iconst_3
            ldc "false"
            aastore
            dup
            iconst_4
         2: .line 159
            ldc "engine.PartialBlockCompilationSize"
            aastore
            dup
            iconst_5
            ldc "1"
            aastore
            dup
            bipush 6
         3: .line 160
            ldc "engine.PartialBlockMaximumSize"
            aastore
            dup
            bipush 7
            ldc "0"
            aastore
         4: .line 157
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.setupContext:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context;
            pop
         5: .line 161
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 1 /* runtime */
        start local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         6: .line 162
            aload 1 /* runtime */
            invokestatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.createBlocks:()Lcom/oracle/truffle/api/nodes/RootNode;
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.createCallTarget:(Lcom/oracle/truffle/api/nodes/RootNode;)Lcom/oracle/truffle/api/RootCallTarget;
            checkcast org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
            astore 2 /* compilable */
        start local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
         7: .line 163
            aload 2 /* compilable */
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.computeBlockCompilations:()Z
            pop
         8: .line 164
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
            dup
            aload 2 /* compilable */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.<init>:(Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)V
            astore 3 /* listener */
        start local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
         9: .line 166
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        10: .line 167
            aload 2 /* compilable */
            aload 2 /* compilable */
            getfield org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.engine:Lorg/graalvm/compiler/truffle/runtime/EngineData;
            getfield org.graalvm.compiler.truffle.runtime.EngineData.multiTier:Z
            ifeq 11
            iconst_0
            goto 12
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
        11: iconst_1
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: org.graalvm.compiler.truffle.runtime.OptimizedCallTarget int
        12: invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.compile:(Z)Z
            pop
        13: .line 168
            aload 3 /* listener */
            bipush 9
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType
            dup
            iconst_0
        14: .line 170
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_1
        15: .line 172
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_2
        16: .line 173
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.DEQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_3
        17: .line 175
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_4
        18: .line 176
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.DEQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            iconst_5
        19: .line 178
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 6
        20: .line 179
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 7
        21: .line 180
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
            dup
            bipush 8
        22: .line 181
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            aastore
        23: .line 168
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.assertEvents:([Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;)V
        24: .line 182
            goto 28
      StackMap locals:
      StackMap stack: java.lang.Throwable
        25: astore 4
        26: .line 183
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        27: .line 184
            aload 4
            athrow
        28: .line 183
      StackMap locals:
      StackMap stack:
            aload 1 /* runtime */
            aload 3 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        29: .line 185
            return
        end local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        end local 2 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        end local 1 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   30     0        this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;
            6   30     1     runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            7   30     2  compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            9   30     3    listener  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$TestListener;
      Exception table:
        from    to  target  type
           9    25      25  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  public void testBlockCompilationMaximumGraalNodeCount();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=11, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
         0: .line 189
            bipush 100
            istore 1 /* blockSize */
        start local 1 // int blockSize
         1: .line 190
            sipush 1000
            istore 2 /* nodeCount */
        start local 2 // int nodeCount
         2: .line 191
            aload 0 /* this */
            bipush 8
            anewarray java.lang.String
            dup
            iconst_0
            ldc "engine.CompileImmediately"
            aastore
            dup
            iconst_1
            ldc "true"
            aastore
            dup
            iconst_2
         3: .line 192
            ldc "engine.BackgroundCompilation"
            aastore
            dup
            iconst_3
            ldc "false"
            aastore
            dup
            iconst_4
         4: .line 193
            ldc "engine.PartialBlockCompilationSize"
            aastore
            dup
            iconst_5
            iload 1 /* blockSize */
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            aastore
            dup
            bipush 6
         5: .line 194
            ldc "engine.MaximumGraalNodeCount"
            aastore
            dup
            bipush 7
            ldc "20000"
            aastore
         6: .line 191
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.setupContext:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context;
            pop
         7: .line 195
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 3 /* runtime */
        start local 3 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         8: .line 196
            iload 2 /* nodeCount */
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode
            astore 4 /* children */
        start local 4 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] children
         9: .line 197
            iconst_0
            istore 5 /* i */
        start local 5 // int i
        10: goto 13
        11: .line 198
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest int int org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] int
      StackMap stack:
            aload 4 /* children */
            iload 5 /* i */
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$ExpensiveTestNode
            dup
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$ExpensiveTestNode.<init>:()V
            aastore
        12: .line 197
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 5 /* i */
            aload 4 /* children */
            arraylength
            if_icmplt 11
        end local 5 // int i
        14: .line 200
            aload 4 /* children */
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor
            dup
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor.<init>:()V
            invokestatic com.oracle.truffle.api.nodes.BlockNode.create:([Lcom/oracle/truffle/api/nodes/Node;Lcom/oracle/truffle/api/nodes/BlockNode$ElementExecutor;)Lcom/oracle/truffle/api/nodes/BlockNode;
            astore 5 /* block */
        start local 5 // com.oracle.truffle.api.nodes.BlockNode block
        15: .line 201
            aload 3 /* runtime */
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestRootNode
            dup
            aload 5 /* block */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestRootNode.<init>:(Lcom/oracle/truffle/api/nodes/BlockNode;)V
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.createCallTarget:(Lcom/oracle/truffle/api/nodes/RootNode;)Lcom/oracle/truffle/api/RootCallTarget;
            checkcast org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
            astore 6 /* compilable */
        start local 6 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        16: .line 202
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
            dup
            aload 6 /* compilable */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.<init>:(Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)V
            astore 7 /* listener */
        start local 7 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        17: .line 204
            aload 3 /* runtime */
            aload 7 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        18: .line 205
            aload 6 /* compilable */
            aload 6 /* compilable */
            getfield org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.engine:Lorg/graalvm/compiler/truffle/runtime/EngineData;
            getfield org.graalvm.compiler.truffle.runtime.EngineData.multiTier:Z
            ifeq 19
            iconst_0
            goto 20
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest int int org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] com.oracle.truffle.api.nodes.BlockNode org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: org.graalvm.compiler.truffle.runtime.OptimizedCallTarget
        19: iconst_1
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest int int org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] com.oracle.truffle.api.nodes.BlockNode org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: org.graalvm.compiler.truffle.runtime.OptimizedCallTarget int
        20: invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.compile:(Z)Z
            pop
        21: .line 206
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 8 /* expectedEvents */
        start local 8 // java.util.List expectedEvents
        22: .line 208
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        23: .line 209
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        24: .line 210
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_FAILURE:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        25: .line 211
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.DEQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        26: .line 213
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        27: .line 215
            iconst_0
            istore 9 /* i */
        start local 9 // int i
        28: goto 35
        29: .line 216
      StackMap locals: java.util.List int
      StackMap stack:
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.ENQUEUED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        30: .line 217
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        31: .line 218
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        32: .line 219
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        33: .line 220
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        34: .line 215
            iinc 9 /* i */ 1
      StackMap locals:
      StackMap stack:
        35: iload 9 /* i */
            iload 2 /* nodeCount */
            iload 1 /* blockSize */
            idiv
            if_icmplt 29
        end local 9 // int i
        36: .line 223
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_STARTED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        37: .line 224
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.TRUFFLE_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        38: .line 225
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.GRAAL_TIER_FINISHED:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        39: .line 226
            aload 8 /* expectedEvents */
            getstatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType.COMPILATION_SUCCESS:Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        40: .line 227
            aload 7 /* listener */
            aload 8 /* expectedEvents */
            aload 8 /* expectedEvents */
            invokeinterface java.util.List.size:()I
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType
            invokeinterface java.util.List.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType[]
            invokevirtual org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener.assertEvents:([Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;)V
        end local 8 // java.util.List expectedEvents
        41: .line 228
            goto 45
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest int int org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] com.oracle.truffle.api.nodes.BlockNode org.graalvm.compiler.truffle.runtime.OptimizedCallTarget org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener
      StackMap stack: java.lang.Throwable
        42: astore 10
        43: .line 229
            aload 3 /* runtime */
            aload 7 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        44: .line 230
            aload 10
            athrow
        45: .line 229
      StackMap locals:
      StackMap stack:
            aload 3 /* runtime */
            aload 7 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        46: .line 231
            return
        end local 7 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener listener
        end local 6 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        end local 5 // com.oracle.truffle.api.nodes.BlockNode block
        end local 4 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] children
        end local 3 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        end local 2 // int nodeCount
        end local 1 // int blockSize
        end local 0 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   47     0            this  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest;
            1   47     1       blockSize  I
            2   47     2       nodeCount  I
            8   47     3         runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            9   47     4        children  [Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$AbstractTestNode;
           10   14     5               i  I
           15   47     5           block  Lcom/oracle/truffle/api/nodes/BlockNode<Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$AbstractTestNode;>;
           16   47     6      compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
           17   47     7        listener  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$TestListener;
           22   41     8  expectedEvents  Ljava/util/List<Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$EventType;>;
           28   36     9               i  I
      Exception table:
        from    to  target  type
          17    42      42  any
    RuntimeVisibleAnnotations: 
      org.junit.Test()

  private static com.oracle.truffle.api.nodes.RootNode createFailureNode();
    descriptor: ()Lcom/oracle/truffle/api/nodes/RootNode;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=1, args_size=0
         0: .line 234
            new org.graalvm.compiler.truffle.test.CompilerAssertsTest$NeverPartOfCompilationTestNode
            dup
            invokespecial org.graalvm.compiler.truffle.test.CompilerAssertsTest$NeverPartOfCompilationTestNode.<init>:()V
            astore 0 /* result */
        start local 0 // org.graalvm.compiler.truffle.test.CompilerAssertsTest$NeverPartOfCompilationTestNode result
         1: .line 235
            new org.graalvm.compiler.truffle.test.nodes.RootTestNode
            dup
            new com.oracle.truffle.api.frame.FrameDescriptor
            dup
            invokespecial com.oracle.truffle.api.frame.FrameDescriptor.<init>:()V
            ldc "neverPartOfCompilation"
            aload 0 /* result */
            invokespecial org.graalvm.compiler.truffle.test.nodes.RootTestNode.<init>:(Lcom/oracle/truffle/api/frame/FrameDescriptor;Ljava/lang/String;Lorg/graalvm/compiler/truffle/test/nodes/AbstractTestNode;)V
            areturn
        end local 0 // org.graalvm.compiler.truffle.test.CompilerAssertsTest$NeverPartOfCompilationTestNode result
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            1    2     0  result  Lorg/graalvm/compiler/truffle/test/CompilerAssertsTest$NeverPartOfCompilationTestNode;

  private static com.oracle.truffle.api.nodes.RootNode createBlocks();
    descriptor: ()Lcom/oracle/truffle/api/nodes/RootNode;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 239
            iconst_1
            iconst_2
            invokestatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.createBlocks:(II)Lcom/oracle/truffle/api/nodes/BlockNode;
            astore 0 /* block */
        start local 0 // com.oracle.truffle.api.nodes.BlockNode block
         1: .line 240
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestRootNode
            dup
            aload 0 /* block */
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestRootNode.<init>:(Lcom/oracle/truffle/api/nodes/BlockNode;)V
            areturn
        end local 0 // com.oracle.truffle.api.nodes.BlockNode block
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1    2     0  block  Lcom/oracle/truffle/api/nodes/BlockNode<Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$AbstractTestNode;>;

  private static com.oracle.truffle.api.nodes.BlockNode<org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode> createBlocks(int, int);
    descriptor: (II)Lcom/oracle/truffle/api/nodes/BlockNode;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=2
        start local 0 // int depth
        start local 1 // int blockSize
         0: .line 244
            iload 0 /* depth */
            ifne 2
         1: .line 245
            aconst_null
            areturn
         2: .line 247
      StackMap locals:
      StackMap stack:
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor
            dup
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor.<init>:()V
            astore 2 /* nodeExecutor */
        start local 2 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor nodeExecutor
         3: .line 248
            iload 1 /* blockSize */
            anewarray org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode
            astore 3 /* children */
        start local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] children
         4: .line 249
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         5: goto 8
         6: .line 250
      StackMap locals: org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] int
      StackMap stack:
            aload 3 /* children */
            iload 4 /* i */
            new org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NestedTestNode
            dup
            iload 0 /* depth */
            iconst_1
            isub
            iload 1 /* blockSize */
            invokestatic org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest.createBlocks:(II)Lcom/oracle/truffle/api/nodes/BlockNode;
            invokespecial org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NestedTestNode.<init>:(Lcom/oracle/truffle/api/nodes/BlockNode;)V
            aastore
         7: .line 249
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 4 /* i */
            aload 3 /* children */
            arraylength
            if_icmplt 6
        end local 4 // int i
         9: .line 252
            aload 3 /* children */
            aload 2 /* nodeExecutor */
            invokestatic com.oracle.truffle.api.nodes.BlockNode.create:([Lcom/oracle/truffle/api/nodes/Node;Lcom/oracle/truffle/api/nodes/BlockNode$ElementExecutor;)Lcom/oracle/truffle/api/nodes/BlockNode;
            areturn
        end local 3 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode[] children
        end local 2 // org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor nodeExecutor
        end local 1 // int blockSize
        end local 0 // int depth
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   10     0         depth  I
            0   10     1     blockSize  I
            3   10     2  nodeExecutor  Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$NodeExecutor;
            4   10     3      children  [Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$AbstractTestNode;
            5    9     4             i  I
    Signature: (II)Lcom/oracle/truffle/api/nodes/BlockNode<Lorg/graalvm/compiler/truffle/test/GraalTruffleRuntimeListenerTest$AbstractTestNode;>;
    MethodParameters:
           Name  Flags
      depth      
      blockSize  

  private static java.util.List<org.graalvm.compiler.truffle.runtime.OptimizedCallTarget> getBlocks(org.graalvm.compiler.truffle.runtime.OptimizedCallTarget);
    descriptor: (Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget callTarget
         0: .line 258
            ldc Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            ldc "blockCompilations"
            invokevirtual java.lang.Class.getDeclaredField:(Ljava/lang/String;)Ljava/lang/reflect/Field;
            astore 1 /* blockCompilations */
        start local 1 // java.lang.reflect.Field blockCompilations
         1: .line 259
            aload 1 /* blockCompilations */
            iconst_1
            invokevirtual java.lang.reflect.Field.setAccessible:(Z)V
         2: .line 260
            aload 1 /* blockCompilations */
            aload 0 /* callTarget */
            invokevirtual java.lang.reflect.Field.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
         3: areturn
        end local 1 // java.lang.reflect.Field blockCompilations
         4: .line 261
      StackMap locals:
      StackMap stack: java.lang.ReflectiveOperationException
            astore 1 /* e */
        start local 1 // java.lang.ReflectiveOperationException e
         5: .line 262
            new java.lang.AssertionError
            dup
            ldc "Failed to read blockCompilations"
            aload 1 /* e */
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.ReflectiveOperationException e
        end local 0 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget callTarget
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    6     0         callTarget  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            1    4     1  blockCompilations  Ljava/lang/reflect/Field;
            5    6     1                  e  Ljava/lang/ReflectiveOperationException;
      Exception table:
        from    to  target  type
           0     3       4  Class java.lang.ReflectiveOperationException
    Signature: (Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;)Ljava/util/List<Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;>;
    MethodParameters:
            Name  Flags
      callTarget  
}
SourceFile: "GraalTruffleRuntimeListenerTest.java"
NestMembers:
  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$1  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$ExpensiveTestNode  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NestedTestNode  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestRootNode
InnerClasses:
  public abstract ElementExecutor = com.oracle.truffle.api.nodes.BlockNode$ElementExecutor of com.oracle.truffle.api.nodes.BlockNode
  public NeverPartOfCompilationTestNode = org.graalvm.compiler.truffle.test.CompilerAssertsTest$NeverPartOfCompilationTestNode of org.graalvm.compiler.truffle.test.CompilerAssertsTest
  org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$1
  private abstract AbstractTestNode = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$AbstractTestNode of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  private final EventType = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$EventType of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  private final ExpensiveTestNode = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$ExpensiveTestNode of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  private final NestedTestNode = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NestedTestNode of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  private final NodeExecutor = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$NodeExecutor of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  private final TestListener = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestListener of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  private final TestRootNode = org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest$TestRootNode of org.graalvm.compiler.truffle.test.GraalTruffleRuntimeListenerTest
  public final Builder = org.graalvm.polyglot.Context$Builder of org.graalvm.polyglot.Context