aboutsummaryrefslogtreecommitdiff
path: root/src/test/run-pass/task-comm-7.rs
blob: e236f69e2f802876a904c8efa66363b38fec2d3b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// xfail-stage0
// xfail-stage1
// xfail-stage2
fn main() -> () {
   test00();
}

fn test00_start(chan[int] c, int start, int number_of_messages) {
    let int i = 0;
    while (i < number_of_messages) {
        c <| start + i;
        i += 1;
    }    
}

fn test00() {
    let int r = 0;    
    let int sum = 0;
    let port[int] p = port();
    let int number_of_messages = 10;
        
    let task t0 = spawn test00_start(chan(p), 
                        number_of_messages * 0, number_of_messages);
    let task t1 = spawn test00_start(chan(p), 
                        number_of_messages * 1, number_of_messages);
    let task t2 = spawn test00_start(chan(p), 
                        number_of_messages * 2, number_of_messages);
    let task t3 = spawn test00_start(chan(p), 
                        number_of_messages * 3, number_of_messages);
    
    let int i = 0;
    while (i < number_of_messages) {
        r <- p; sum += r;
        r <- p; sum += r;
        r <- p; sum += r;
        r <- p; sum += r;
        i += 1;
    }
            
    join t0;
    join t1;
    join t2;
    join t3;
    
    assert (sum == (((number_of_messages * 4) * 
                   ((number_of_messages * 4) - 1)) / 2));
}