From 23209e2f10a123aa7ccd512454cd18ace81a2476 Mon Sep 17 00:00:00 2001 From: Jason Zaugg Date: Fri, 9 Nov 2012 18:41:16 +0100 Subject: Test with less trivial types. Works like it says on the box. --- .../scala/async/run/toughtype/ToughType.scala | 39 ++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 src/test/scala/scala/async/run/toughtype/ToughType.scala (limited to 'src/test/scala') diff --git a/src/test/scala/scala/async/run/toughtype/ToughType.scala b/src/test/scala/scala/async/run/toughtype/ToughType.scala new file mode 100644 index 0000000..f576ddc --- /dev/null +++ b/src/test/scala/scala/async/run/toughtype/ToughType.scala @@ -0,0 +1,39 @@ +/** + * Copyright (C) 2012 Typesafe Inc. + */ + +package scala.async +package run +package toughtype + +import language.{reflectiveCalls, postfixOps} +import scala.concurrent._ +import scala.concurrent.duration._ +import scala.async.Async._ +import org.junit.Test +import org.junit.runner.RunWith +import org.junit.runners.JUnit4 + + +object ToughTypeObject { + + import ExecutionContext.Implicits.global + + class Inner + + def m2 = async[(List[_], ToughTypeObject.Inner)] { + val y = await(future[List[_]](Nil)) + val z = await(future[Inner](new Inner)) + (y, z) + } +} + +@RunWith(classOf[JUnit4]) +class ToughTypeSpec { + + @Test def `propogates tough types`() { + val fut = ToughTypeObject.m2 + val res: (List[_], scala.async.run.toughtype.ToughTypeObject.Inner) = Await.result(fut, 2 seconds) + res._1 mustBe (Nil) + } +} -- cgit v1.2.3