summaryrefslogtreecommitdiff
path: root/test/pending
diff options
context:
space:
mode:
authorPhilipp Haller <hallerp@gmail.com>2009-11-09 10:23:57 +0000
committerPhilipp Haller <hallerp@gmail.com>2009-11-09 10:23:57 +0000
commit6167e273e008614c08b08af656eb5e5d7f6a2e58 (patch)
tree8ef071fac67013f1cb9aeb90314f53294bff50fe /test/pending
parentc490722ae1b7a9147bcdc884e362409b4017d19f (diff)
downloadscala-6167e273e008614c08b08af656eb5e5d7f6a2e58.tar.gz
scala-6167e273e008614c08b08af656eb5e5d7f6a2e58.tar.bz2
scala-6167e273e008614c08b08af656eb5e5d7f6a2e58.zip
Moved (non-regression) actor-receive-sender tes...
Moved (non-regression) actor-receive-sender test to pending for bug fixing.
Diffstat (limited to 'test/pending')
-rw-r--r--test/pending/jvm/actor-receive-sender.check2
-rw-r--r--test/pending/jvm/actor-receive-sender.scala51
2 files changed, 53 insertions, 0 deletions
diff --git a/test/pending/jvm/actor-receive-sender.check b/test/pending/jvm/actor-receive-sender.check
new file mode 100644
index 0000000000..2c94e48371
--- /dev/null
+++ b/test/pending/jvm/actor-receive-sender.check
@@ -0,0 +1,2 @@
+OK
+OK
diff --git a/test/pending/jvm/actor-receive-sender.scala b/test/pending/jvm/actor-receive-sender.scala
new file mode 100644
index 0000000000..ea7c40cced
--- /dev/null
+++ b/test/pending/jvm/actor-receive-sender.scala
@@ -0,0 +1,51 @@
+import scala.actors.{Actor, TIMEOUT, Exit}
+import scala.actors.Actor._
+
+object Test {
+
+ val NUM = 2000
+
+ def main(args: Array[String]) {
+ var b: Actor = null
+ var c: Actor = null
+
+ val a = actor {
+ for (_ <- 0 until NUM)
+ receive {
+ case 'hello if sender == b => // do nothing
+ }
+ b ! 'ok
+ for (_ <- 0 until NUM)
+ receiveWithin (1000) {
+ case 'bye if sender == b => // do nothing
+ case TIMEOUT => b ! 'fail
+ }
+ b ! 'ok
+ }
+
+ b = actor {
+ self.trapExit = true
+ link(a)
+
+ for (_ <- 0 until NUM)
+ a ! 'hello
+
+ val proceed = receive {
+ case Exit(from, reason) => println("FAIL"); false
+ case 'ok => println("OK"); true
+ case other => println(other); false
+ }
+
+ if (proceed) {
+ for (_ <- 0 until NUM)
+ a ! 'bye
+ receive {
+ case Exit(from, reason) => println("FAIL")
+ case 'ok => println("OK")
+ case other => println(other)
+ }
+ }
+ }
+ }
+
+}