about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorJohn Kåre Alsaker <john.kare.alsaker@gmail.com>2017-07-08 00:58:33 +0200
committerJohn Kåre Alsaker <john.kare.alsaker@gmail.com>2017-07-28 15:46:23 +0200
commitcc40f58b8ba7019f52acd4e8da015ddd249db86a (patch)
tree553ec7f9ebdd4030573df86abfc69a32ad6569db /src
parent0b5b0122ae283df567d1b2fddd7fc4ad17125fb5 (diff)
downloadrust-cc40f58b8ba7019f52acd4e8da015ddd249db86a.tar.gz
rust-cc40f58b8ba7019f52acd4e8da015ddd249db86a.zip
Added some tests
Diffstat (limited to 'src')
-rw-r--r--src/test/compile-fail/generator/invalid-positions.rs23
-rw-r--r--src/test/compile-fail/generator/no-arguments-on-generators.rs (renamed from src/test/compile-fail/generator/const-yield.rs)9
-rw-r--r--src/test/run-pass/generator/implicit-argument-dead-when-suspended.rs (renamed from src/test/compile-fail/generator/generator-not-fnmut.rs)24
3 files changed, 44 insertions, 12 deletions
diff --git a/src/test/compile-fail/generator/invalid-positions.rs b/src/test/compile-fail/generator/invalid-positions.rs
new file mode 100644
index 00000000000..c2f5b20d575
--- /dev/null
+++ b/src/test/compile-fail/generator/invalid-positions.rs
@@ -0,0 +1,23 @@
+// Copyright 2017 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.
+
+#![feature(generators)]
+
+const A: u8 = { yield 3u8; gen arg; 3u8};
+//~^ ERROR yield statement outside
+//~| ERROR gen arg expression outside
+
+static B: u8 = { yield 3u8; gen arg; 3u8};
+//~^ ERROR yield statement outside
+//~| ERROR gen arg expression outside
+
+fn main() { yield; gen arg; }
+//~^ ERROR yield statement outside
+//~| ERROR gen arg expression outside
diff --git a/src/test/compile-fail/generator/const-yield.rs b/src/test/compile-fail/generator/no-arguments-on-generators.rs
index fa99e8553a0..9c68fe4ceda 100644
--- a/src/test/compile-fail/generator/const-yield.rs
+++ b/src/test/compile-fail/generator/no-arguments-on-generators.rs
@@ -10,7 +10,8 @@
 
 #![feature(generators)]
 
-const A: u8 = { yield 3u8; 3u8}; //~ ERROR yield statement outside of function body
-static B: u8 = { yield 3u8; 3u8}; //~ ERROR yield statement outside of function body
-
-fn main() {}
\ No newline at end of file
+fn main() {
+    let gen = |start| { //~ ERROR generators cannot have explicit arguments
+        yield;
+    }; 
+}
\ No newline at end of file
diff --git a/src/test/compile-fail/generator/generator-not-fnmut.rs b/src/test/run-pass/generator/implicit-argument-dead-when-suspended.rs
index 460db8e3819..722ec2477ef 100644
--- a/src/test/compile-fail/generator/generator-not-fnmut.rs
+++ b/src/test/run-pass/generator/implicit-argument-dead-when-suspended.rs
@@ -10,16 +10,24 @@
 
 #![feature(generators)]
 
+use std::cell::Cell;
+
+struct Flag<'a>(&'a Cell<bool>);
+
+impl<'a> Drop for Flag<'a> {
+    fn drop(&mut self) {
+        self.0.set(false)
+    }
+}
+
 fn main() {
-    let mut a = Vec::<bool>::new();
+    let alive = Cell::new(true);
 
-    let mut test = || {
-        let _: () = gen arg;
-        yield 3;
-        a.push(true);
-        2
+    let gen = || {
+        yield;
     };
 
-    let a1 = test();
-    let a2 = test(); //~ ERROR use of moved value
+    gen.resume(Flag(&alive));
+
+    assert_eq!(alive.get(), false);
 }