rust/src/test/run-pass/vec-self-append.rs

50 lines
1.0 KiB
Rust
Raw Normal View History

use std;
import vec;
2011-08-22 15:04:28 -07:00
fn test_heap_to_heap() {
// a spills onto the heap
let a = [0, 1, 2, 3, 4];
a += a;
2011-09-02 15:34:58 -07:00
assert (vec::len(a) == 10u);
assert (a[0] == 0);
assert (a[1] == 1);
assert (a[2] == 2);
assert (a[3] == 3);
assert (a[4] == 4);
assert (a[5] == 0);
assert (a[6] == 1);
assert (a[7] == 2);
assert (a[8] == 3);
assert (a[9] == 4);
2011-08-22 15:04:28 -07:00
}
fn test_stack_to_heap() {
// a is entirely on the stack
let a = [0, 1, 2];
// a spills to the heap
a += a;
2011-09-02 15:34:58 -07:00
assert (vec::len(a) == 6u);
assert (a[0] == 0);
assert (a[1] == 1);
assert (a[2] == 2);
assert (a[3] == 0);
assert (a[4] == 1);
assert (a[5] == 2);
2011-08-22 15:04:28 -07:00
}
fn test_loop() {
// Make sure we properly handle repeated self-appends.
2011-08-22 15:04:28 -07:00
let a: [int] = [0];
2011-07-27 14:19:39 +02:00
let i = 20;
let expected_len = 1u;
while i > 0 {
2011-08-15 16:38:23 -07:00
log_err vec::len(a);
assert (vec::len(a) == expected_len);
a += a;
i -= 1;
expected_len *= 2u;
}
}
2011-08-22 15:04:28 -07:00
2011-09-02 15:34:58 -07:00
fn main() { test_heap_to_heap(); test_stack_to_heap(); test_loop(); }