From bab1cbc10a4c15cefecda7435ffaf9be51fbe3c4 Mon Sep 17 00:00:00 2001 From: phaller Date: Fri, 9 Nov 2012 10:11:19 +0100 Subject: Add failing test case for local classes inside async blocks --- .../run/local-classes0/LocalClasses0Spec.scala | 45 ++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 src/test/scala/scala/async/run/local-classes0/LocalClasses0Spec.scala (limited to 'src/test') diff --git a/src/test/scala/scala/async/run/local-classes0/LocalClasses0Spec.scala b/src/test/scala/scala/async/run/local-classes0/LocalClasses0Spec.scala new file mode 100644 index 0000000..6b8fc4b --- /dev/null +++ b/src/test/scala/scala/async/run/local-classes0/LocalClasses0Spec.scala @@ -0,0 +1,45 @@ +package scala.async +package run +package await0 + +/** + * Copyright (C) 2012 Typesafe Inc. + */ + +import language.{reflectiveCalls, postfixOps} + +import scala.concurrent.{Future, ExecutionContext, future, Await} +import scala.concurrent.duration._ +import scala.async.Async.{async, await} +import org.junit.runner.RunWith +import org.junit.runners.JUnit4 +import org.junit.Test + +class LocalClasses0Class { + + import ExecutionContext.Implicits.global + + def base(x: Int): Future[Int] = future { + x + 2 + } + + def methodWithLocalClass(): Future[Int] = async { + case class Person(name: String) + val fut = base(10) + val x = await(fut) + x + 1 + } +} + +@RunWith(classOf[JUnit4]) +class LocalClasses0Spec { + + @Test + def `An async method should reject local classes without crashing`() { + val o = new LocalClasses0Class + val fut = o.methodWithLocalClass() + val res = Await.result(fut, 2 seconds) + res mustBe (13) + } +} + -- cgit v1.2.3