public class org.graalvm.compiler.truffle.test.CompilerLoggingTest extends org.graalvm.compiler.truffle.test.TruffleCompilerImplTest
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.graalvm.compiler.truffle.test.CompilerLoggingTest
  super_class: org.graalvm.compiler.truffle.test.TruffleCompilerImplTest
{
  private static final java.lang.String FORMAT_FAILURE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "Failed to compile %s due to %s"

  private static final java.lang.String FORMAT_SUCCESS;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "Compiled %s"

  private static final java.lang.String MESSAGE_TO_STREAM;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "begin"

  private static final java.lang.String MESSAGE_TO_TTY;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "end"

  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.CompilerLoggingTest this
         0: .line 42
            aload 0 /* this */
            invokespecial org.graalvm.compiler.truffle.test.TruffleCompilerImplTest.<init>:()V
            return
        end local 0 // org.graalvm.compiler.truffle.test.CompilerLoggingTest this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/graalvm/compiler/truffle/test/CompilerLoggingTest;

  public void testLogging();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=10, args_size=1
        start local 0 // org.graalvm.compiler.truffle.test.CompilerLoggingTest this
         0: .line 51
            aconst_null
            astore 1
            aconst_null
            astore 2
         1: new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 3 /* logOut */
        start local 3 // java.io.ByteArrayOutputStream logOut
         2: .line 52
            aload 0 /* this */
            iconst_0
            anewarray java.lang.String
            invokestatic org.graalvm.polyglot.Context.newBuilder:([Ljava/lang/String;)Lorg/graalvm/polyglot/Context$Builder;
            aload 3 /* logOut */
            invokevirtual org.graalvm.polyglot.Context$Builder.logHandler:(Ljava/io/OutputStream;)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.MultiTier"
            ldc "false"
            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;
            invokevirtual org.graalvm.compiler.truffle.test.CompilerLoggingTest.setupContext:(Lorg/graalvm/polyglot/Context$Builder;)V
         3: .line 53
            invokestatic org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.getRuntime:()Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            astore 4 /* runtime */
        start local 4 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
         4: .line 54
            new org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener
            dup
            invokespecial org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener.<init>:()V
            astore 5 /* listener */
        start local 5 // org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener listener
         5: .line 56
            aload 4 /* runtime */
            aload 5 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.addListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
         6: .line 57
            aload 4 /* 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 6 /* compilable */
        start local 6 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
         7: .line 58
            aload 6 /* compilable */
            iconst_0
            anewarray java.lang.Object
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.call:([Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 59
            new java.lang.String
            dup
            aload 3 /* logOut */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            invokespecial java.lang.String.<init>:([B)V
            astore 7 /* logContent */
        start local 7 // java.lang.String logContent
         9: .line 60
            ldc "Compiled %s%s%s%n"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 6 /* compilable */
            invokevirtual org.graalvm.compiler.truffle.runtime.OptimizedCallTarget.getName:()Ljava/lang/String;
            aastore
            dup
            iconst_1
            ldc "begin"
            aastore
            dup
            iconst_2
            ldc "end"
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 8 /* expected */
        start local 8 // java.lang.String expected
        10: .line 61
            new java.lang.StringBuilder
            dup
            ldc "Expected "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* expected */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " in "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* logContent */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 8 /* expected */
            aload 7 /* logContent */
            invokestatic org.junit.Assert.assertEquals:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        end local 8 // java.lang.String expected
        end local 7 // java.lang.String logContent
        end local 6 // org.graalvm.compiler.truffle.runtime.OptimizedCallTarget compilable
        11: .line 62
            goto 15
      StackMap locals: org.graalvm.compiler.truffle.test.CompilerLoggingTest java.lang.Throwable java.lang.Throwable java.io.ByteArrayOutputStream org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener
      StackMap stack: java.lang.Throwable
        12: astore 9
        13: .line 63
            aload 4 /* runtime */
            aload 5 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        14: .line 64
            aload 9
            athrow
        15: .line 63
      StackMap locals:
      StackMap stack:
            aload 4 /* runtime */
            aload 5 /* listener */
            invokevirtual org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime.removeListener:(Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntimeListener;)V
        end local 5 // org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener listener
        end local 4 // org.graalvm.compiler.truffle.runtime.GraalTruffleRuntime runtime
        16: .line 65
            aload 3 /* logOut */
            ifnull 22
            aload 3 /* logOut */
            invokevirtual java.io.ByteArrayOutputStream.close:()V
            goto 22
      StackMap locals: org.graalvm.compiler.truffle.test.CompilerLoggingTest java.lang.Throwable java.lang.Throwable java.io.ByteArrayOutputStream
      StackMap stack: java.lang.Throwable
        17: astore 1
            aload 3 /* logOut */
            ifnull 18
            aload 3 /* logOut */
            invokevirtual java.io.ByteArrayOutputStream.close:()V
        end local 3 // java.io.ByteArrayOutputStream logOut
      StackMap locals:
      StackMap stack:
        18: aload 1
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        19: astore 2
            aload 1
            ifnonnull 20
            aload 2
            astore 1
            goto 21
      StackMap locals:
      StackMap stack:
        20: aload 1
            aload 2
            if_acmpeq 21
            aload 1
            aload 2
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        21: aload 1
            athrow
        22: .line 66
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.graalvm.compiler.truffle.test.CompilerLoggingTest this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   23     0        this  Lorg/graalvm/compiler/truffle/test/CompilerLoggingTest;
            2   18     3      logOut  Ljava/io/ByteArrayOutputStream;
            4   16     4     runtime  Lorg/graalvm/compiler/truffle/runtime/GraalTruffleRuntime;
            5   16     5    listener  Lorg/graalvm/compiler/truffle/test/CompilerLoggingTest$TestListener;
            7   11     6  compilable  Lorg/graalvm/compiler/truffle/runtime/OptimizedCallTarget;
            9   11     7  logContent  Ljava/lang/String;
           10   11     8    expected  Ljava/lang/String;
      Exception table:
        from    to  target  type
           5    12      12  any
           2    16      17  any
           1    19      19  any
    Exceptions:
      throws java.io.IOException
    RuntimeVisibleAnnotations: 
      org.junit.Test()
}
SourceFile: "CompilerLoggingTest.java"
NestMembers:
  org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener
InnerClasses:
  private final TestListener = org.graalvm.compiler.truffle.test.CompilerLoggingTest$TestListener of org.graalvm.compiler.truffle.test.CompilerLoggingTest
  public final Builder = org.graalvm.polyglot.Context$Builder of org.graalvm.polyglot.Context