diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2017-07-14 15:53:15 -0700 |
|---|---|---|
| committer | John Kåre Alsaker <john.kare.alsaker@gmail.com> | 2017-07-28 15:46:25 +0200 |
| commit | 12bbcd3c294a96ea915048a9bd525ee9074390f1 (patch) | |
| tree | 5673aa40e56aca3f3b464352de96cd755ab5c67c | |
| parent | 77bf6e4461404dce1bb06a7804dcceaf4e819836 (diff) | |
| download | rust-12bbcd3c294a96ea915048a9bd525ee9074390f1.tar.gz rust-12bbcd3c294a96ea915048a9bd525ee9074390f1.zip | |
Add a test case for conditional drop
| -rw-r--r-- | src/test/run-pass/generator/conditional-drop.rs | 65 |
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); +} |
