about summary refs log tree commit diff
diff options
context:
space:
mode:
authorAlex Crichton <alex@alexcrichton.com>2017-07-14 15:53:15 -0700
committerJohn Kåre Alsaker <john.kare.alsaker@gmail.com>2017-07-28 15:46:25 +0200
commit12bbcd3c294a96ea915048a9bd525ee9074390f1 (patch)
tree5673aa40e56aca3f3b464352de96cd755ab5c67c
parent77bf6e4461404dce1bb06a7804dcceaf4e819836 (diff)
downloadrust-12bbcd3c294a96ea915048a9bd525ee9074390f1.tar.gz
rust-12bbcd3c294a96ea915048a9bd525ee9074390f1.zip
Add a test case for conditional drop
-rw-r--r--src/test/run-pass/generator/conditional-drop.rs65
1 files changed, 65 insertions, 0 deletions
diff --git a/src/test/run-pass/generator/conditional-drop.rs b/src/test/run-pass/generator/conditional-drop.rs
new file mode 100644
index 00000000000..8329684e1a3
--- /dev/null
+++ b/src/test/run-pass/generator/conditional-drop.rs
@@ -0,0 +1,65 @@
+// 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, generator_trait)]
+
+use std::ops::Generator;
+use std::sync::atomic::{AtomicUsize, ATOMIC_USIZE_INIT, Ordering};
+
+static A: AtomicUsize = ATOMIC_USIZE_INIT;
+
+struct B;
+
+impl Drop for B {
+    fn drop(&mut self) {
+        A.fetch_add(1, Ordering::SeqCst);
+    }
+}
+
+
+fn test() -> bool { true }
+fn test2() -> bool { false }
+
+fn main() {
+    t1();
+    t2();
+}
+
+fn t1() {
+    let mut a = || {
+        let b = B;
+        if test() {
+            drop(b);
+        }
+        yield;
+    };
+
+    let n = A.load(Ordering::SeqCst);
+    a.resume();
+    assert_eq!(A.load(Ordering::SeqCst), n + 1);
+    a.resume();
+    assert_eq!(A.load(Ordering::SeqCst), n + 1);
+}
+
+fn t2() {
+    let mut a = || {
+        let b = B;
+        if test2() {
+            drop(b);
+        }
+        yield;
+    };
+
+    let n = A.load(Ordering::SeqCst);
+    a.resume();
+    assert_eq!(A.load(Ordering::SeqCst), n);
+    a.resume();
+    assert_eq!(A.load(Ordering::SeqCst), n + 1);
+}