diff options
| author | Michael Bebenita <[email protected]> | 2010-07-28 16:58:17 -0700 |
|---|---|---|
| committer | Graydon Hoare <[email protected]> | 2010-07-28 20:30:30 -0700 |
| commit | 74a79fff3aa1374e6dc5ef75deb8f216cb3136c9 (patch) | |
| tree | a8637f58321ac19e1eab66040b2bb7e446a98804 /src/test | |
| parent | Log dead tasks when dom is just waiting for refcounts to drop. (diff) | |
| download | rust-74a79fff3aa1374e6dc5ef75deb8f216cb3136c9.tar.xz rust-74a79fff3aa1374e6dc5ef75deb8f216cb3136c9.zip | |
Add a bunch of comm tests.
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/run-pass/task-comm-2.rs | 14 | ||||
| -rw-r--r-- | src/test/run-pass/task-comm-6.rs | 36 | ||||
| -rw-r--r-- | src/test/run-pass/task-comm-7.rs | 44 | ||||
| -rw-r--r-- | src/test/run-pass/task-comm-8.rs | 44 | ||||
| -rw-r--r-- | src/test/run-pass/task-comm-9.rs | 30 |
5 files changed, 162 insertions, 6 deletions
diff --git a/src/test/run-pass/task-comm-2.rs b/src/test/run-pass/task-comm-2.rs index 9151c7b1..9c85da34 100644 --- a/src/test/run-pass/task-comm-2.rs +++ b/src/test/run-pass/task-comm-2.rs @@ -1,8 +1,8 @@ -fn main() -> () { - log "===== THREADS ====="; - test00(true); - log "====== TASKS ======"; - test00(false); +fn main() -> () { + log "===== THREADS ====="; + test00(true); + log "====== TASKS ======"; + // test00(false); } fn start(int task_number) { @@ -15,7 +15,7 @@ fn start(int task_number) { } fn test00(bool create_threads) { - let int number_of_tasks = 32; + let int number_of_tasks = 0; let int i = 0; let vec[task] tasks = vec(); @@ -31,4 +31,6 @@ fn test00(bool create_threads) { for (task t in tasks) { join t; } + + log "Joined all task."; }
\ No newline at end of file diff --git a/src/test/run-pass/task-comm-6.rs b/src/test/run-pass/task-comm-6.rs new file mode 100644 index 00000000..c579a98c --- /dev/null +++ b/src/test/run-pass/task-comm-6.rs @@ -0,0 +1,36 @@ +io fn main() -> () { + test00(); +} + +io fn test00() { + let int r = 0; + let int sum = 0; + let port[int] p = port(); + + let chan[int] c0 = chan(p); + let chan[int] c1 = chan(p); + let chan[int] c2 = chan(p); + let chan[int] c3 = chan(p); + + let int number_of_messages = 1000; + + let int i = 0; + while (i < number_of_messages) { + c0 <| i; + c1 <| i; + c2 <| i; + c3 <| i; + i += 1; + } + + 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; + } + + check (sum == 4 * ((number_of_messages * (number_of_messages - 1)) / 2)); +}
\ No newline at end of file diff --git a/src/test/run-pass/task-comm-7.rs b/src/test/run-pass/task-comm-7.rs new file mode 100644 index 00000000..bb59807d --- /dev/null +++ b/src/test/run-pass/task-comm-7.rs @@ -0,0 +1,44 @@ +io fn main() -> () { + test00(); +} + +io 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; + } +} + +io 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; + + check (sum == (((number_of_messages * 4) * + ((number_of_messages * 4) - 1)) / 2)); +}
\ No newline at end of file diff --git a/src/test/run-pass/task-comm-8.rs b/src/test/run-pass/task-comm-8.rs new file mode 100644 index 00000000..c5f73a3f --- /dev/null +++ b/src/test/run-pass/task-comm-8.rs @@ -0,0 +1,44 @@ +io fn main() -> () { + test00(); +} + +io 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; + } +} + +io 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 thread test00_start(chan(p), + number_of_messages * 0, number_of_messages); + let task t1 = spawn thread test00_start(chan(p), + number_of_messages * 1, number_of_messages); + let task t2 = spawn thread test00_start(chan(p), + number_of_messages * 2, number_of_messages); + let task t3 = spawn thread 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; + + check (sum == (((number_of_messages * 4) * + ((number_of_messages * 4) - 1)) / 2)); +}
\ No newline at end of file diff --git a/src/test/run-pass/task-comm-9.rs b/src/test/run-pass/task-comm-9.rs new file mode 100644 index 00000000..e6ca84f5 --- /dev/null +++ b/src/test/run-pass/task-comm-9.rs @@ -0,0 +1,30 @@ +io fn main() -> () { + test00(); +} + +io fn test00_start(chan[int] c, int number_of_messages) { + let int i = 0; + while (i < number_of_messages) { + c <| i; + i += 1; + } +} + +io 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 thread test00_start(chan(p), number_of_messages); + + let int i = 0; + while (i < number_of_messages) { + r <- p; sum += r; log (r); + i += 1; + } + + join t0; + + check (sum == (number_of_messages * (number_of_messages - 1)) / 2); +}
\ No newline at end of file |