2011-05-03 20:13:51 -05:00
|
|
|
// xfail-stage1
|
|
|
|
// xfail-stage2
|
2011-07-20 21:37:09 -05:00
|
|
|
// xfail-stage3
|
2010-06-23 23:03:09 -05:00
|
|
|
// This checks that preemption works.
|
|
|
|
|
2011-07-27 07:19:39 -05:00
|
|
|
fn starve_main(alive: chan[int]) {
|
|
|
|
log "signalling main";
|
|
|
|
alive <| 1;
|
|
|
|
log "starving main";
|
|
|
|
let i: int = 0;
|
|
|
|
while true { i += 1; }
|
2010-06-23 23:03:09 -05:00
|
|
|
}
|
|
|
|
|
2011-04-19 15:35:49 -05:00
|
|
|
fn main() {
|
2011-07-27 07:19:39 -05:00
|
|
|
let alive: port[int] = port();
|
|
|
|
log "main started";
|
|
|
|
let s: task = spawn starve_main(chan(alive));
|
|
|
|
let i: int;
|
|
|
|
log "main waiting for alive signal";
|
|
|
|
alive |> i;
|
|
|
|
log "main got alive signal";
|
|
|
|
while i < 50 { log "main iterated"; i += 1; }
|
|
|
|
log "main completed";
|
2010-06-23 23:03:09 -05:00
|
|
|
}
|