summaryrefslogtreecommitdiff
path: root/test/files/jvm/t7146.scala
blob: aaa3dc7ca46b834d7f5405f9568231be709984c8 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
import scala.language.{ reflectiveCalls }
import java.util.concurrent.Executor
import scala.concurrent._
import scala.util.control.NoStackTrace

object Test {
  def main(args: Array[String]) {
    println("should be scala.concurrent.impl.ExecutionContextImpl == " +
      ExecutionContext.global.toString.startsWith("scala.concurrent.impl.ExecutionContextImpl"))
    val i = ExecutionContext.global.asInstanceOf[{ def executor: Executor }]
    println("should be scala.concurrent.forkjoin.ForkJoinPool == " +
      i.executor.toString.startsWith("scala.concurrent.forkjoin.ForkJoinPool"))
    val u = i.executor.
             asInstanceOf[{ def getUncaughtExceptionHandler: Thread.UncaughtExceptionHandler }].
             getUncaughtExceptionHandler
    println("should have non-null UncaughtExceptionHandler == " + (u ne null))
    println("should be a scala.concurrent.impl.ExecutionContextImpl UncaughtExceptionHandler == " +
      u.toString.startsWith("scala.concurrent.impl.ExecutionContextImpl"))
    print("should just print out on uncaught == ")
    u.uncaughtException(Thread.currentThread, new Throwable {
      override def printStackTrace() { println("true") }
    })
  }
}