From b0bf1b46820d74c30a725a7ea332305098bf3def Mon Sep 17 00:00:00 2001 From: Masaki Hara Date: Wed, 14 Jun 2017 12:27:51 +0900 Subject: [PATCH] Split dst-dtor-{1,2} tests into four. --- src/test/run-pass-valgrind/dst-dtor-1.rs | 3 +-- src/test/run-pass-valgrind/dst-dtor-2.rs | 3 +-- src/test/run-pass-valgrind/dst-dtor-3.rs | 32 ++++++++++++++++++++++++ src/test/run-pass-valgrind/dst-dtor-4.rs | 29 +++++++++++++++++++++ 4 files changed, 63 insertions(+), 4 deletions(-) create mode 100644 src/test/run-pass-valgrind/dst-dtor-3.rs create mode 100644 src/test/run-pass-valgrind/dst-dtor-4.rs diff --git a/src/test/run-pass-valgrind/dst-dtor-1.rs b/src/test/run-pass-valgrind/dst-dtor-1.rs index 00bfebb3f1e..4af642a106c 100644 --- a/src/test/run-pass-valgrind/dst-dtor-1.rs +++ b/src/test/run-pass-valgrind/dst-dtor-1.rs @@ -28,8 +28,7 @@ struct Fat { pub fn main() { { - let _x: Box<(i32, Fat)> = - Box::<(i32, Fat)>::new((42, Fat { f: Foo })); + let _x: Box> = Box::>::new(Fat { f: Foo }); } unsafe { assert!(DROP_RAN); diff --git a/src/test/run-pass-valgrind/dst-dtor-2.rs b/src/test/run-pass-valgrind/dst-dtor-2.rs index fa0c6c03225..283b8202b35 100644 --- a/src/test/run-pass-valgrind/dst-dtor-2.rs +++ b/src/test/run-pass-valgrind/dst-dtor-2.rs @@ -25,8 +25,7 @@ struct Fat { pub fn main() { { - let _x: Box<(Fat<[Foo]>,)> = - Box::<(Fat<[Foo; 3]>,)>::new((Fat { f: [Foo, Foo, Foo] },)); + let _x: Box> = Box::>::new(Fat { f: [Foo, Foo, Foo] }); } unsafe { assert_eq!(DROP_RAN, 3); diff --git a/src/test/run-pass-valgrind/dst-dtor-3.rs b/src/test/run-pass-valgrind/dst-dtor-3.rs new file mode 100644 index 00000000000..b21f6434b54 --- /dev/null +++ b/src/test/run-pass-valgrind/dst-dtor-3.rs @@ -0,0 +1,32 @@ +// 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 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// no-prefer-dynamic + +static mut DROP_RAN: bool = false; + +struct Foo; +impl Drop for Foo { + fn drop(&mut self) { + unsafe { DROP_RAN = true; } + } +} + +trait Trait { fn dummy(&self) { } } +impl Trait for Foo {} + +pub fn main() { + { + let _x: Box<(i32, Trait)> = Box::<(i32, Foo)>::new((42, Foo)); + } + unsafe { + assert!(DROP_RAN); + } +} diff --git a/src/test/run-pass-valgrind/dst-dtor-4.rs b/src/test/run-pass-valgrind/dst-dtor-4.rs new file mode 100644 index 00000000000..810589de770 --- /dev/null +++ b/src/test/run-pass-valgrind/dst-dtor-4.rs @@ -0,0 +1,29 @@ +// 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 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// no-prefer-dynamic + +static mut DROP_RAN: isize = 0; + +struct Foo; +impl Drop for Foo { + fn drop(&mut self) { + unsafe { DROP_RAN += 1; } + } +} + +pub fn main() { + { + let _x: Box<(i32, [Foo])> = Box::<(i32, [Foo; 3])>::new((42, [Foo, Foo, Foo])); + } + unsafe { + assert_eq!(DROP_RAN, 3); + } +}