Skip to content

Commit

Permalink
TEST: Test both panic and non-panic cases for apply_collect
Browse files Browse the repository at this point in the history
  • Loading branch information
bluss committed Apr 29, 2020
1 parent fabea29 commit 089aedf
Showing 1 changed file with 66 additions and 0 deletions.
66 changes: 66 additions & 0 deletions tests/azip.rs
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,72 @@ fn test_zip_assign_into_cell() {
assert_abs_diff_eq!(a2, &b + &c, epsilon = 1e-6);
}

#[test]
fn test_zip_collect_drop() {
use std::cell::RefCell;
use std::panic;

struct Recorddrop<'a>((usize, usize), &'a RefCell<Vec<(usize, usize)>>);

impl<'a> Drop for Recorddrop<'a> {
fn drop(&mut self) {
self.1.borrow_mut().push(self.0);
}
}

#[derive(Copy, Clone)]
enum Config {
CC,
CF,
FF,
}

impl Config {
fn a_is_f(self) -> bool {
match self {
Config::CC | Config::CF => false,
_ => true,
}
}
fn b_is_f(self) -> bool {
match self {
Config::CC => false,
_ => true,
}
}
}

let test_collect_panic = |config: Config, will_panic: bool| {
let mut inserts = RefCell::new(Vec::new());
let mut drops = RefCell::new(Vec::new());

let a = Array::from_shape_fn((5, 10).set_f(config.a_is_f()), |idx| idx);
let b = Array::from_shape_fn((5, 10).set_f(config.b_is_f()), |_| 0);

let _result = panic::catch_unwind(panic::AssertUnwindSafe(|| {
Zip::from(&a).and(&b).apply_collect(|&elt, _| {
if elt.0 > 3 && will_panic {
panic!();
}
inserts.borrow_mut().push(elt);
Recorddrop(elt, &drops)
});
}));

println!("{:?}", inserts.get_mut());
println!("{:?}", drops.get_mut());

assert_eq!(inserts.get_mut().len(), drops.get_mut().len(), "Incorrect number of drops");
assert_eq!(inserts.get_mut(), drops.get_mut(), "Incorrect order of drops");
};

for &should_panic in &[true, false] {
test_collect_panic(Config::CC, should_panic);
test_collect_panic(Config::CF, should_panic);
test_collect_panic(Config::FF, should_panic);
}
}


#[test]
fn test_azip_syntax_trailing_comma() {
Expand Down

0 comments on commit 089aedf

Please sign in to comment.