New attempt at fixing the tests. No review.

git-svn-id: http://lampsvn.epfl.ch/svn-repos/scala/scala/trunk@21121 5e8d7ff9-d8ef-0310-90f0-a4852d11357a
This commit is contained in:
phaller 2010-03-09 14:03:02 +00:00
parent 5734dfb80b
commit 7678303e15
3 changed files with 64 additions and 52 deletions

View File

@ -1,4 +1,5 @@
import scala.actors.{Reactor, Actor, TIMEOUT}
import Actor._
object Test {
@ -7,67 +8,78 @@ object Test {
println("FAIL ["+hint+"]")
}
def expectActorState(a: Reactor[T] forSome { type T }, s: Actor.State.Value) {
var done = false
var i = 0
while (!done) {
i = i + 1
if (i == 10) { // only wait for 2 seconds total
println("FAIL ["+a+": expected "+s+"]")
done = true
}
Thread.sleep(200)
if (a.getState == s) // success
done = true
}
}
def main(args: Array[String]) {
val a = new Reactor[Any] {
def act() {
assert(getState == Actor.State.Runnable, "runnable1")
react {
case 'go =>
println("OK")
actor {
val a = new Reactor[Any] {
def act() {
assert(getState == Actor.State.Runnable, "runnable1")
react {
case 'go =>
println("OK")
}
}
}
}
assert(a.getState == Actor.State.New, "new1")
expectActorState(a, Actor.State.New)
a.start()
Thread.sleep(200)
assert(a.getState == Actor.State.Suspended, "suspend1")
a.start()
expectActorState(a, Actor.State.Suspended)
a ! 'go
Thread.sleep(200)
assert(a.getState == Actor.State.Terminated, "terminated1")
a ! 'go
expectActorState(a, Actor.State.Terminated)
val b = new Actor {
def act() {
assert(getState == Actor.State.Runnable, "runnable2")
react {
case 'go =>
reactWithin(100000) {
case TIMEOUT =>
case 'go =>
receive {
case 'go =>
}
receiveWithin(100000) {
case TIMEOUT =>
case 'go =>
println("OK")
}
}
val b = new Actor {
def act() {
assert(getState == Actor.State.Runnable, "runnable2: "+getState)
react {
case 'go =>
reactWithin(100000) {
case TIMEOUT =>
case 'go =>
receive {
case 'go =>
}
receiveWithin(100000) {
case TIMEOUT =>
case 'go =>
println("OK")
}
}
}
}
}
expectActorState(b, Actor.State.New)
b.start()
expectActorState(b, Actor.State.Suspended)
b ! 'go
expectActorState(b, Actor.State.TimedSuspended)
b ! 'go
expectActorState(b, Actor.State.Blocked)
b ! 'go
expectActorState(b, Actor.State.TimedBlocked)
b ! 'go
expectActorState(b, Actor.State.Terminated)
}
assert(b.getState == Actor.State.New, "new2")
b.start()
Thread.sleep(200)
assert(b.getState == Actor.State.Suspended, "suspend2")
b ! 'go
Thread.sleep(200)
assert(b.getState == Actor.State.TimedSuspended, "timedsuspend2")
b ! 'go
Thread.sleep(200)
assert(b.getState == Actor.State.Blocked, "blocked2")
b ! 'go
Thread.sleep(200)
assert(b.getState == Actor.State.TimedBlocked, "timedblocked2")
b ! 'go
Thread.sleep(200)
assert(b.getState == Actor.State.Terminated, "terminated2")
}
}