]> git.lizzy.rs Git - rust.git/commitdiff
add tests
authorJorge Aparicio <japaricious@gmail.com>
Fri, 23 Jan 2015 02:50:11 +0000 (21:50 -0500)
committerJorge Aparicio <japaricious@gmail.com>
Fri, 30 Jan 2015 15:37:44 +0000 (10:37 -0500)
src/test/compile-fail/for-loop-hygiene.rs [new file with mode: 0644]
src/test/run-pass/for-loop-into-iterator.rs [new file with mode: 0644]

diff --git a/src/test/compile-fail/for-loop-hygiene.rs b/src/test/compile-fail/for-loop-hygiene.rs
new file mode 100644 (file)
index 0000000..ff6f848
--- /dev/null
@@ -0,0 +1,20 @@
+// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+// for-loops are expanded in the front end, and use an `iter` ident in their expansion. Check that
+// `iter` is not accessible inside the for loop.
+
+#![allow(unstable)]
+
+fn main() {
+    for _ in 0..10 {
+        iter.next();  //~ error: unresolved name `iter`
+    }
+}
diff --git a/src/test/run-pass/for-loop-into-iterator.rs b/src/test/run-pass/for-loop-into-iterator.rs
new file mode 100644 (file)
index 0000000..7564efb
--- /dev/null
@@ -0,0 +1,27 @@
+// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+// Test that for loops can do what RFC #235 claims
+
+fn main() {
+    let mut v = vec![1];
+
+    for x in &v {
+        assert_eq!(x, &1);
+    }
+
+    for x in &mut v {
+        assert_eq!(x, &mut 1);
+    }
+
+    for x in v {
+        assert_eq!(x, 1);
+    }
+}